基于SpringBoot+Vue在线作业管理系统的设计与实现-程序员宅基地

技术标签: spring boot  Java精选毕设项目  vue.js  后端  

系统介绍

时代在飞速进步,每个行业都在努力发展现在先进技术,通过这些先进的技术来提高自己的水平和优势,在线作业管理系统当然不能排除在外。在线作业管理系统是在实际应用和软件工程的开发原理之上,运用java语言以及SpringBoot框架进行开发。首先要进行需求分析,分析出在线作业管理系统的主要功能,然后设计了系统结构。整体设计包括系统的功能、系统总体结构、系统数据结构和对系统安全性进行设计;最后要对系统进行测试,还要对测试的结果进行总结和分析,为以后系统的维护提供方便,也为以后类似系统的开发提供参考和帮助。这种个性化的网络系统管理更重视相互协调和管理合作,能激发管理者的创造性和主动性,这对在线作业管理系统来说非常有益。

系统主要技术 

开发语言:Java
 
使用框架:spring boot
 
前端技术:JavaScript、Vue 、css3
 
开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code
 
数据库:MySQL 5.7/8.0
 
数据库管理工具:phpstudy/Navicat
 
JDK版本:jdk1.8
 
Maven: apache-maven 3.8.1-bin

系统展示

管理员模块属于是网站的后台,进入之后有大量的管理员功能,管理员也可以使用教师、学生模块的功能,为了维护网站的稳定与页面的布局,将管理员模块的功能详细化后可以使用系统管理对页面进行布局修改,用户模块只可以对班级信息、题库信息、布置作业、提交作业、作业成绩、学生留言等进行查询等,并且更改个人信息,在线作业管理系统总体结构图如图4-2所示。

5.1学生功能实现

这是一个学生注册的界面,当学生没有账户时可以通过注册来登录系统,只需要根据相应的提示,输入学生学号、密码、确认密码、学生姓名、性别、头像、邮箱、手机号等信息即可。学生注册界面如图5-1所示:

图5-1 学生注册界面

这是学生登录界面,学生在登录页面填写用户名或者密码,点击登录,如图5-2所示:

图5-2学生登录页面

学生登录系统后,可以对系统首页、个人中心、班级信息管理、题库信息管理、布置作业管理、提交作业管理、作业成绩管理、学生留言管理等进行操作。学生主页面如图5-3所示:

图5-3学生主界面

学生点击班级信息管理:在班级信息管理页面,可以对班级、班级人数、班级位置、教师工号、教师姓名等信息,进行查询班级信息等操作,如图5-4所示:

图5-4班级信息管理界面

学生点击题库信息管理:在题库信息管理页面,可以对题库名称、题型、题型数量、题型出自、配图、发布时间等信息,进行查询题库信息等操作,如图5-5所示:

图5-5题库信息管理界面

学生点击布置作业管理:在布置作业管理页面,可以对班级、课程名称、作业名称、作业内容、布置时间、截止时间、教师工号、教师姓名等信息,进行查询布置作业等操作,如图5-6所示:

图5-6布置作业管理界面

5.2管理员功能实现

管理员登录,在登录页面选择需要登录的角色,在正确输入用户名和密码后,点击登录操作;如图5-7所示。                               

图5-7 管理员登录界面

管理员进入主页面,主要功能包括对系统首页、个人中心、教师管理、学生管理、班级信息管理、题库信息管理、布置作业管理、提交作业管理、作业成绩管理、学生留言管理等进行操作。管理员主页面如图5-8所示:

图5-8管理员主界面

管理员点击教师管理:在教师管理页面,可以对教师工号、教师姓名、性别、头像、邮箱、手机号等信息,进行查询或者新增、删除教师信息等操作,如图5-9所示:

图5-9教师管理界面

管理员点击学生管理:在学生管理页面,可以对学生学号、学生姓名、性别、头像、邮箱、手机号等信息,进行查询、新增或者删除学生信息等操作,如图5-10所示:

