首页 > 其他分享 >微服务分布式springcloud高校竞赛活动报名管理系统

微服务分布式springcloud高校竞赛活动报名管理系统

时间:2024-10-28 12:46:39浏览次数:8  
标签:userService 竞赛活动 springcloud Eureka user Spring return Cloud 分布式

目录

课题介绍

与高校竞赛活动报名管理系统管理者及学生交流后经过详细缜密的思考,再讨论研究后得出的初步系统开发所需实现功能。这是开发的第一步,也是至关重要的一步,如果不在这个阶段制定系统所需模块,日后会带来不必要的麻烦。因此,必须严肃认真,全身心投入去做好这个步骤。
课题要求实现一套高校竞赛活动报名管理系统,系统主要包括竞赛项目、项目类型、比赛报名、比赛成绩、录入证书、发放证书、获奖名单、发放学分等功能模块。 该系统将采用B/S结构模式
技术栈
前端:vue.js+ElementUI
开发工具:IDEA 或者eclipse都支持
编程语言: java
框架:springboot-springcloud
数据库: mysql 版本不限
数据库工具:Navicat/SQLyog都可以

具体实现截图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

开发核心技术:

Springboot简介:
Springboot是一Spring级框架为基础的的全新轻量级框架。其前身Spring框架首发是轻量级框架,目的是减轻了开发人员多负担。后期大量升级导致变得笨重,违背了框架的初衷。
Spring Boot内置了Tomcat、Jetty和Undertow等服务器,这意味着你可以直接使用它们而不需要额外的安装和配置。Spring Boot的一个主要优点是它的自动配置功能。它可以根据你的项目中的依赖关系自动配置应用程序。这使得配置应用程序变得非常容易,因为你不需要手动配置每个依赖项。
Spring Boot也提供了大量的开箱即用的功能和插件,如Spring Data、Spring Security和Spring Cloud等。这些功能使得开发者可以更快速地构建应用程序,并且可以更容易地扩展和集成其他技术。它是一个非常流行的框架,它的自动配置、内置服务器和插件等功能使得开发者可以更快、更轻松地构建高质量的应用程序。
Spring Cloud
Spring Cloud构建分布式系统不需要复杂和容易出错。Spring Cloud 为最常见的分布式系统模式提供了一种简单且易于接受的编程模型,帮助开发人员构建有弹性的、可靠的、协调的应用程序。Spring Cloud 构建于 Spring Boot 之上,使得开发者很容易入手并快速应用于生产中。
Eureka:
Spring Cloud Eureka是Spring Cloud Netflix微服务套件中的一部分,它基于Netflix Eureka做了二次封装。主要负责完成微服务架构中的服务治理功能。

Eureka服务端,即服务注册中心。它同其他服务注册中心一样,支持高可用配置。依托于强一致性提供良好的服务实例可用性,可以应对多种不同的故障场景。
Mybatis简介:
Mybatis是基于Mysql的一个优秀的持久层框架,其几乎将所有连接Java语言需要配置的地方包括JDBC都封装起来,不在向JDBC那样繁琐,让开发人员专注于编写SQL语句,其内部页添加了许多自己的规则,以便让Spring框架与其无缝结合。
前端框架Vue
Vue.js的核心是虚拟DOM技术。虚拟DOM是一个内存中的数据结构,它可以帮助Vue.js实现高效的DOM操作,它采用了响应式数据绑定、虚拟DOM、组件化等现代化技术,为开发者提供了一种灵活、高效、易于维护的开发模式,当数据发生变化时,UI也会自动更新,这样就使得开发者可以更加专注于数据处理,而不是手动更新UI,这就是Vue体现出来的简洁,灵活,高效。

开发工具

IntelliJ IDEA: 一先进的IDE,用于java开发,提供了丰富的工具和功能。
后端技术
SpinrgBoot的主要优点有:
1、为所有spring开发提供了一个更快、更广泛的入门体验;
2、零配置;
3、集成了大量常用的第三方库的配置;
Maven: 项目管理和构建自动化工具,用于java项目。
java: 广泛使用的编程语言,适用于构建跨平台应用。
Springmvc:从而在使用Spring进行WEB开发时,可以选择使用Spring的Spring MVC框架。
MyBatis: java持久层框架,支持定制化SQL、存储过程以及高级映射。
Spring: 开源的java平台,提供了全面的编程和配置模型。

开发技术Spring Cloud Eureka

