前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >实验报告管理系统 毕业设计 JAVA+Vue+SpringBoot+MySQL

实验报告管理系统 毕业设计 JAVA+Vue+SpringBoot+MySQL

作者头像
Designer 小郑
发布2024-03-01 14:23:28
1750
发布2024-03-01 14:23:28
举报
文章被收录于专栏:跟着小郑学JAVA跟着小郑学JAVA

作者主页Designer 小郑 作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN博客专家,阿里云社区专家博主,蓝桥云课讲师。

\color{red}{本文项目编号:S098。}

一、摘要

1.1 项目介绍

基于JAVA+Vue+SpringBoot+MySQL的实验报告管理系统,包含了实验管理模块、实验实例模块、实验批阅模块、实验咨询模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,实验报告管理系统基于角色的访问控制,给高校管理员、学生角色使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。

1.2 项目录屏

二、功能模块

2.1 实验管理模块

实验报告管理系统的实验管理模块通常包括实验信息的增加、删除、修改和查询功能,用户可以通过实验管理模块添加新的实验信息,包括实验名称、实验时间、实验地点、实验内容等。通常会有表单或者界面供用户填写相关信息,并在提交后将信息存储到数据库中。用户可以删除不再需要的实验信息。通常会提供一个列表或者搜索功能供用户选择需要删除的实验信息,确认删除后,系统会从数据库中删除相应的记录。用户可以对已有的实验信息进行修改,例如更改实验时间、地点,或者修正实验内容等。一般会提供编辑界面让用户对已有信息进行修改,并更新到数据库中。用户可以通过实验管理模块进行实验信息的查询,可以根据实验名称、时间、地点等条件进行搜索,系统会返回符合条件的实验信息列表供用户查看。这些功能通常会被整合到实验管理模块中,以便用户能够方便地管理和查看实验信息,提高实验管理的效率和准确性。

2.2 实验实例模块

实验报告管理系统的实验实例模块是用于管理和记录具体实验过程和实验结果的部分。主要包括实验实例的增加、删除、修改和查询功能,用户可以通过实验实例模块添加新的实验实例,包括实验名称、实验时间、实验地点、实验者、实验步骤、实验结果等。通常会提供表单或者界面供用户填写具体实验过程和结果,并将信息存储到数据库中。用户可以删除不再需要的实验实例。通常会提供一个列表或者搜索功能供用户选择需要删除的实验实例,确认删除后,系统会从数据库中删除相应的记录。用户可以对已有的实验实例进行修改,例如更改实验步骤、修改实验结果等。一般会提供编辑界面让用户对已有实验实例进行修改,并更新到数据库中。用户可以通过实验实例模块进行实验实例的查询,可以根据实验名称、实验者、时间等条件进行搜索,系统会返回符合条件的实验实例列表供用户查看。这些功能通常会被整合到实验实例模块中,以便用户能够方便地管理和查看具体实验过程和结果,提高实验记录和管理的效率和准确性。

2.3 实验批阅模块

实验报告管理系统的实验批阅模块是用于教师或者指导员对学生提交的实验报告进行评阅和反馈的部分,该模块通常包括实验报告批阅的增加、删除、修改和查询功能。教师或者指导员可以通过实验批阅模块对学生提交的实验报告进行评阅和反馈。通常会提供一个界面或者表单供教师输入评阅结果、评分、意见等信息,并将批阅结果存储到数据库中,以便学生查看。教师可以删除错误的实验批阅结果,或者重新进行评阅。通常会提供一个列表或者搜索功能供教师选择需要删除的批阅记录,确认删除后,系统会从数据库中删除相应的记录。教师可以对已有的实验批阅结果进行修改,例如修改评分、修改评语等。一般会提供编辑界面让教师对已有批阅结果进行修改,并更新到数据库中。教师可以通过实验批阅模块进行实验批阅结果的查询,可以根据学生姓名、实验名称、时间等条件进行搜索,系统会返回符合条件的实验批阅结果供教师查看和管理。这些功能通常会被整合到实验批阅模块中,以便教师能够方便地对学生提交的实验报告进行评阅和反馈,提高教学管理的效率和准确性。

2.4 实验咨询模块

实验报告管理系统的实验咨询模块是用于学生在实验过程中对实验内容、实验步骤等方面提出疑问并获得解答的部分。该模块通常包括实验咨询的增加、删除、修改和查询功能,学生可以通过实验咨询模块提出实验相关的问题和疑问。通常提供一个表单或者界面供学生填写问题的具体描述和相关信息,并将咨询信息存储到数据库中。学生可以删除不再需要或已解决的实验咨询。通常提供一个列表或者搜索功能供学生选择需要删除的咨询记录,确认删除后,系统会从数据库中删除相应的记录。学生可以对已有的实验咨询进行修改,例如补充问题描述或修改相关信息。一般会提供编辑界面让学生对已有咨询进行修改,并更新到数据库中。学生可以通过实验咨询模块进行实验咨询记录的查询。通常可以根据问题关键词、时间、状态等条件进行搜索,系统会返回符合条件的咨询记录供学生查看。这些功能通常会被整合到实验咨询模块中,以便学生能够方便地提出问题并获得相关解答,提高学生在实验过程中的支持和指导效果。同时,教师或指导员也可以通过该模块回复学生的咨询,以提供更好的实验辅导和支持。