图5-10学生管理界面

管理员点击班级信息管理:在班级信息管理页面,可以对班级、班级人数、班级位置、教师工号、教师姓名等信息,进行查询、新增或者删除班级信息等操作,如图5-11所示:

图5-11班级信息管理界面

管理员点击题库信息管理:在题库信息管理页面,可以对题库名称、题型、题型数量、题型出自、配图、发布时间等信息,进行查询、新增或者删除题库信息等操作,如图5-12所示:

图5-12题库信息管理界面

管理员点击布置作业管理:在布置作业管理页面,可以对班级、课程名称、作业名称、作业内容、布置时间、截止时间、教师工号、教师姓名等信息,进行查询、新增或者删除布置作业等操作,如图5-13所示:

图5-13布置作业管理界面

5.3教师功能实现

这是一个教师注册的界面,当教师没有账户时可以通过注册来登录系统,只需要根据相应的提示,输入教师工号、密码、确认密码、教师姓名、性别、头像、邮箱、手机号等信息即可。教师注册界面如图5-14所示:

图5-14 教师注册界面

这是教师登录界面,教师在登录页面填写用户名或者密码,点击登录,如图5-15所示:

图5-15教师登录页面

教师登录系统后,可以对系统首页、个人中心、班级信息管理、题库信息管理、布置作业管理、提交作业管理、作业成绩管理、学生留言管理等进行操作,如图5-16所示:

图5-16 教师主界面

教师点击班级信息管理:在班级信息管理页面,可以对班级、班级人数、班级位置、教师工号、教师姓名等信息,进行查询、新增或者删除班级信息等操作,如图5-17所示:

图5-17班级信息管理界面

教师点击题库信息管理:在题库信息管理页面,可以对题库名称、题型、题型数量、题型出自、配图、发布时间等信息,进行查询、新增或者删除题库信息等操作,如图5-18所示:

图5-18题库信息管理界面

部分核心代码

/**
 * 登录相关
 */
@RequestMapping("users")
@RestController
public class UsersController {
	
	@Autowired
	private UsersService usersService;
	
	@Autowired
	private TokenService tokenService;
 
	/**
	 * 登录
	 */
	@IgnoreAuth
	@PostMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		UsersEntity user = usersService.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());
		R r = R.ok();
		r.put("token", token);
		r.put("role",user.getRole());
		r.put("userId",user.getId());
		return r;
	}
	
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UsersEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(usersService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        usersService.insert(user);
        return R.ok();
    }
 
	/**
	 * 退出
	 */
	@GetMapping(value = "logout")
	public R logout(HttpServletRequest request) {
		request.getSession().invalidate();
		return R.ok("退出成功");
	}
 
	/**
	 * 修改密码
	 */
	@GetMapping(value = "/updatePassword")
	public R updatePassword(String  oldPassword, String  newPassword, HttpServletRequest request) {
		UsersEntity users = usersService.selectById((Integer)request.getSession().getAttribute("userId"));
		if(newPassword == null){
			return R.error("新密码不能为空") ;
		}
		if(!oldPassword.equals(users.getPassword())){
			return R.error("原密码输入错误");
		}
		if(newPassword.equals(users.getPassword())){
			return R.error("新密码不能和原密码一致") ;
		}
		users.setPassword(newPassword);
		usersService.updateById(users);
		return R.ok();
	}
	
	/**
     * 密码重置
     */
    @IgnoreAuth
	@RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	UsersEntity user = usersService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
    	user.setPassword("123456");
        usersService.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 = usersService.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", usersService.selectListView(ew));
    }
 
    /**
     * 信息
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") String id){
        UsersEntity user = usersService.selectById(id);
        return R.ok().put("data", user);
    }
    
    /**
     * 获取用户的session用户信息
     */
    @RequestMapping("/session")
    public R getCurrUser(HttpServletRequest request){
    	Integer id = (Integer)request.getSession().getAttribute("userId");
        UsersEntity user = usersService.selectById(id);
        return R.ok().put("data", user);
    }
 
    /**
     * 保存
     */
    @PostMapping("/save")
    public R save(@RequestBody UsersEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(usersService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        usersService.insert(user);
        return R.ok();
    }
 
    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody UsersEntity user){
//        ValidatorUtils.validateEntity(user);
        usersService.updateById(user);//全部更新
        return R.ok();
    }
 
    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
		List<UsersEntity> user = usersService.selectList(null);
		if(user.size() > 1){
			usersService.deleteBatchIds(Arrays.asList(ids));
		}else{
			return R.error("管理员最少保留一个");
		}
        return R.ok();
    }
}

 此源码非开源,若需要此源码可扫码添加微信或者qq:2214904953进行咨询!

