ssm基于java的养老院管理系统(源码+文档+调试+vue)

收藏关注不迷路!!

🌟文末获取源码+数据库🌟

感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人


前言

养老院管理系统是一款旨在提高养老机构运营效率、改善老年人生活质量的软件。系统通过为护工、用户和管理员提供专门的功能模块,确保了养老院的日常工作能够高效有序地进行。该系统不仅提升了养老院的服务品质,也提高了工作效率,满足了不同用户的多样化需求。
系统对于Java、B/S结构、MySql进行了较为深入的学习与应用。主要针对系统的设计与描述,实现和分析与测试方面来表明开发的过程。开发中使用了ssm框架和MySql数据库技术搭建系统的整体架构。利用这些技术结合实际需求进行开发,最后对系统进行相应的测试,测试系统有无存在问题以及测试用户权限来优化系统,最后系统达到预期目标。

详细视频演示

文章底部名片,联系我看更详细的演示视频

一、项目介绍

开发语言:Java
框架:ssm
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven

————————————————

二、功能介绍

养老院管理系统主要有管理员、护工和用户三个功能模块。以下将对这三个功能的作用进行详细的剖析。
管理员模块:管理员是系统中的核心用户,管理员登录后,可以对后台系统进行管理。主要功能有用户、护工、健康科普、健康数据、养老院、入住预约、寝室分配、退住信息、病历档案、外出申请、来访登记、护工工资、药品信息、系统管理、用户信息等功能。

护工:护工进入系统可以实现对健康数据、入住预约、寝室分配、退住信息、病历档案、外出申请、来访登记、护工工资、药品信息、用户信息等功能进行操作

养老院管理系统分三大部分,即管理员管理、护工管理和用户管理。系统按照用户的实际需求开发而来,贴近生活。从管理员出拿到分配好的账号密码可以进入系统,使用相关的系统应用。管理员总体负责整体系统的运行维护,统筹协调。
系统整体模块设计:系统分为管理员、护工和用户三大用户角色,系统管理员有最大的权限,整体功能展示如图4-1所示。
在这里插入图片描述

图4-1 系统整体功能图

三、核心代码

部分代码:


package com.example.controller;

import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.Caiwu;
import com.example.exception.CustomException;
import com.example.service.CaiwuService;
import com.example.utils.MapWrapperUtils;
import com.example.utils.jwt.JwtUtil;
import com.example.vo.CaiwuVo;
import org.springframework.beans.BeanUtils;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@RestController
@RequestMapping(value = "/caiwu")
public class CaiwuController {

    @Resource
    private CaiwuService caiwuService;

    @PostMapping
    public Result<Caiwu> add(@RequestBody CaiwuVo caiwu) {
        caiwuService.add(caiwu);
           return Result.success(caiwu);
    }
	
	

    @PostMapping("/deleteList")
    public Result<Caiwu> deleteList(@RequestBody CaiwuVo caiwu) {
        caiwuService.deleteList(caiwu.getList());
        return Result.success();
    }

    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Long id) {
        caiwuService.delete(id);
        return Result.success();
    }

    @PutMapping
    public Result update(@RequestBody CaiwuVo caiwu) {
        caiwuService.update(caiwu);
        return Result.success();
    }

    @GetMapping("/{id}")
    public Result<Caiwu> detail(@PathVariable Integer id) {
        Caiwu caiwu = caiwuService.findById(id);
        return Result.success(caiwu);
    }

    @GetMapping
    public Result<List<Caiwu>> all() {
        return Result.success(caiwuService.list());
    }

    @PostMapping("/page")
    public Result<CaiwuVo> page(@RequestBody CaiwuVo caiwuVo) {
        return Result.success(caiwuService.findPage(caiwuVo));
    }
	    @PostMapping("/login")
    public Result login(@RequestBody Caiwu caiwu, HttpServletRequest request) {
        if (StrUtil.isBlank(caiwu.getZhanghao()) || StrUtil.isBlank(caiwu.getMima())) {
            throw new CustomException(ResultCode.PARAM_LOST_ERROR);
        }
        Caiwu login = caiwuService.login(caiwu);
//        if(!login.getStatus()){
//            return Result.error("1001","状态限制,无法登录系统");
//        }
        if(login != null) {
            HashMap hashMap = new HashMap();
            hashMap.put("user", login);
            Map<String, Object> map = MapWrapperUtils.builder(MapWrapperUtils.KEY_USER_ID,caiwu.getId());
            String token = JwtUtil.creatToken(map);
            hashMap.put("token", token);
            return Result.success(hashMap);
        }else {
            return Result.error();
        }
    }
    @PutMapping("/updatePassword")
    public Result updatePassword(@RequestBody Caiwu info, HttpServletRequest request) {
        Caiwu caiwu = caiwuService.findById(info.getId());
        String oldPassword = SecureUtil.md5(info.getMima());
        if (!oldPassword.equals(caiwu.getMima())) {
            return Result.error(ResultCode.PARAM_PASSWORD_ERROR.code, ResultCode.PARAM_PASSWORD_ERROR.msg);
        }
        info.setMima(SecureUtil.md5(info.getNewPassword()));
        Caiwu caiwu1 = new Caiwu();
        BeanUtils.copyProperties(info, caiwu1);
        caiwuService.update(caiwu1);
        return Result.success();
    }
}