三、系统展示

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

四、核心代码

4.1 查询实验

代码语言:javascript
复制
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询实验")
public Result<IPage<Experiment>> getByPage(@ModelAttribute Experiment experiment ,@ModelAttribute PageVo page){
    QueryWrapper<Experiment> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(experiment.getTitle())) {
        qw.like("title",experiment.getTitle());
    }
    if(!ZwzNullUtils.isNull(experiment.getLevel())) {
        qw.like("level",experiment.getLevel());
    }
    IPage<Experiment> data = iExperimentService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<Experiment>>().setData(data);
}

4.2 新增实验咨询

代码语言:javascript
复制
@RequestMapping(value = "/addOne", method = RequestMethod.GET)
@ApiOperation(value = "新增实验咨询")
public Result<Object> addOne(@RequestParam String exampleId,@RequestParam String content){
    ExperimentExample example = iExperimentExampleService.getById(exampleId);
    if(example == null) {
        return ResultUtil.error("实验实例不存在");
    }
    User currUser = securityUtil.getCurrUser();
    ExperimentAsk ea = new ExperimentAsk();
    ea.setExperimentId(example.getExperimentId());
    ea.setExampleId(example.getId());
    ea.setTitle(example.getTitle());
    ea.setUserId(currUser.getId());
    ea.setUserName(currUser.getNickname());
    ea.setContent(content);
    ea.setFile("");
    ea.setAskTime(DateUtil.now());
    ea.setReplyFlag(false);
    ea.setReplyTime("");
    ea.setReplyMessage("未答复");
    iExperimentAskService.saveOrUpdate(ea);
    return ResultUtil.success();
}

4.3 回复实验咨询

代码语言:javascript
复制
@RequestMapping(value = "/replyOne", method = RequestMethod.GET)
@ApiOperation(value = "回复实验咨询")
public Result<Object> replyOne(@RequestParam String askId,@RequestParam String content) {
    ExperimentAsk ask = iExperimentAskService.getById(askId);
    if (ask == null) {
        return ResultUtil.error("实验咨询单不存在");
    }
    ask.setReplyFlag(true);
    ask.setReplyMessage(content);
    ask.setReplyTime(DateUtil.now());
    iExperimentAskService.saveOrUpdate(ask);
    return ResultUtil.success();
}

4.4 新增实验实例

代码语言:javascript
复制
@RequestMapping(value = "/addOne", method = RequestMethod.GET)
@ApiOperation(value = "新增实验实例")
public Result<Object> addOne(@RequestParam String experimentId,@RequestParam String userId){
    Experiment experiment = iExperimentService.getById(experimentId);
    if(experiment == null) {
        return ResultUtil.error("实验不存在");
    }
    User currUser = iUserService.getById(userId);
    if(currUser == null) {
        return ResultUtil.error("用户不存在");
    }
    ExperimentExample ee = ExperimentUtils.getNewExperimentExample(experiment);
    ee.setUserId(currUser.getId());
    ee.setUserName(currUser.getNickname());
    ee.setSubmitStatus(0);
    ee.setFile1("");
    ee.setFile2("");
    ee.setFile3("");
    ee.setAuditStatus(0);
    ee.setAuditMessage("未审核");
    ee.setAchievement(BigDecimal.ZERO);
    iExperimentExampleService.saveOrUpdate(ee);
    return ResultUtil.success();
}

4.5 查询实验实例

代码语言:javascript
复制
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询实验实例")
public Result<IPage<ExperimentExample>> getByPage(@ModelAttribute ExperimentExample experimentExample ,@ModelAttribute PageVo page){
    QueryWrapper<ExperimentExample> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(experimentExample.getTitle())) {
        qw.like("title",experimentExample.getTitle());
    }
    if(!ZwzNullUtils.isNull(experimentExample.getUserName())) {
        qw.like("user_name",experimentExample.getUserName());
    }
    IPage<ExperimentExample> data = iExperimentExampleService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<ExperimentExample>>().setData(data);
}

五、免责说明

  • 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
  • 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
  • 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。

下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-02-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、摘要
    • 1.1 项目介绍
      • 1.2 项目录屏
      • 二、功能模块
        • 2.1 实验管理模块
          • 2.2 实验实例模块
            • 2.3 实验批阅模块
              • 2.4 实验咨询模块
              • 三、系统展示
              • 四、核心代码
                • 4.1 查询实验
                  • 4.2 新增实验咨询
                    • 4.3 回复实验咨询
                      • 4.4 新增实验实例
                        • 4.5 查询实验实例
                        • 五、免责说明
                        相关产品与服务
                        云数据库 MySQL
                        腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                        领券
                        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档