2600多套项目欢迎咨询

 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/ymhyd/article/details/138083443

智能推荐

HDU--4305(生成树计数)-程序员宅基地

文章浏览阅读176次。2015-09-0722:23:26【传送门】题意:平面上300个点,如果两点之间距离<=R,且两点形成的线段上没有另外的点,那么两点之间有一条无向边。问生成树的方案数。思路:暴力n^2建图,关于判断两点形成线段上是否有其他点,比如判断 k 点知否在 i ,j 之间,首先看斜率是否相等,不能直接求斜率,而应该转化为乘式;再判断 dis(i,k)+dis(k,j)是否等..._hdu4305

阿里云OSS请求文件跨域问题Access-Control-Allow-Origin_oss预签名url access-control-allow-origin-程序员宅基地

文章浏览阅读2.2k次。跨域问题网上很多解决方案提示到这里配置但是不生效,一定要勾选Vary:Origin这个选项,请求的时候浏览器记得请求在控制台要清理缓存。_oss预签名url access-control-allow-origin

OpenCV - C++ - cv::setWindowProperty-程序员宅基地

文章浏览阅读4k次,点赞2次,收藏2次。OpenCV - C++ - cv::setWindowPropertyHigh-level GUI#include <opencv2/highgui.hpp>1. setWindowProperty()void cv::setWindowProperty(const String &winname, int prop_id, double prop_value) - C++None = cv.setWindowProperty(winname, prop_id, prop__setwindowproperty

Qt Creator 4.13中的CMake项目配置_qt cmake configuration-程序员宅基地

文章浏览阅读5.1k次,点赞3次,收藏4次。在Qt Creator中配置中型到大型CMake项目可能是一个挑战。这是因为您需要给CMake传递正确配置项目的选项太多了。让我们以Qt Creator的CMake为例。不同于qmake构建,CMake构建可配置你想要构建的插件。_qt cmake configuration

探测网络设备(主机、路由器)存活的方法-程序员宅基地

文章浏览阅读2.1k次。//=======================ping-test============================void ping_test(char *ipaddress){ //add by sun-1014 char command[100]="ping -c 5 "; char ipaddr[20]; strcpy(ipaddr,_探测网络设备

docker 运行jar包 指定配置文件(wvp-gb28181-pro平台制作docker镜像)_wvp-gb28181-pro docker部署-程序员宅基地

文章浏览阅读982次。要在Docker中运行JAR包并指定配置文件,你可以创建一个Dockerfile来定义你的容器环境,并在其中指定如何运行JAR包和配置文件。现在,你的JAR包将在Docker容器中运行,并使用指定的配置文件。你可以通过访问主机的8080端口来访问你的应用程序。这将启动一个容器,并将容器的8080端口映射到主机的8080端口。你可以根据你的需要调整端口映射。,你需要根据实际情况进行替换。此外,你还可以根据需要添加其他配置和依赖项,以满足你的应用程序要求。在上面的Dockerfile中,我们使用了。_wvp-gb28181-pro docker部署

