✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌
文末获取项目下载方式
一、项目背景介绍:
研究背景介绍:
随着社会的发展和人们对心理健康重视程度的提升,学校心理教育和辅导工作日益受到关注。学校作为培养学生全面发展的重要场所,心理健康教育在学校中扮演着至关重要的角色。而学校心理测试系统作为辅助心理教育和辅导的重要工具,具有极大的应用潜力。
传统的学校心理测试工作往往依赖于纸质问卷和手工处理,存在许多问题,如成本高、效率低、难以统计分析等。为了解决这些问题,开发一套基于SpringBoot+Vue的学校心理测试系统具有非常重要的意义。
该系统的开发旨在提供一个实用、高效、智能化的平台,能够方便学校管理者、教师和学生进行心理测试与咨询工作。管理端模块提供了公告管理、学生管理、老师管理和管理员管理等功能,使得学校管理者能够快速发布通知、管理学生和教职工信息,保证学校的正常运转。教师端模块则提供了学生咨询管理、个人信息管理、试卷管理、建档信息和试题信息等功能,使得教师能够灵活安排心理咨询工作和考试管理。
同时,学生端模块包括登录注册、首页咨询、心理测试、咨询教师和个人中心等功能,使得学生能够方便地获取心理咨询服务、进行心理测试和管理个人信息。通过该系统,学生能够更好地了解自己的心理状态,寻求适当的心理咨询和辅导,从而增强心理健康。
二、项目技术简介:
三、系统功能模块介绍:
四、数据库设计:
1:‘管理员表’(manage)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 管理员编号 |
user_name | varchar | NULL | 用户名 |
pass_word | varchar | NULL | 密码 |
photo_img | varchar | NULL | 图片 |
name | varchar | NULL | 名称 |
2:‘留言表’(messages)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
tea_id | bigint | NULL | 老师ID |
stu_id | bigint | NULL | 学生ID |
create_time | datetime | NULL | 创建时间 |
answer | varchar | NULL | 回复 |
content | varchar | NULL | 留言内容 |
3:‘公告信息表’(notice)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 公告编号 |
banner_img | varchar | NULL | 公告图片 |
content | text | NULL | 公告内容 |
info | varchar | NULL | 公告简介 |
create_time | datetime | NULL | 创建时间 |
title | varchar | NULL | 公告标题 |
4:‘题目表’(questions)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 题目编号 |
title | text | NULL | 题目标题 |
option_a | varchar | NULL | 选项A |
option_b | varchar | NULL | 选项B |
option_c | varchar | NULL | 选项C |
option_d | varchar | NULL | 选项D |
grade_a | varchar | NULL | 答案A分数 |
grade_b | varchar | NULL | 答案B分数 |
teacher_id | bigint | NULL | 老师编号 |
create_time | datetime | NULL | 创建时间 |
grade_c | varchar | NULL | 答案C分数 |
grade_d | varchar | NULL | 答案D分数 |
5:‘建档信息’(records)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 档案编号 |
stu_id | bigint | NULL | 学生编号 |
test_id | bigint | NULL | 试卷编号 |
tea_id | bigint | NULL | 教师编号 |
grade | varchar | NULL | 考试分数 |
create_time | datetime | NULL | 创建时间 |
info | varchar | NULL | 对应结果 |
6:‘学生表’(student)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 学生编号 |
stu_name | varchar | NULL | 学生姓名 |
stu_age | int | NULL | 年龄 |
stu_sex | int | NULL | 性别[0:男,1:女] |
stu_phone | varchar | NULL | 联系方式 |
stu_address | varchar | NULL | 家庭住址 |
stu_class_num | varchar | NULL | 所属班级 |
stu_img | varchar | NULL | 照片 |
password | varchar | NULL | 登录密码 |
7:‘老师’(teachers)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 教师编号 |
username | varchar | NULL | 账号 |
password | varchar | NULL | 密码 |
tea_name | varchar | NULL | 姓名 |
tea_age | int | NULL | 年龄 |
tea_sex | int | NULL | 性别 |
tea_info | text | NULL | 简介 |
tea_tel | varchar | NULL | 联系方式 |
tea_img | varchar | NULL | 头像 |
create_time | datetime | NULL | 创建时间 |
varchar | NULL | 邮箱 |
8:‘试卷管理’(test_paper)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 试卷编号 |
tea_id | bigint | NULL | 所属老师 |
title | varchar | NULL | 试卷标题 |
img | varchar | NULL | 封面图片 |
create_time | datetime | NULL | 创建时间 |
total_grade | varchar | NULL | 总分 |
info | varchar | NULL | 试卷简介 |
9:‘试卷题目’(test_questions)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
test_id | bigint | NULL | 所属试卷 |
question_id | bigint | NULL | 题目编号 |
tea_id | bigint | NULL | 老师编号 |
10:‘试卷规则管理’(test_rules)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 规则编号 |
test_id | bigint | NULL | 试卷编号 |
min_grade | int | NULL | 最低分数 |
max_grade | int | NULL | 最高分数 |
info | varchar | NULL | 对应结果 |
create_time | datetime | NULL | 创建时间 |
tea_id | bigint | NULL | 老师编号 |
五、功能模块:
公告管理模块:提供对学校内部公告的增加、修改、删除和查询功能,管理员可以按照时间,内容等方式对公告进行排序和查找,方便快速发布和管理校内通知。
学生管理模块:提供对学生信息的增加、修改、删除和查询功能
老师管理模块:提供对教职工信息的增加、修改、删除和查询功能
管理员管理模块:提供对管理员账号的增加、修改、删除和查询功能
学生咨询管理模块:提供给教师对学生心理咨询的管理与处理,以及学生咨询历史记录查询、沟通记录备份。
个人信息管理模块:提供给教师对个人信息的查看和管理,可以修改个人基本信息,包括姓名、照片、联系方式等。
提供试卷列表管理、试卷组装、试卷规则的设置等功能,教师可以根据不同的需求灵活地组合试卷,并设置具体的考试规则,满足不同场景下的学校考试需求。:试卷管理模块
建档信息模块:提供对学生心理建档的管理,包括学生数据的录入、历史记录查询,教师可以通过该模块辅助开展心理辅导工作。
试题信息模块:提供对试题信息的管理,包括试题列表查看、试题组卷、试题答案解析等功能,教师可以根据学科专业和知识点等标签分类,方便快速制定试卷。
登录注册模块:提供学生账号的注册与登录功能,使得学生可以使用自己的账号密码登录系统,更好地享受系统提供的服务。
首页咨询模块:提供心理咨询服务,包括心理资讯、在线问答、心理测评等,为学生提供相关心理知识和咨询服务。
心理测试模块:提供常见心理测试工具和教育心理学测验,为学生提供对自身心理状态的了解和思考。
心理测评试卷详情:在心理测评界面选择对应的试卷来进行填写系统会根据所填的答案进行评分
个人中心:提供学生个人信息的查看和管理,包括个人资料、心理测试记录、咨询记录、反馈建议等,方便学生根据自身需求使用系统服务。
六、代码示例:
/**
* 生成验证码
*/
@GetMapping("/captchaImage")
public AjaxResult getCode(HttpServletResponse response) throws IOException
{
AjaxResult ajax = AjaxResult.success();
boolean captchaEnabled = configService.selectCaptchaEnabled();
ajax.put("captchaEnabled", captchaEnabled);
if (!captchaEnabled)
{
return ajax;
}
// 保存验证码信息
String uuid = IdUtils.simpleUUID();
String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid;
String capStr = null, code = null;
BufferedImage image = null;
// 生成验证码
String captchaType = RuoYiConfig.getCaptchaType();
if ("math".equals(captchaType))
{
String capText = captchaProducerMath.createText();
capStr = capText.substring(0, capText.lastIndexOf("@"));
code = capText.substring(capText.lastIndexOf("@") + 1);
image = captchaProducerMath.createImage(capStr);
}
else if ("char".equals(captchaType))
{
capStr = code = captchaProducer.createText();
image = captchaProducer.createImage(capStr);
}
redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
// 转换流信息写出
FastByteArrayOutputStream os = new FastByteArrayOutputStream();
try
{
ImageIO.write(image, "jpg", os);
}
catch (IOException e)
{
return AjaxResult.error(e.getMessage());
}
ajax.put("uuid", uuid);
ajax.put("img", Base64.encode(os.toByteArray()));
return ajax;
}
/**
* 通用的本地文件上传
*
* @param multipartFile 文件对象
* @return 文件访问链接URL
*/
@PostMapping("/file")
public SimpleResponse uploadImg(@RequestParam("file") MultipartFile file) {
// 文件后缀
String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".") + 1);
File savePathFile = new File(newTomcatFolder);
if (!savePathFile.exists()) {
// 若不存在该目录,则创建目录
savePathFile.mkdir();
}
// 通过UUID生成唯一文件名
String filename = UUID.randomUUID() + "." + suffix;
try {
// 将文件保存指定目录
file.transferTo(new File(newTomcatFolder + filename));
} catch (Exception e) {
e.printStackTrace();
return SimpleResponse.error("保存文件异常");
}
// 返回访问链接
return SimpleResponse.success(newTomcatHost + filename);
}
/**
* 用户登录
*/
@PostMapping("/login")
public ReturnMsg manageLogin(@RequestBody Map<String, String> param) {
if (StrUtil.isEmpty(param.get("username")) || StrUtil.isEmpty(param.get("password"))) {
return ReturnMsg.error("用户名或密码错误!");
}
ManageDTO manageDTO = new ManageDTO();
manageDTO.setUserName(param.get("username"));
manageDTO.setPassWord(param.get("password"));
QueryWrapper<ManageDTO> manageDTOQueryWrapper = new QueryWrapper<>(manageDTO);
manageDTOQueryWrapper.last("limit 1");
ManageDTO adminDTOS = manageService.getOne(manageDTOQueryWrapper);
if (adminDTOS == null) return ReturnMsg.error("用户名或密码错误!");
Map<String, Object> map = new HashMap<>();
map.put("avatar", StrUtil.isNotBlank(adminDTOS.getPhotoImg()) ? adminDTOS.getPhotoImg() : "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");
map.put("introduction", adminDTOS.getName() + ",你好!");
map.put("name", adminDTOS.getName());
map.put("roles", Arrays.asList("admin"));
map.put("type", adminDTOS.getStatus());
Map<String, String> returnMap = new HashMap<>();
String uuid = UUID.randomUUID().toString();
returnMap.put("token", uuid);
userInfoMap.put(uuid, JSON.toJSONString(map));
return ReturnMsg.ok(returnMap);
}
七、项目总结:
通过对SpringBoot+Vue的学校心理测试系统的开发,让我深刻明白开发一个程序软件需要经历的流程,当确定要开发一个SpringBoot+Vue的学校心理测试系统的程序时,
我在开发期间,对其功能进行合理的需求分析,然后才是程序软件的功能的框架设计,数据库的实体与数据表设计,
程序软件的功能详细界面实现,以及程序的功能测试等进行全方位的细致考虑,虽然在此过程中,各个环节都遇到了大大小小的困难,但是通过对这些问题进行反复的分析,深入的思考,
借助各种相关文献资料提供的方法与解决思路成功解决面临的各个问题,最后成功的让我开发的SpringBoot+Vue的学校心理测试系统得以正常运行。
SpringBoot+Vue的学校心理测试系统在功能上面是基本可以满足用户对系统的操作,但是这个程序软件也有许多方面是不足的,因此,在下一个时间阶段,有几点需要改进的地方需要提出来,它们分别是:
(1)操作页面可以满足用户简易操作的要求,但是在页面多样化设计层面上需要把一些比较丰富的设计结构考虑进来。
(2)程序软件的总体安全性能需要优化,例如程序的退出安全性,以及程序的并发性等问题都需要进行安全性升级,让开发的SpringBoot+Vue的学校心理测试系统中的相关网站更贴合。
(3)需要对程序的数据结构方面,程序的代码方面等进行优化,让运行起来的程序可以保持稳定运行,也让程序能够保证短时间内处理相关事务,节省处理事务的时间,提高事务处理的效率,
同时对服务器上资源占用的比例进行降低。
SpringBoot+Vue的学校心理测试系统的开发一方面是对自身专业知识技能进行最终考核,另一方面也是让自己学会独立解决程序开发过程中所遇到的问题,掌握将理论知识运用于程序开发实践的方法。
SpringBoot+Vue的学校心理测试系统的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。
八、源码获取:
大家点赞、收藏、关注、评论啦 、查看获取项目下载链接,博主联系方式
链接点击直达:下载链接