Spring Cloud Eureka是Spring Cloud Netflix微服务套件中的一部分,它基于Netflix Eureka做了二次封装。主要负责完成微服务架构中的服务治理功能。
SpringCloud 是一套基于 SpringCloud 构建的通用工具集,适合用于快速地构建分布式系统。作为微服务的开发框架,其整合并增强了微服务架构中常用的组件,如
Eureka、Zuul 等,具有功能齐全、开箱即用、适用于各种环境等特点[6]。这些服务
组件框架的实现,来自于 SpringCloud 的 Netflix 工具包,主要包括以下部分:
1)、 Netflix Eureka:服务发现和注册工具,主要包含 Eureka Server 和
Eureka Client 两个组件
2)、 Netflix Zuul:前后端数据交互的 API 网关
3)、 Netflix Ribbon:实现服务调用以及负载均衡的客户端工具,是一款
云中间层服务的开源项目,由国外的 Netflix 发布和维护,主要目的是提供
客户端负载均衡算法,Ribbon 组件提供了一系列完善的配置项,业主可根
据需要自行选择[7]。

详细视频演示

请联系我获取更详细的演示视频

核心代码部分展示

/**
 * 登录相关
 */
@RequestMapping("users")
@RestController
public class UsersController{
	
	@Autowired
	private UsersService userService;
	
	@Autowired
	private TokenService tokenService;

	/**
	 * 登录
	 */
	@IgnoreAuth
	@PostMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
		if(user==null || !user.getPassword().equals(password)) {
			return R.error("账号或密码不正确");
		}
		String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
		return R.ok().put("token", token);
	}
	
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UsersEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }

	/**
	 * 退出
	 */
	@GetMapping(value = "logout")
	public R logout(HttpServletRequest request) {
		request.getSession().invalidate();
		return R.ok("退出成功");
	}
	
	/**
     * 密码重置
     */
    @IgnoreAuth
	@RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
    	user.setPassword("123456");
        userService.update(user,null);
        return R.ok("密码已重置为:123456");
    }
	
	/**
     * 列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,UsersEntity user){
        EntityWrapper<UsersEntity> ew = new EntityWrapper<UsersEntity>();
    	PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
        return R.ok().put("data", page);
    }

	/**
     * 列表
     */
    @RequestMapping("/list")
    public R list( UsersEntity user){
       	EntityWrapper<UsersEntity> ew = new EntityWrapper<UsersEntity>();
      	ew.allEq(MPUtil.allEQMapPre( user, "user")); 
        return R.ok().put("data", userService.selectListView(ew));
    }

    /**
     * 信息
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") String id){
        UsersEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }
    
    /**
     * 获取用户的session用户信息
     */
    @RequestMapping("/session")
    public R getCurrUser(HttpServletRequest request){
    	Long id = (Long)request.getSession().getAttribute("userId");
        UsersEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }

系统设计

为了确保系统的正确性和可靠性,需要对不同的模块进行审查,在代码完成后对系统进行测试必不可少。(1)代码逻辑测试,代码的质量决定了模块运行的持续性。因此,在编写代码时,必须严格按照测试的要求进行编写,测试输出是否符合预期的要求。(2)功能性测试,为了测试模块之间的衔接是否紧密,各个功能之间的组合是否符合最初系统设计的要求,有一些细微的功能上的差别是否会影响到系统的运行,本系统虽然还是存在一些细小的误差,但是不会影响整个系统的运行。(3)压力测试,当多个管理员登录系统进行操作时,测试服务器是否能承载。经过以上测试发现本系统存在一些不足和缺点,一边测试一边进行修改,力争使本系统符合要求。
采用MVC框架,MVC英文全称是Model View Controller,翻译过来是是模型——视图——控制器模型的缩写,MVC是一种软件设计方法,其中心思想是把存储数据、业务逻辑、存储数据和用户显示三者分离开来,单独控制每一个模块。MVC的作用是把一系列相关的商业逻辑都部署和封装到同一个部件中,这样在显示层需要发生修改的时候,不需要重新编写业务逻辑。

需求分析

系统需求分析就是在实际设计前对系统功能、界面的分析,通俗的说即这个系统需要做什么,要达到什么样的效果,可以说需求分析是在软件设计前重要的环节。细致具体的需求分析可以避免不必要的返工。
过程永远比结果重要。毕业设计是大学生活中最为浓墨重彩的一笔,在这个过程中不仅学到更为全面的书本和实践知识,更让我感受到了浓浓的同窗之情及师生情。虽然大学四年间做过不少实验作业,但是独立完成这样一个操作系统还是第一次,遇到困难时理所当然,我也有所心理准备,但是超出自身能力的部分还是需要寻求教师及同学的帮助。

可行性论证

本系统作为以java作为开发语言的系统,而且选用springcloud微服务架构和B/S结构则决定了要操作本系统仅需要占用很小的资源,并没有过多地硬件配置要求,目前市面上只要能正常运行浏览器的个人电脑都可以正常运行使用该系统。
本系统主要使用Java、mySQL、B/S架构以及 SpringCloud等技术进行整合开发。数据库开发则使用mySQL语言进行数据库的开发,在众多的数据库管理系统中mysql是最灵活方便的,它是网站开发最常用的语言,mysql数据库使得开发人员开发数据库更加的方便快捷,灵活有效。因此,从技术上来说,本系统在技术上是可行的。

