当前位置:   article > 正文

基于Java+Spring Boot+MySQL的精品在线试题库系统设计与实现(源码+数据库+文档)_基于java的题库管理系统

基于java的题库管理系统

目录

项目简介

技术详情

效果图

学生管理

教师管理

专业管理

试卷管理

试题管理

考试管理

错题本

考试记录

文档内容展示

核心代码

其他案例

​编辑

源码获取


末尾获取源码
作者介绍:大厂全栈码农|毕设实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。

更多项目:CSDN主页曾几何时

我欲乘风归去 又恐琼楼玉宇  高处不胜寒 -苏轼


项目简介

使用旧方法对作业管理信息进行系统化管理已经不再让人们信赖了,把现在的网络信息技术运用在作业管理信息的管理上面可以解决许多信息管理上面的难题,比如处理数据时间很长,数据存在错误不能及时纠正等问题。这次开发的精品在线试题库系统有管理员,教师,学生三个角色。管理员功能有个人中心,专业管理,学生管理,教师管理,试卷管理,试题管理,考试管理。教师可以管理试题和试卷,查看学生考试记录和错题本。学生可以参加考试,查看试卷和错题本以及考试记录。经过前面自己查阅的网络知识,加上自己在学校课堂上学习的知识,决定开发系统选择B/S模式这种高效率的模式完成系统功能开发。这种模式让操作员基于浏览器的方式进行网站访问,采用的主流的Java语言这种面向对象的语言进行精品在线试题库系统程序的开发,在数据库的选择上面,选择功能强大的MySQL数据库进行数据的存放操作。精品在线试题库系统被人们投放于现在的生活中进行使用,该款管理类软件就可以让管理人员处理信息的时间介于十几秒之间。在这十几秒内就能完成信息的编辑等操作。有了这样的管理软件,作业管理信息的管理就离无纸化办公的目标更贴近了。


技术详情

  1. 语言:Java
  2. 使用框架:Spring Boot
  3. 前端技术:JS、Vue 、css3
  4. 开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code
  5. 数据库:MySQL 5.7/8.0
  6. 数据库管理工具:phpstudy/Navicat
  7. JDK版本:jdk1.8
  8. Maven: apache-maven 3.8.1-bin
  9. 前端环境:Node.Js 12\14\16

效果图

学生管理

管理员可以添加,查询,修改,删除学生。下图就是学生管理页面。

 

教师管理

管理员可以对教师信息进行添加,删除,查询和修改操作。下图就是通讯录信息管理页面。

 

专业管理

管理员可以对专业进行添加,查询,修改,删除操作。下图就是专业管理页面。

 

试卷管理

管理员和教师可以对试卷进行修改,删除操作。下图就是作业管理页面。

 

试题管理

管理员和教师可以对试题进行添加,查询,修改,删除操作。下图就是试题管理页面。

 

考试管理

学生可以参加考试。

 

错题本

学生参考考试后可以查看自己的错题本,教师和管理员都可以看到学生的错题本。

 

考试记录

学生参加过考试后可以在自己的考试记录里面查到自己的考试记录,管理员和教师也可以查看到学生的考试记录。

 

文档内容展示


核心代码

  1. @RequestMapping("users")
  2. @RestController
  3. public class UserController{
  4. @Autowired
  5. private UserService userService;
  6. @Autowired
  7. private TokenService tokenService;
  8. /**
  9. * 登录
  10. */
  11. @IgnoreAuth
  12. @PostMapping(value = "/login")
  13. public R login(String username, String password, String captcha, HttpServletRequest request) {
  14. UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
  15. if(user==null || !user.getPassword().equals(password)) {
  16. return R.error("账号或密码不正确");
  17. }
  18. String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
  19. return R.ok().put("token", token);
  20. }
  21. /**
  22. * 注册
  23. */
  24. @IgnoreAuth
  25. @PostMapping(value = "/register")
  26. public R register(@RequestBody UserEntity user){
  27. // ValidatorUtils.validateEntity(user);
  28. if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
  29. return R.error("用户已存在");
  30. }
  31. userService.insert(user);
  32. return R.ok();
  33. }
  34. /**
  35. * 退出
  36. */
  37. @GetMapping(value = "logout")
  38. public R logout(HttpServletRequest request) {
  39. request.getSession().invalidate();
  40. return R.ok("退出成功");
  41. }
  42. /**
  43. * 密码重置
  44. */
  45. @IgnoreAuth
  46. @RequestMapping(value = "/resetPass")
  47. public R resetPass(String username, HttpServletRequest request){
  48. UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
  49. if(user==null) {
  50. return R.error("账号不存在");
  51. }
  52. user.setPassword("123456");
  53. userService.update(user,null);
  54. return R.ok("密码已重置为:123456");
  55. }
  56. /**
  57. * 列表
  58. */
  59. @RequestMapping("/list")
  60. public R list( UserEntity user){
  61. EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
  62. ew.allEq(MPUtil.allEQMapPre( user, "user"));
  63. return R.ok().put("data", userService.selectListView(ew));
  64. }
  65. /**
  66. * 保存
  67. */
  68. @PostMapping("/save")
  69. public R save(@RequestBody UserEntity user){
  70. // ValidatorUtils.validateEntity(user);
  71. if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
  72. return R.error("用户已存在");
  73. }
  74. userService.insert(user);
  75. return R.ok();
  76. }
  77. /**
  78. * 修改
  79. */
  80. @RequestMapping("/update")
  81. public R update(@RequestBody UserEntity user){
  82. // ValidatorUtils.validateEntity(user);
  83. userService.updateById(user);//全部更新
  84. return R.ok();
  85. }
  86. /**
  87. * 删除
  88. */
  89. @RequestMapping("/delete")
  90. public R delete(@RequestBody Long[] ids){
  91. userService.deleteBatchIds(Arrays.asList(ids));
  92. return R.ok();
  93. }
  94. }

其他案例

源码获取

 大家点赞、收藏、关注、评论啦 、

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/500551
推荐阅读
相关标签