数据库参考



--
-- Current Database: `ssmn7rjad25`
--

/*!40000 DROP DATABASE IF EXISTS `ssmn7rjad25`*/;

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `ssmn7rjad25` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;

USE `ssmn7rjad25`;

--
-- Table structure for table `aboutus`
--

DROP TABLE IF EXISTS `aboutus`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `aboutus` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `title` varchar(200) NOT NULL COMMENT '标题',
  `subtitle` varchar(200) DEFAULT NULL COMMENT '副标题',
  `content` longtext NOT NULL COMMENT '内容',
  `picture1` longtext COMMENT '图片1',
  `picture2` longtext COMMENT '图片2',
  `picture3` longtext COMMENT '图片3',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='关于我们';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `aboutus`
--

LOCK TABLES `aboutus` WRITE;
/*!40000 ALTER TABLE `aboutus` DISABLE KEYS */;
INSERT INTO `aboutus` VALUES (1,'2024-03-18 05:49:31','关于我们','ABOUT US','当你设想门外是寒冷可怕的世界时,你还应该开门出去看看,是否真的如此。如果你有信心,你对前途就不犹豫了。如果你有勇气,你就不怕前途是否有困难或危险了每个人心中都应有两盏灯,一盏是希望的灯,一盏是勇气的灯。有了这两盏灯,我们就不怕海上的黑暗和风涛的险恶了。人的一生很像是在雾中行走。远远望去,只是迷蒙一片,辨不出方向和吉凶。可是,当你鼓起勇气,放下恐惧和怀疑,一步一步向前走去的时候,你就会发现,每走一步,你都能把下一步路看得清楚一点。“往前走,别站在远远的地方观望!”你就可以找到你的方向。','upload/aboutus_picture1.jpg','upload/aboutus_picture2.jpg','upload/aboutus_picture3.jpg');
/*!40000 ALTER TABLE `aboutus` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `binglidangan`
--

DROP TABLE IF EXISTS `binglidangan`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `binglidangan` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `yonghuzhanghao` varchar(200) DEFAULT NULL COMMENT '用户账号',
  `yonghuxingming` varchar(200) DEFAULT NULL COMMENT '用户姓名',
  `xingbie` varchar(200) DEFAULT NULL COMMENT '性别',
  `nianling` int(11) DEFAULT NULL COMMENT '年龄',
  `tupian` longtext COMMENT '图片',
  `shengao` int(11) DEFAULT NULL COMMENT '身高',
  `tizhong` double DEFAULT NULL COMMENT '体重',
  `xueya` double DEFAULT NULL COMMENT '血压',
  `xuetang` double DEFAULT NULL COMMENT '血糖',
  `xinlv` double DEFAULT NULL COMMENT '心率',
  `yongyaoqingkuang` longtext COMMENT '用药情况',
  `shenghuoxiguan` longtext COMMENT '生活习惯',
  `yiwangbingshi` longtext COMMENT '以往病史',
  `manxingbing` varchar(200) DEFAULT NULL COMMENT '慢性病',
  `jiankangzhuangkuang` varchar(200) DEFAULT NULL COMMENT '健康状况',
  `dengjiriqi` date DEFAULT NULL COMMENT '登记日期',
  `zhanghao` varchar(200) DEFAULT NULL COMMENT '账号',
  `xingming` varchar(200) DEFAULT NULL COMMENT '姓名',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=99 DEFAULT CHARSET=utf8 COMMENT='病历档案';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `binglidangan`
--

LOCK TABLES `binglidangan` WRITE;
/*!40000 ALTER TABLE `binglidangan` DISABLE KEYS */;
INSERT INTO `binglidangan` VALUES (91,'2024-03-18 05:49:31','用户账号1','用户姓名1','性别1',1,'upload/binglidangan_tupian1.jpg,upload/binglidangan_tupian2.jpg,upload/binglidangan_tupian3.jpg',1,1,1,1,1,'','生活习惯1','以往病史1','','健康','2024-03-18','账号1','姓名1'),(92,'2024-03-18 05:49:31','用户账号2','用户姓名2','性别2',2,'upload/binglidangan_tupian2.jpg,upload/binglidangan_tupian3.jpg,upload/binglidangan_tupian4.jpg',2,2,2,2,2,'','生活习惯2','以往病史2','','健康','2024-03-18','账号2','姓名2'),(93,'2024-03-18 05:49:31','用户账号3','用户姓名3','性别3',3,'upload/binglidangan_tupian3.jpg,upload/binglidangan_tupian4.jpg,upload/binglidangan_tupian5.jpg',3,3,3,3,3,'','生活习惯3','以往病史3','','健康','2024-03-18','账号3','姓名3'),(94,'2024-03-18 05:49:31','用户账号4','用户姓名4','性别4',4,'upload/binglidangan_tupian4.jpg,upload/binglidangan_tupian5.jpg,upload/binglidangan_tupian6.jpg',4,4,4,4,4,'','生活习惯4','以往病史4','','健康','2024-03-18','账号4','姓名4'),(95,'2024-03-18 05:49:31','用户账号5','用户姓名5','性别5',5,'upload/binglidangan_tupian5.jpg,upload/binglidangan_tupian6.jpg,upload/binglidangan_tupian7.jpg',5,5,5,5,5,'','生活习惯5','以往病史5','','健康','2024-03-18','账号5','姓名5'),(96,'2024-03-18 05:49:31','用户账号6','用户姓名6','性别6',6,'upload/binglidangan_tupian6.jpg,upload/binglidangan_tupian7.jpg,upload/binglidangan_tupian8.jpg',6,6,6,6,6,'','生活习惯6','以往病史6','','健康','2024-03-18','账号6','姓名6'),(97,'2024-03-18 05:49:31','用户账号7','用户姓名7','性别7',7,'upload/binglidangan_tupian7.jpg,upload/binglidangan_tupian8.jpg,upload/binglidangan_tupian9.jpg',7,7,7,7,7,'','生活习惯7','以往病史7','','健康','2024-03-18','账号7','姓名7'),(98,'2024-03-18 05:49:31','用户账号8','用户姓名8','性别8',8,'upload/binglidangan_tupian8.jpg,upload/binglidangan_tupian9.jpg,upload/binglidangan_tupian10.jpg',8,8,8,8,8,'','生活习惯8','以往病史8','','健康','2024-03-18','账号8','姓名8');
/*!40000 ALTER TABLE `binglidangan` ENABLE KEYS */;
UNLOCK TABLES;