源码获取

需要成品,加我们的时候,记得把视频页面截图发下我,方便查找相应的源代码。可以的话 顺便点赞!
文章下方名片联系我即可~

标签:userService,竞赛活动,springcloud,Eureka,user,Spring,return,Cloud,分布式
From: https://blog.csdn.net/dongyun2022/article/details/143298239

相关文章

  • 鸿蒙跨设备协同开发08——使用分布式数据对象接续应用
    如果你也对鸿蒙开发感兴趣,加入“Harmony自习室”吧!扫描下方名片,关注公众号,公众号更新更快,同时也有更多学习资料和技术讨论群。1、前言本文是基于鸿蒙跨设备协同开发07——动态控制应用接续的进一步讨论。我们在鸿蒙跨设备协同开发06——应用接续中有提到:为了接续体验,在o......
  • Hadoop分布式系统架构
    Hadoop分布式系统架构Hadoop已经非常火了,Greenplum的开源跟它也是脱不了关系的。它有着高可靠性、高扩展性、高效性、高容错性的口碑。在互联网领域有着非常广泛的运用,雅虎、Facebook、百度、淘宝、京东等都在使用Hadoop。Hadoop生态体系非常庞大,各公司基于Hadoop所实现的......
  • SpringCloud Alibaba 06 (配置中心 Nacos Config)
    目录了解微服务常用的概念了解项目架构演变掌握微服务环境搭建掌握微服务治理组件-NacosDiscovery掌握微服务负载均衡调度组件-Ribbon掌握微服务远程调度组件-Feign掌握微服务流控容错组件-Sentinel掌握微服务网关组件-Gateway掌握微服务链路追踪组件-Sleuth&Zipkin掌握......
  • SpringCloud Alibaba 01 (微服务的概念理解,微服务的环境搭建,微服务的服务注册中心Nacos
    目录了解微服务常用的概念了解项目架构演变掌握微服务环境搭建掌握微服务治理组件-NacosDiscovery掌握微服务负载均衡调度组件-Ribbon掌握微服务远程调度组件-Feign掌握微服务流控容错组件-Sentinel掌握微服务网关组件-Gateway掌握微服务链路追踪组件-Sleuth&Zi......
  • 2024年最新互联网大厂精选 Java 面试真题集锦(JVM、多线程、MQ、MyBatis、MySQL、Redis
    前言春招,秋招,社招,我们Java程序员的面试之路,是挺难的,过了HR,还得被技术面,在去各个厂面试的时候,经常是通宵睡不着觉,头发都脱了一大把,还好最终侥幸能够入职一个独角兽公司,安稳从事喜欢的工作至今...近期也算是抽取出大部分休息的时间,为大家准备了一份通往大厂面试的小捷径,准备......
  • 【顶级EI复现】分布式电源选址定容的多目标优化算法(Matlab代码实现)
      ......
  • TensorFlow面试整理-分布式
     在深度学习的训练过程中,随着数据量和模型的复杂性增加,单个GPU或CPU无法满足高效训练的需求。TensorFlow提供了强大的分布式训练功能,通过并行处理加速训练过程。分布式训练可以在多个GPU、多个机器甚至是TPU上运行。以下是分布式训练的关键概念及其使用方法......
  • 【深入理解SpringCloud微服务】Hystrix作用与原理剖析
    【深入理解SpringCloud微服务】Hystrix作用与原理剖析Hystrix的作用熔断降级隔离Hystrix有限流的功能吗?Hystrix的原理@HystrixCommand注解是如何起作用的工作流程1、构建命令对象2、执行命令3、检查缓存是否开启并且是否命中4、检查断路器是否打开5、检查线程池或信号量......
  • 分布式数据库的魔力
    分布式数据库的魔力在这个信息爆炸的时代,你是否曾好奇过,支撑着我们日常生活中各类服务的那些看似“无形”的科技背后,究竟有怎样的秘密?分布式数据库,就是其中一个重要的谜底。它不仅让数据存储和管理变得更加灵活、聪明,还为企业解决了许多棘手的问题。在这篇文章中,我们将一起......
  • 阿里面试:秒杀的分布式事务, 是如何设计的?
    文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录博客园版为您奉上珍贵的学习资源:免费赠送:《尼恩Java面试宝典》持续更新+史上最全+面试必备2000页+面试必备+大厂必备+涨薪必备免费赠送:《尼恩技术圣经+高并发系列PDF》,帮你实现技术自由,完成职业升级,薪......