博主主页:一点源码
博主简介:专注Java技术领域和毕业设计项目实战、Java、微信小程序、安卓等技术开发,远程调试部署、代码讲解、文档指导、ppt制作等技术指导。
主要内容:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、小程序、安卓app、大数据等设计与开发。感兴趣的可以收藏+关注,所有项目均配有开发文档,一系列安装配置教程,可以定制功能包安装运行!!
文末获取联系
随着信息时代的来临,过去的传统管理方式缺点逐渐暴露,对过去的传统管理方式的缺点进行分析,采取计算机方式构建《学生手册》线上考试系统设计与实现。本文通过课题背景、课题目的及意义相关技术,提出了一种考试试卷、考试试题、在线考试等于一体的系统构建方案。
本文通过采用B/S架构,MySQL数据库以及java语言、springboot框架,结合国内线上管理现状,开发了一个基于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-2所示:
图5-2学生注册、学生登录界面
学生点考试试卷,在考试试卷页面查看考试试卷名称、在线考试时长(分钟)、考试试卷状态,如果有需要可以进行在线考试等操作;如图5-3所示:
图5-3考试试卷页面
在个人中心页面可以输入个人详细信息,进行信息更新操作,还可以对在线考试记录、错题本进行详细操作,如图5-4所示:
图5-4个人中心界面
管理员登录,通过登录页面填写用户名、密码、角色,点击登录,如图5-5所示。
图5-5管理员登录界面图
管理员登录进入《学生手册》线上考试系统可以对系统首页、个人中心、学生管理、辅导员管理、学生成绩管理、考试试卷管理、考试试题管理、系统管理、在线考试管理等功能,进行详细操作,如图5-6所示。
图5-6 管理员功能界面图
管理员点击学生管理,在学生管理页面中可以对学号、姓名、性别、手机、班级等信息,并可根据需要进行查询或者新增、删除学生信息等操作,如图5-7所示。
图5-7学生管理界面图
管理员点击辅导员管理,在辅导员管理页面中可以对辅导员号、辅导员、性别、职称、电话、照片等信息,并可根据需要进行查询或者新增、删除辅导员信息等操作,如图5-8所示。
图5-8辅导员管理界面图
管理员点击学生成绩管理,在学生成绩管理页面中可以对年份、学期、科目、分数、班级排名、学号、姓名、班级、辅导员号、辅导员、登记时间等信息,并可根据需要进行查询、新增、导出、统计报表或者删除学生成绩等操作,如图5-9所示。
图5-9学生成绩管理界面图
管理员点击考试试卷管理,在考试试卷管理页面中可以对考试试卷名称、在线考试时长(分钟)、考试试卷状态等信息,并可根据需要进行查询、新增或者删除考试试卷等操作,如图5-10所示。
图5-10考试试卷管理界面图
管理员点击考试试题管理,在考试试题管理页面中可以对考试试卷、考试试题名称、分值、答案、类型等信息,并可根据需要进行查询、新增、导出或者删除考试试题等操作,如图5-11所示。
图5-11考试试题管理界面图
/**
* 上传文件映射表
*/
@RestController
@RequestMapping("file")
@SuppressWarnings({"unchecked","rawtypes"})
public class FileController{
@Autowired
private ConfigService configService;
/**
* 上传文件
*/
@RequestMapping("/upload")
@IgnoreAuth
public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
if (file.isEmpty()) {
throw new EIException("上传文件不能为空");
}
String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
File path = new File(ResourceUtils.getURL("classpath:static").getPath());
if(!path.exists()) {
path = new File("");
}
File upload = new File(path.getAbsolutePath(),"/upload/");
if(!upload.exists()) {
upload.mkdirs();
}
String fileName = new Date().getTime()+"."+fileExt;
File dest = new File(upload.getAbsolutePath()+"/"+fileName);
file.transferTo(dest);
/**
* 如果使用idea或者eclipse重启项目,发现之前上传的图片或者文件丢失,将下面一行代码注释打开
* 请将以下的"D:\\springbootq33sd\\src\\main\\resources\\static\\upload"替换成你本地项目的upload路径,
* 并且项目路径不能存在中文、空格等特殊字符
*/
// FileUtils.copyFile(dest, new File("D:\\springbootq33sd\\src\\main\\resources\\static\\upload"+"/"+fileName)); /**修改了路径以后请将该行最前面的//注释去掉**/
if(StringUtils.isNotBlank(type) && type.equals("1")) {
ConfigEntity configEntity = configService.selectOne(new EntityWrapper().eq("name", "faceFile"));
if(configEntity==null) {
configEntity = new ConfigEntity();
configEntity.setName("faceFile");
configEntity.setValue(fileName);
} else {
configEntity.setValue(fileName);
}
configService.insertOrUpdate(configEntity);
}
return R.ok().put("file", fileName);
}
/**
* 下载文件
*/
@IgnoreAuth
@RequestMapping("/download")
public ResponseEntity download(@RequestParam String fileName) {
try {
File path = new File(ResourceUtils.getURL("classpath:static").getPath());
if(!path.exists()) {
path = new File("");
}
File upload = new File(path.getAbsolutePath(),"/upload/");
if(!upload.exists()) {
upload.mkdirs();
}
File file = new File(upload.getAbsolutePath()+"/"+fileName);
if(file.exists()){
/*if(!fileService.canRead(file, SessionManager.getSessionUser())){
getResponse().sendError(403);
}*/
HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
headers.setContentDispositionFormData("attachment", fileName);
return new ResponseEntity(FileUtils.readFileToByteArray(file),headers, HttpStatus.CREATED);
}
} catch (IOException e) {
e.printStackTrace();
}
return new ResponseEntity(HttpStatus.INTERNAL_SERVER_ERROR);
}
}