四、效果图

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

五、文章目录

目 录

1 概 述 5
1.1 研究背景与意义 5
1.2 国内外研究现状 5
1.3 研究内容 6
2 关键技术介绍 7
2.1 Java介绍 7
2.2 MySql数据库 7
2.3 Vue.js框架 8
2.4 B/S架构 9
2.5 Ssm框架 9
3 系统分析 11
3.1需求分析 11
3.2系统可行性分析 11
3.2.1经济可行性 12
3.2.2技术可行性 12
3.2.3运行可行性 12
3.3 系统功能分析 12
3.4系统流程分析 14
3.4.1程序流程图设计 14
3.4.2添加信息流程图设计 15
3.4.3删除信息流程图设计 16
4系统的设计 17
4.1 系统总功能模块设计 17
4.2 系统数据库设计 17
4.2.1 数据库系统概要设计 17
4.2.2 E-R模型结构设计 18
4.3数据表设计 18
5 系统详细设计与实现 29
5.1系统注册登录功能实现 29
5.1.1首页页面实现 29
5.1.2个人中心页面 31
5.1.3后台管理 31
5.2后台模块实现 31
5.2.1管理员功能实现 32
5.2.2护工功能实现 35
6系统测试 36
6.1系统测试的目的 36
6.2软件测试过程 36
6.3测试用例 37
结论 38
致谢 39
参考文献 40

六 、源码获取

下方名片联系我即可!!


大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻请添加图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

毕业程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值