一、项目背景介绍:
随着社会的发展和科技的进步,人们越来越重视健康问题。大学作为培养人才的摇篮,学生的健康状况直接影响到国家的未来。然而,传统的大学健康档案管理方式存在诸多问题,如信息不透明、数据分散、更新不及时等。为了解决这些问题,我们提出了一种基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统。
该系统采用前后端分离的架构设计,前端使用Vue.js框架进行开发,后端使用Java语言和SpringBoot框架进行开发。通过这种架构设计,我们可以实现前后端的数据交互和业务逻辑处理,提高系统的可维护性和扩展性。
在功能方面,该系统主要包括以下几个模块:
用户管理模块:实现用户的注册、登录、修改个人信息等功能。
健康档案管理模块:用户可以查看和管理自己的健康档案,包括体检记录、疫苗接种记录、疾病史等信息。
健康资讯模块:提供健康相关的资讯和文章,帮助用户了解健康知识,提高自我保健意识。
系统管理模块:管理员可以对系统进行配置和管理,包括用户管理、权限管理等功能。
通过这个系统,我们可以实现大学健康档案的集中管理,提高档案信息的透明度和准确性。同时,学生和教职工可以方便地查询和管理自己的健康档案,及时了解自己的健康状况。此外,该系统还可以为学校提供有关学生健康状况的数据支持,有助于学校制定更加科学合理的健康教育政策。
二、项目技术简介:
- JAVA:Java是一门 面向对象编程语言 ,不仅 吸收了C++语言的各种优点 ,还摒弃了C++里难以理解的 多继承、指针 等概念,因此Java语言具有 功能强大和简单易用 两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
- Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。 Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
- Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
- SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来 简化 新 Spring 应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
- Mybatis-Plus:MyBatis-Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为 简化开发、提高效率而生。
三、系统功能模块介绍:
四、数据库设计:
1:check_info(check_info)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
all_legs | varchar | NULL | 四肢 |
arthrosis | varchar | NULL | 关节 |
assay_check | varchar | NULL | |
birth | datetime | NULL | |
blood_pressure | int | NULL | |
check_result | varchar | NULL | |
check_time | datetime | NULL | |
chest_check | varchar | NULL | |
college | varchar | NULL | |
color_or_code | varchar | NULL | 彩色图案及编码 |
correct_left_view | double | NULL | |
correct_right_view | double | NULL | |
culture_level | varchar | NULL | |
ear_sick | varchar | NULL | 耳疾 |
foot | varchar | NULL | 平足 |
glandula_thyroidea | varchar | NULL | 甲状腺 |
grade | varchar | NULL | |
growth | varchar | NULL | 发育营养 |
heart | varchar | NULL | 心脏及血管 |
height | double | NULL | |
history_check | varchar | NULL | 既往医史 |
hypodontia | varchar | NULL | 缺齿 |
left_audition | double | NULL | |
left_view | double | NULL | |
liver | varchar | NULL | 肝 |
lung | varchar | NULL | 肺及呼吸道 |
lymph | varchar | NULL | 淋巴 |
major | varchar | NULL | |
mind | varchar | NULL | 神经及精神 |
name | varchar | NULL | |
nation | varchar | NULL | |
native_place | varchar | NULL | |
occupation | varchar | NULL | |
other_check | varchar | NULL | |
other_eyes_sick | varchar | NULL | 其他眼疾 |
other_internal_sick | varchar | NULL | 其他内科疾病 |
other_sense_sick | varchar | NULL | 其他五官疾病 |
other_surgery_sick | varchar | NULL | 其他外科疾病 |
paranasal_sinus | varchar | NULL | 鼻窦 |
photo | longtext | NULL | |
present_address | varchar | NULL | |
pulse | int | NULL | |
real_age | int | NULL | |
remark | varchar | NULL | |
right_audition | double | NULL | |
right_view | double | NULL | |
sealer | varchar | NULL | |
sex | varchar | NULL | |
sign_for_assay | varchar | NULL | |
sign_for_chest | varchar | NULL | |
sign_for_ear | varchar | NULL | |
sign_for_eyes | varchar | NULL | |
sign_for_internal | varchar | NULL | |
sign_for_mouth | varchar | NULL | |
sign_for_result | varchar | NULL | |
sign_for_surgery | varchar | NULL | |
single_color_judge | varchar | NULL | 单色识别 |
skin | varchar | NULL | 皮肤 |
smell | varchar | NULL | 嗅觉 |
spine_backbone | varchar | NULL | 脊柱 |
spleen | varchar | NULL | 脾 |
stammer | varchar | NULL | 口吃 |
stu_no | varchar | NULL | |
suggest_for_check | varchar | NULL | |
throat | varchar | NULL | 咽喉 |
tooth_place | varchar | NULL | 齿槽 |
tooth_sick | varchar | NULL | 龋齿 |
user_id | int | NULL | |
waistline | double | NULL | |
weight | double | NULL | |
work_place | varchar | NULL | |
check_year | varchar | NULL |
2:health_document(health_document)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
author | varchar | NULL | |
book | varchar | NULL | |
content | longtext | NULL | |
description | text | NULL | |
is_published | int | NULL | |
publish_data | datetime | NULL | |
visit_num | varchar | NULL |
3:resources(resources)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
icon | varchar | NULL | |
name | varchar | NULL | |
parent_id | int | NULL | |
permission | varchar | NULL | |
sort | int | NULL | |
type | int | NULL | |
url | varchar | NULL |
4:role(role)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
remark | varchar | NULL | |
role_name | varchar | NULL |
5:role_resource_bind(role_resource_bind)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
resource_id | int | NULL | |
role_id | int | NULL |
6:suggestion(suggestion)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
check_info_id | int | NULL | |
content | varchar | NULL | |
doctor_id | int | NULL | |
is_read | int | NULL | |
office | varchar | NULL | |
user_id | int | NULL |
7:system_info(system_info)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
notice | varchar | NULL | |
system_name | varchar | NULL | |
version | varchar | NULL |
8:user(user)
字段名 | 类型 | 默认值 | 列注释 |
id | int | NULL | |
create_datetime | timestamp | NULL | |
update_datetime | timestamp | NULL | |
birth | datetime | NULL | |
college | varchar | NULL | |
grade | varchar | NULL | |
major | varchar | NULL | |
name | varchar | NULL | |
password | varchar | NULL | |
role_id | int | NULL | |
sex | varchar | NULL | |
stu_no | varchar | NULL | |
username | varchar | NULL | |
culture_level | varchar | NULL | |
nation | varchar | NULL | |
native_place | varchar | NULL | |
occupation | varchar | NULL | |
present_address | varchar | NULL | |
work_place | varchar | NULL | |
photo | longtext | NULL | |
real_age | int | NULL | |
teacher_id | int | NULL |
五、功能模块:
- 系统登录注册:
- 个人信息:身高体重分析,基本信息
- 个人健康档案:不同学年的健康档案统计
- 档案详情:主要包含基本信息,以及健康信息
- 健康建议:医生角色给其他用户的健康建议
- 健康知识阅读:
- 系统权限管理:
六、代码示例:
@GetMapping("/getCurrentCheckInfo/{userId}")
ResponseEntity<CheckInfo> getCurrentCheckInfo(@PathVariable("userId") Integer userId) {
return checkInfoService.getCurrentCheckInfo(userId);
}
@GetMapping("/getBim")
ResponseEntity judgeIsHealth(Double height, Double weight) {
String suggestion;
if (height == null || weight == null) {
throw new MyException(ExceptionEnums.NO_WEIGHT_HEIGHT);
}
Double result = weight / ((height / 100) * (height / 100));
NumberFormat nf = NumberFormat.getNumberInstance();
nf.setMaximumFractionDigits(2);
nf.setRoundingMode(RoundingMode.UP);
result = Double.valueOf(nf.format(result));
if (result < 19) {
suggestion = "体重偏低";
} else if (result < 25) {
suggestion = "健康体重";
} else if (result < 30) {
suggestion = "超重";
} else if (result < 39) {
suggestion = "严重超重";
} else {
suggestion = "极度超重";
}
return ResponseEntity.ok(new HealthDTO().setBim(result).setSuggestion(suggestion));
}
@GetMapping("/getDataAnalysis/{userId}")
ResponseEntity getDataAnalysis(@PathVariable("userId") Integer userId) {
List<CheckInfo> analysis = checkInfoService.getDataAnalysis(userId);
if (analysis == null) {
throw new MyException(ExceptionEnums.NO_CHECK_INFO);
} else {
List<String> label = new ArrayList<>();
List<Double> height = new ArrayList<>();
List<Double> weight = new ArrayList<>();
analysis.forEach(v -> {
label.add(v.getCheckYear());
height.add(v.getHeight());
weight.add(v.getWeight());
});
return ResponseEntity.ok(new AnalysisData().setLabel(label).setHeight(height).setWeight(weight));
}
}
@ApiOperation(value = "基础接口: 分页返回数据")
@PostMapping(value = "page")
public ResponseEntity<Page<CheckInfo>> page(@RequestBody Condition condition) {
//log.info();
return ResponseEntity.ok(checkInfoService.selectPage(condition));
}
/**
* 判断体检表是否存在
*
* @param userId 用户id
* @param checkYear 检查年份
* @return 是否存在
*/
@GetMapping("/judgeCheckIsExist")
ResponseEntity judgeCheckIsExist(Integer userId, String checkYear) {
boolean aBoolean = checkInfoService.CheckIsExist(userId, checkYear);
return ResponseEntity.ok(aBoolean);
}
@ApiOperation(value = "基础接口: 新增操作")
@PostMapping(value = "add")
@RequiresPermissions("checkInfo:add")
public ResponseEntity<CheckInfo> save(@RequestBody CheckInfo checkInfo) {
checkInfo.setCreateDatetime(new Date());
checkInfo.setUpdateDatetime(new Date());
LambdaQueryWrapper<CheckInfo> checkInfoLambdaQueryWrapper = new LambdaQueryWrapper<>();
checkInfoLambdaQueryWrapper.eq(CheckInfo::getCheckYear, checkInfo.getCheckYear());
checkInfoLambdaQueryWrapper.eq(CheckInfo::getStuNo, checkInfo.getStuNo());
CheckInfo check = checkInfoService.getOne(checkInfoLambdaQueryWrapper);
if (null == check && checkInfo.getCheckYear() != null) {
boolean save = checkInfoService.save(checkInfo);
if (save) {
return ResponseEntity.ok(checkInfo);
}
}
throw new MyException(ExceptionEnums.ADD_ERROR);
}
@ApiOperation(value = "基础接口: 返回指定ID的数据")
@GetMapping(value = "get/{id}")
public ResponseEntity<CheckInfo> get(@PathVariable("id") Integer id) {
CheckInfo checkInfo = checkInfoService.getById(id);
if (checkInfo != null) {
return ResponseEntity.ok(checkInfo);
}
throw new MyException(ExceptionEnums.GET_ITEM);
}
七、项目总结:
通过对基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统的开发,让我深刻明白开发一个程序软件需要经历的流程,当确定要开发一个基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统的程序时,
我在开发期间,对其功能进行合理的需求分析,然后才是程序软件的功能的框架设计,数据库的实体与数据表设计,
程序软件的功能详细界面实现,以及程序的功能测试等进行全方位的细致考虑,虽然在此过程中,各个环节都遇到了大大小小的困难,但是通过对这些问题进行反复的分析,深入的思考,
借助各种相关文献资料提供的方法与解决思路成功解决面临的各个问题,最后成功的让我开发的基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统得以正常运行。
基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统在功能上面是基本可以满足用户对系统的操作,但是这个程序软件也有许多方面是不足的,因此,在下一个时间阶段,有几点需要改进的地方需要提出来,它们分别是:
(1)操作页面可以满足用户简易操作的要求,但是在页面多样化设计层面上需要把一些比较丰富的设计结构考虑进来。
(2)程序软件的总体安全性能需要优化,例如程序的退出安全性,以及程序的并发性等问题都需要进行安全性升级,让开发的基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统中的相关网站更贴合。
(3)需要对程序的数据结构方面,程序的代码方面等进行优化,让运行起来的程序可以保持稳定运行,也让程序能够保证短时间内处理相关事务,节省处理事务的时间,提高事务处理的效率,
同时对服务器上资源占用的比例进行降低。
基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统的开发一方面是对自身专业知识技能进行最终考核,另一方面也是让自己学会独立解决程序开发过程中所遇到的问题,掌握将理论知识运用于程序开发实践的方法。
基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。
八、源码获取:
此源码非开源,若需要此源码可扫码添加微信进行咨询!