基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统

✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌

🍅文末获取项目下载方式🍅


一、项目背景介绍:

随着社会的发展和科技的进步,人们越来越重视健康问题。大学作为培养人才的摇篮,学生的健康状况直接影响到国家的未来。然而,传统的大学健康档案管理方式存在诸多问题,如信息不透明、数据分散、更新不及时等。为了解决这些问题,我们提出了一种基于JAVA+SpringBoot+Vue的前后端分离的大学健康档案管理系统。

该系统采用前后端分离的架构设计,前端使用Vue.js框架进行开发,后端使用Java语言和SpringBoot框架进行开发。通过这种架构设计,我们可以实现前后端的数据交互和业务逻辑处理,提高系统的可维护性和扩展性。

在功能方面,该系统主要包括以下几个模块:

用户管理模块:实现用户的注册、登录、修改个人信息等功能。
健康档案管理模块:用户可以查看和管理自己的健康档案,包括体检记录、疫苗接种记录、疾病史等信息。
健康资讯模块:提供健康相关的资讯和文章,帮助用户了解健康知识,提高自我保健意识。
系统管理模块:管理员可以对系统进行配置和管理,包括用户管理、权限管理等功能。
通过这个系统,我们可以实现大学健康档案的集中管理,提高档案信息的透明度和准确性。同时,学生和教职工可以方便地查询和管理自己的健康档案,及时了解自己的健康状况。此外,该系统还可以为学校提供有关学生健康状况的数据支持,有助于学校制定更加科学合理的健康教育政策。

二、项目技术简介:

  1. JAVA:Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。
    Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
  3. Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
  4. SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
  5. Mybatis-Plus:MyBatis-Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为 简化开发、提高效率而生。

三、系统功能模块介绍:

功能模块图

四、数据库设计:

1:check_info(check_info)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
all_legsvarcharNULL四肢
arthrosisvarcharNULL关节
assay_checkvarcharNULL
birthdatetimeNULL
blood_pressureintNULL
check_resultvarcharNULL
check_timedatetimeNULL
chest_checkvarcharNULL
collegevarcharNULL
color_or_codevarcharNULL彩色图案及编码
correct_left_viewdoubleNULL
correct_right_viewdoubleNULL
culture_levelvarcharNULL
ear_sickvarcharNULL耳疾
footvarcharNULL平足
glandula_thyroideavarcharNULL甲状腺
gradevarcharNULL
growthvarcharNULL发育营养
heartvarcharNULL心脏及血管
heightdoubleNULL
history_checkvarcharNULL既往医史
hypodontiavarcharNULL缺齿
left_auditiondoubleNULL
left_viewdoubleNULL
livervarcharNULL
lungvarcharNULL肺及呼吸道
lymphvarcharNULL淋巴
majorvarcharNULL
mindvarcharNULL神经及精神
namevarcharNULL
nationvarcharNULL
native_placevarcharNULL
occupationvarcharNULL
other_checkvarcharNULL
other_eyes_sickvarcharNULL其他眼疾
other_internal_sickvarcharNULL其他内科疾病
other_sense_sickvarcharNULL其他五官疾病
other_surgery_sickvarcharNULL其他外科疾病
paranasal_sinusvarcharNULL鼻窦
photolongtextNULL
present_addressvarcharNULL
pulseintNULL
real_ageintNULL
remarkvarcharNULL
right_auditiondoubleNULL
right_viewdoubleNULL
sealervarcharNULL
sexvarcharNULL
sign_for_assayvarcharNULL
sign_for_chestvarcharNULL
sign_for_earvarcharNULL
sign_for_eyesvarcharNULL
sign_for_internalvarcharNULL
sign_for_mouthvarcharNULL
sign_for_resultvarcharNULL
sign_for_surgeryvarcharNULL
single_color_judgevarcharNULL单色识别
skinvarcharNULL皮肤
smellvarcharNULL嗅觉
spine_backbonevarcharNULL脊柱
spleenvarcharNULL
stammervarcharNULL口吃
stu_novarcharNULL
suggest_for_checkvarcharNULL
throatvarcharNULL咽喉
tooth_placevarcharNULL齿槽
tooth_sickvarcharNULL龋齿
user_idintNULL
waistlinedoubleNULL
weightdoubleNULL
work_placevarcharNULL
check_yearvarcharNULL

2:health_document(health_document)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
authorvarcharNULL
bookvarcharNULL
contentlongtextNULL
descriptiontextNULL
is_publishedintNULL
publish_datadatetimeNULL
visit_numvarcharNULL

3:resources(resources)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
iconvarcharNULL
namevarcharNULL
parent_idintNULL
permissionvarcharNULL
sortintNULL
typeintNULL
urlvarcharNULL

4:role(role)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
remarkvarcharNULL
role_namevarcharNULL

5:role_resource_bind(role_resource_bind)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
resource_idintNULL
role_idintNULL

6:suggestion(suggestion)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
check_info_idintNULL
contentvarcharNULL
doctor_idintNULL
is_readintNULL
officevarcharNULL
user_idintNULL

7:system_info(system_info)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
noticevarcharNULL
system_namevarcharNULL
versionvarcharNULL

8:user(user)

字段名类型默认值列注释
idintNULL
create_datetimetimestampNULL
update_datetimetimestampNULL
birthdatetimeNULL
collegevarcharNULL
gradevarcharNULL
majorvarcharNULL
namevarcharNULL
passwordvarcharNULL
role_idintNULL
sexvarcharNULL
stu_novarcharNULL
usernamevarcharNULL
culture_levelvarcharNULL
nationvarcharNULL
native_placevarcharNULL
occupationvarcharNULL
present_addressvarcharNULL
work_placevarcharNULL
photolongtextNULL
real_ageintNULL
teacher_idintNULL

五、功能模块:

  1. 系统登录注册:

    系统登录注册

  2. 个人信息:身高体重分析,基本信息

    个人信息

  3. 个人健康档案:不同学年的健康档案统计

    个人健康档案

  4. 档案详情:主要包含基本信息,以及健康信息

    档案详情

  5. 健康建议:医生角色给其他用户的健康建议

    健康建议

  6. 健康知识阅读:

    健康知识阅读

  7. 系统权限管理:

    系统权限管理

六、代码示例:

 @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的前后端分离的大学健康档案管理系统的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。

八、源码获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取项目下载链接,博主联系方式👇🏻👇🏻👇🏻

链接点击直达:下载链接

  • 37
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值