随便推点

C++代码实现Top-K问题最优解决办法_c++用优先队列解决topk-程序员宅基地

文章浏览阅读1.6k次。Top-K问题Top-K问题1、问题描述2、解法思想和实现Top-K问题1、问题描述Top-K问题是一个十分经典的问题,一般有以下两种方式来描述问题:在10亿的数字里,找出其中最大的100个数;或者在一个包含n个整数的数组中,找出最大的100个数。前边两种问题描述稍有区别,但都是说的Top-K问题,前一种描述方式是说这里也许没有足够的空间存储大量的数字或其他东西,我们最好可以在一边输入数据,一边求出结果,而不需要存储数据;后一种说法则表示可以存储数据,这种情况下,最简单直观的想法就是对数组进行排序,_c++用优先队列解决topk

怎么用matlab剔除数据的异常值(3σ准则)_3sigma原则matlab-程序员宅基地

文章浏览阅读5.2w次,点赞27次,收藏379次。参考:https://blog.csdn.net/weixin_30633405/article/details/951770093σ准则又称为拉依达准则,它是先假设一组检测数据只含有随机误差,对其进行计算处理得到标准偏差,按一定概率确定一个区间,认为凡超过这个区间的误差,就不属于随机误差而是粗大误差,含有该误差的数据应予以剔除。且3σ适用于有较多组数据的时候。这种判别处理原理及方法仅局限于对正态或近似正态分布的样本数据处理,它是以测量次数充分大为前提的,当测量次数较少的情形用准则剔除粗大误_3sigma原则matlab

导入PYQT5不能使用的坑_pdroid3已经导入pyqt5怎么不管用-程序员宅基地

文章浏览阅读5.1k次,点赞4次,收藏17次。如图:import进来之后里面的类全都不能用是因为这个引用路径下面有中文。改成英文的就不报错了,如果还是报错,那就新建一个项目命名成英文_pdroid3已经导入pyqt5怎么不管用

手推线性模型及最小二乘法(房价预测实例)_基于最小二乘法的房价预测实验报告-程序员宅基地

文章浏览阅读1.4k次,点赞4次,收藏24次。手推线性模型及最小二乘法(房价预测实例)线性模型及最小二乘法推导房价预测实例Reference线性模型及最小二乘法推导房价预测实例生成数据#生成数据import numpy as np#生成随机数np.random.seed(1234)x = np.random.rand(500,3)#构建映射关系,模拟真实的数据待预测值,映射关系为y = 4.2 + 5.7*x1 + 1..._基于最小二乘法的房价预测实验报告

多文件使用全局变量时extern的规范用法_extern变量多个文件中修改-程序员宅基地

文章浏览阅读494次。关键字extern用来声明变量或者函数是一个外部变量或者外部函数,也就是说告诉编译器是在其他文件中定义的,编译的时候不要报错,在链接的时候按照字符串寻址可以找到这个变量或者函数。(函数默认是外部类型的,不需要显示声明,但是变量必须,如果想把一个函数声明为只在本文件范围有效,那么可以用static来说明) 在某个头文件,比如A.h中定义了全局变量比如int a;,那么在其他文件中的函数调用变量a的时候需要在对应头文件或者定义文件中(保证在使用这个变量前)使用extern int a;..._extern变量多个文件中修改

为 OpenBMC 添加一个新的系统_openbmc对meta名字有要求吗-程序员宅基地

文章浏览阅读773次,点赞15次,收藏27次。在上一篇文章中向大家介绍了OpenBMC的是什么以及它的作用和应用场景,并且以一个自带的示例平台romulus展示了从下载源码包开始到启动系统并访问Web控制页面的整体构建流程。通过前文已经了解到如何为已有的平台构建系统镜像,下面我们来探索一下如何为我们自己的平台构建OpenBMC的系统镜像。_openbmc对meta名字有要求吗

推荐文章

热门文章

相关标签