(2024最新毕设合集)基于Node.js的养老服务系统-44747|可做计算机毕业设计JAVA、PHP、爬虫、APP、小程序、C#、C++、python、数据可视化、大数据、全套文案

养老服务系统的设计与实现

  要

随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。

养老服务系统,主要的模块包括查看首页、通知公告、养老机构、活动信息、护工服务、个人中心;系统用户(管理员、普通用户)。系统中管理员主要是为了安全有效地存储和管理各类信息,还可以对系统进行管理与更新维护等操作,并且对后台有相应的操作权限。

要实现养老服务系统的各项功能,后台数据库起着至关重要的支持作用。管理员需要验证注册信息、收集用户信息,并通过这些数据进行关联分析等操作,这些大量的数据都由数据库管理系统来管理。在本文中,我们选择使用Node.js作为后台服务器,并采用Mysql作为后台数据库,以确保Web与数据库之间的紧密联系。

在系统设计过程中,我们注重保证系统代码具有良好的可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。通过使用Node.js作为后台服务器,我们可以利用其高效的事件驱动和非阻塞I/O模型,实现系统的快速响应和高并发处理能力。同时,借助Mysql作为后台数据库,我们可以有效地存储和管理养老服务系统所需的各类数据。

本文基于Node.js的养老服务系统设计中,我们注重充分利用Mysql作为后台数据库来管理和处理大量的数据。通过保证系统代码质量和设计特点,我们旨在实现一个高效、可靠、易维护的养老服务系统,以满足用户需求并提升用户体验。

关键词Node.js、养老服务系统、Mysql

Design and Implementation of Elderly Care Service Platform

Abstract

With the development of society, various industries are taking advantage of the advantages of the information age. The advantages and popularity of computers make the development of various information systems necessary.

The elderly care service system mainly includes modules such as viewing the homepage, notification announcements, elderly care institutions, activity information, caregiver services, and personal centers; System users (administrators, regular users). The main purpose of administrators in the system is to securely and effectively store and manage various types of information. They can also manage, update, and maintain the system, and have corresponding operation permissions for the backend.

To achieve the various functions of the elderly care service system, the backend database plays a crucial supporting role. Administrators need to verify registration information, collect user information, and perform correlation analysis on this data, which is managed by a database management system. In this article, we choose to use Node.js as the backend server and MySQL as the backend database to ensure a close connection between the web and the database.

In the system design process, we focus on ensuring that the system code has good readability, practicality, scalability, universality, ease of later maintenance, easy operation, and concise pages. By using Node.js as the backend server, we can leverage its efficient event driven and non blocking I/O model to achieve fast response and high concurrency processing capabilities of the system. Meanwhile, with the help of MySQL as the backend database, we can effectively store and manage various types of data required by the elderly care service system.

In the design of the elderly care service system based on Node.js, we focus on fully utilizing MySQL as the backend database to manage and process a large amount of data. By ensuring the quality of system code and design features, we aim to achieve an efficient, reliable, and easy to maintain elderly care service system to meet user needs and enhance user experience.

Key words: Node.js, elderly care service system, MySQL

目录

养老服务系统的设计与实现

摘  要

Abstract

1 系统概述

1.1 概述

1.2课题意义

1.3 主要内容

2 系统开发环境

2.1 B/S体系结构介绍

2.2 Express框架介绍

2.3 Vue.js主要功能

2.4 MySQL数据库

2.5 NodeJS技术

3 需求分析

3.1技术可行性:技术背景     

3.2经济可行性

3.3操作可行性: 

3.4系统设计规则

3.5系统流程和逻辑

4系统概要设计

4.1 概述

4.2 系统结构

4.3. 数据库设计

4.3.1 数据库实体

4.3.2 数据库设计表

4.4 数据表

5 系统详细设计

5.1管理员功能模块

5.2用户功能模块

6 系统测试

6.1系统测试的目的

6.2系统测试方法

6.3测试过程

6.4 测试结果

结论

致 谢

参考文献

1 系统概述

1.1 概述

随着社会的快速发展,计算机的影响是全面且深入的。人们生活水平的不断提高,使得养老服务系统的开发成为必需而且紧迫的事情。养老服务系统主要是借助计算机,通过对养老服务系统所需的信息管理,增加用户选择,同时也方便对广大用户信息的及时查询、修改以及对用户信息的及时了解。养老服务系统给用户带来了更多的便利, 该系统通过和数据库管理系统软件协作来满足用户的需求。

1.2课题意义

随着全球信息化的发展,人们的生活节奏越来越快,对信息的时效性越来越重视。以传统的宣传方式为载体的传统媒介早已不能满足人们对获取信息的方式、便捷性的需求。所以养老服务系统渐渐成为人们关注的焦点。首先,养老服务系统,网上获取信息的实时性、便捷性要远远高于传统媒介。系统一经上线,无论用户在世界的哪个角落,只要能够连接互联网,就能在第一时间获得想要的信息。

计算机技术在现代管理中的应用,使计算机成为人们应用现代技术的重要工具。能够有效的解决获取信息便捷化、全面化的问题,提高效率。

1.3 主要内容

养老服务系统从功能、数据流程、可行性、运行环境等方面进行需求分析。对养老服务系统的数据库、功能进行了详细设计。分析了主要界面设计和相关组件设计,对养老服务系统的具体实现进行了介绍。

采用Node.js作为后台服务器,从数据库中获取数据、向数据库中写入数据,实现系统直接对数据库进行各种操作,在网页中加入动态内容,从而实现养老服务系统所需要的各种基本功能。

2 系统开发环境

本系统前端部分基于MVVM模式进行开发,采用B/S模式,后端部分基于node.js的koa框架进行开发。

前端部分:前端框架采用了比较流行的渐进式JavaScript框架Vue.js。使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信,Element UI组件库使页面快速成型,可适应PC端、平板端、手机端等不同屏幕大小尺寸的完美布局展示。

后端部分:采用koa作为开发框架,同时集成Redis等相关技术。。

2.1 B/S体系结构介绍

B/S结构(Browser/Server,浏览器/服务器模式),是WEB兴起后的一种网络结构模式,WEB浏览器是客户端最主要的应用软件。这种模式统一了客户端,将系统功能实现的核心部分集中到服务器上,简化了系统的开发、维护和使用。客户机上只要安装一个浏览器,如Chrome、Safari、Microsoft Edge、Netscape Navigator或Internet Explorer,服务器安装SQL Server、Oracle、MYSQL等数据库。浏览器通过Web Server同数据库进行数据交互。[1][2]。

2.2 Express框架介绍

Express 是一个简洁而灵活的 node.js Web应用框架, 提供一系列强大特性帮助你创建各种Web应用。Express 不对 node.js 已有的特性进行二次抽象,我们只是在它之上扩展了Web应用所需的功能。丰富的HTTP工具以及来自Connect框架的中间件随取随用,创建强健、友好的API变得快速又简单[3]。

通过使用Node Express,可以使用更少的代码来实现功能。至少通过使用Node Express可以实现中间件来响应http请求,可以定义路由表来定义不同请求的响应函数,还可以使用模板引擎来输出html页面。其实这也是Express的核心特点。

使用 Express 可以快速地搭建一个完整功能的网站。

Express 框架核心特性:

(1)可以设置中间件来响应 HTTP 请求;(2)定义了路由表用于执行不同的 HTTP 请求动作;(3)可以通过向模板传递参数来动态渲染 HTML 页面[4]。

2.3 Vue.js主要功能

Vue.js是一套构建用户界面的渐进式框架。与其他重量级框架不同的是,Vue采用自底向上增量开发的设计。Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整合。另一方面,Vue 完全有能力驱动采用单文件组件和Vue生态系统支持的库开发的复杂单页应用。

Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

Vue.js 自身不是一个全能框架——它只聚焦于视图层。因此它非常容易学习,非常容易与其它库或已有项目整合。另一方面,在与相关工具和支持库一起使用时,Vue.js 也能驱动复杂的单页应用[5]。

2.4 MySql数据库

Mysql的语言是非结构化的,用户可以在数据上进行工作。因为Mysql的语言和结构比较简单,但是功能和存储信息量很强大,其速度、可靠性和适应性而备受关注并得到了普遍的应用。Mysql数据库在编程过程中的作用是很广泛的,为用户进行数据查询带来了方便。Mysql数据库的应用特点:灵活性强,功能强大,语言相对要简洁很多。 

数据流程分析主要就是数据存储的储藏室,它是在计算机上进行的,而不是现实中的储藏室。数据库管理主要是数据存储、修改和增加以及数据表的建立。数据表的建立,可以对数据表中的数据进行调整,数据的重新组合及重新构造,保证数据的安全性。介于数据库的功能强大等特点,本系统的开发主要应用了Mysql进行对数据的管理。

2.5 Node.js技术

Node.js 一种javascript的运行环境,能够使得javascript能够脱离浏览器运行。以前js只能在浏览器基础上运行,能够操作的也知识浏览器,比如浏览器上的放大缩小操作,前提是浏览器开启的基础上进行操作(浏览器是客户端)。有了Node.js之后,js可以在服务端进行操作,直接在系统上进行操作,可以打开、关闭浏览器等操作。

简单的说 Node.js 就是运行在服务端的 JavaScript。Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台。Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好[8][9]。Node.js 不是库,是一个运行环境,或者说是一个JS语言解释器。Node.js今天已经成为了Web 前端开发必不可少的基础设施[10]。

3 需求分析

3.1技术可行性:技术背景     

养老服务系统是基于Node.js开发和运行的,它可以在Windows操作系统下进行开发和应用。目前,PC机的性能已经足够满足普通网站的Web服务器需求。系统开发所使用的技术也都是Node.js所具备的,并且是当今广泛应用的技术之一。

系统的开发环境和配置都是可以自行安装的,系统使用Node.js开发工具,使用比较成熟的Mysql数据库进行对系统前台及后台的数据交互,根据技术语言对数据库,结合需求进行修改维护,可以使得网站运行更具有稳定性和安全性,从而完成实现网站的开发。

(1)硬件可行性分析

系统管理及信息分析的设计对于所使用的计算机没有什么硬性的要求,计算机只要可以正常的使用进行代码的编写及页面设计就可行,主要是对于服务器有些要求,对于平台搭建完成要上传的服务器是有一定的要求的,服务器必须选择安全性比较高的,然后就是在打开网站必须顺畅,不能停顿太长时间;性价比高;安全性高。

(2)软件可行性分析

开发整个系统使用的是云计算,流量的可扩展性和基于流量的智能调整云计算的优点就是流量的可扩展性和基于流量的智能调整,保障了数据信息能够得到及时的备份,整个系统可以安全有效的运行。

因此,我们从两个方面进行了可行性研究,可以看出系统的开发没有问题。

3.2经济可行性

在养老服务系统开发之前所做的市场调研及与其相关的其他管理系统,都是没有任何费用的。所有的调查研究都是通过开发者自己的努力,所有的工作也都是自己亲力亲为的。在碰到自己比较难以解决的问题时,大多数是通过指导老师和同学的帮助进行相关问题的解决。所以对于养老服务系统的开发在经济上是完全可行的,没有任何费用支出的。

使用比较成熟的技术,系统是基于Node.js的开发,采用Mysql数据库。所以系统在开发人力、财力方面的要求不高,具有经济可行性。

3.3操作可行性: 

可操作性主要是对在养老服务系统设计完成后,用户的使用体验度,以及管理员可以通过系统随时管理相关的数据信息,并且对于管理员、用户两个角色,都可以简单明了的进入到自己的系统界面,通过界面导航菜单可以简单明了地操作功能模块,方便用户信息的操作需求和管理员管理数据信息。对于系统的操作,不需要专业人员都可以直接进行功能模块的操作管理,所以养老服务系统的可操作性是完全可行的。本系统的操作使用的也是界面窗口进行登录,所以操作人员只要会简单的电脑操作就完全可以的。

3.4系统设计规则

本养老服务系统采用Node.js技术,Mysql数据库开发,充分保证了系统稳定性、完整性。

养老服务系统的设计与实现的设计思想如下:

1、操作简单方便、系统界面安全良好:简单明了的页面布局,方便查询养老服务系统管理的相关信息。

2、即时可见:对养老服务系统信息的处理将立马在对应地点可以查询到,从而实现“即时发布、即时见效”的系统功能。

3、功能的完善性:可以管理系统首页、个人中心、系统用户管理、养老机构管理、活动信息管理、报名信息管理、护工服务管理、护工聘请管理、护理计划管理、健康档案管理、体检预约管理、系统管理、通知公告管理的修改和维护操作。

3.5系统流程和逻辑

系统业务流程图,如图所示:

图3-1登录流程图

图3-2添加信息流程图

图3-3注册信息流程图

4系统概要设计

4.1 概述

养老服务系统基于Web服务模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在不受时间、地点的限制来使用这个系统。养老服务系统工作原理图,如图4-1所示:

图4-1  系统工作原理图

4.2 系统结构

本系统架构网站系统,本系统的具体功能如下:

图4-2系统功能结构图

整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计。

系统功能结构图,如图4-3所示:

图4-3 系统功能结构图

4.3. 数据库设计

4.3.1 数据库实体

管理员信息结构图,如图4-5所示:

 图4-5 管理员信息实体结构图

用户信息实体属性图,如图4-6所示:

图4-6用户信息实体属性图

4.3.2 数据库设计表

  数据库的设计承载者系统的各种数据,在建立数据库的时候,主要是数据库模型的设计以及各个数据库表的设计两部分。

下面是整个养老服务系统中主要的数据库表以及总E-R实体关系图。  

   图4-7 系统ER图

4.4 数据表

将数据库概念设计的E-R图转换为关系数据库。在关系数据库中,数据关系由数据表组成,但是表的结构表现在表的字段上。

表access_token (登陆访问时长)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

token_id

int

10

0

N

Y

临时访问牌ID

2

token

varchar

64

0

Y

N

临时访问牌

3

info

text

65535

0

Y

N

4

maxage

int

10

0

N

N

2

最大寿命:默认2小时

5

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

7

user_id

int

10

0

N

N

0

用户编号:

表auth (用户权限管理)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

auth_id

int

10

0

N

Y

授权ID:

2

user_group

varchar

64

0

Y

N

用户组:

3

mod_name

varchar

64

0

Y

N

模块名:

4

table_name

varchar

64

0

Y

N

表名:

5

page_title

varchar

255

0

Y

N

页面标题:

6

path

varchar

255

0

Y

N

路由路径:

7

position

varchar

32

0

Y

N

位置:

8

mode

varchar

32

0

N

N

_blank

跳转方式:

9

add

tinyint

3

0

N

N

1

是否可增加:

10

del

tinyint

3

0

N

N

1

是否可删除:

11

set

tinyint

3

0

N

N

1

是否可修改:

12

get

tinyint

3

0

N

N

1

是否可查看:

13

field_add

text

65535

0

Y

N

添加字段:

14

field_set

text

65535

0

Y

N

修改字段:

15

field_get

text

65535

0

Y

N

查询字段:

16

table_nav_name

varchar

500

0

Y

N

跨表导航名称:

17

table_nav

varchar

500

0

Y

N

跨表导航:

18

option

text

65535

0

Y

N

配置:

19

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

20

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表caregiver_services (护工服务)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

caregiver_services_id

int

10

0

N

Y

护工服务ID

2

name_of_caregiver

varchar

64

0

Y

N

护工姓名

3

gender_of_caregiver

varchar

64

0

Y

N

护工性别

4

picture_of_caregiver

varchar

255

0

Y

N

护工图片

5

elderly_care_services

varchar

64

0

Y

N

养老服务

6

hiring_fees

int

10

0

Y

N

0

聘请费用

7

service_introduction

text

65535

0

Y

N

服务介绍

8

hits

int

10

0

N

N

0

点击数

9

praise_len

int

10

0

N

N

0

点赞数

10

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

11

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表collect (收藏)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

collect_id

int

10

0

N

Y

收藏ID:

2

user_id

int

10

0

N

N

0

收藏人ID:

3

source_table

varchar

255

0

Y

N

来源表:

4

source_field

varchar

255

0

Y

N

来源字段:

5

source_id

int

10

0

N

N

0

来源ID:

6

title

varchar

255

0

Y

N

标题:

7

img

varchar

255

0

Y

N

封面:

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表comment (评论)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

comment_id

int

10

0

N

Y

评论ID:

2

user_id

int

10

0

N

N

0

评论人ID:

3

reply_to_id

int

10

0

N

N

0

回复评论ID:空为0

4

content

longtext

2147483647

0

Y

N

内容:

5

nickname

varchar

255

0

Y

N

昵称:

6

avatar

varchar

255

0

Y

N

头像地址:[0,255]

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

9

source_table

varchar

255

0

Y

N

来源表:

10

source_field

varchar

255

0

Y

N

来源字段:

11

source_id

int

10

0

N

N

0

来源ID:

表elderly_care_institutions (养老机构)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

elderly_care_institutions_id

int

10

0

N

Y

养老机构ID

2

institution_name

varchar

64

0

Y

N

机构名称

3

institution_type

varchar

64

0

Y

N

机构类型

4

institution_image

varchar

255

0

Y

N

机构图片

5

institutional_scale

varchar

64

0

Y

N

机构规模

6

institutional_location

varchar

64

0

Y

N

机构位置

7

institutional_introduction

text

65535

0

Y

N

机构介绍

8

hits

int

10

0

N

N

0

点击数

9

praise_len

int

10

0

N

N

0

点赞数

10

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

11

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表event_information (活动信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

event_information_id

int

10

0

N

Y

活动信息ID

2

activity_name

varchar

64

0

Y

N

活动名称

3

activity_images

varchar

255

0

Y

N

活动图片

4

event_location

varchar

64

0

Y

N

活动地点

5

activity_time

datetime

19

0

Y

N

活动时间

6

activity_content

text

65535

0

Y

N

活动内容

7

hits

int

10

0

N

N

0

点击数

8

praise_len

int

10

0

N

N

0

点赞数

9

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表health_records (健康档案)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

health_records_id

int

10

0

N

Y

健康档案ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

health_condition

varchar

64

0

Y

N

健康状况

5

evaluation_time

date

10

0

Y

N

评估时间

6

health_assessment

text

65535

0

Y

N

健康评估

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表hits (用户点击)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

hits_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

表notice (公告)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

notice_id

mediumint

8

0

N

Y

公告id:

2

title

varchar

125

0

N

N

标题:

3

content

longtext

2147483647

0

Y

N

正文:

4

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

5

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表nursing_plan (护理计划)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

nursing_plan_id

int

10

0

N

Y

护理计划ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

nursing_date

date

10

0

Y

N

护理日期

5

nursing_plan

text

65535

0

Y

N

护理计划

6

nursing_progress

text

65535

0

Y

N

护理进度

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表physical_examination_appointment (体检预约)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

physical_examination_appointment_id

int

10

0

N

Y

体检预约ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

appointment_time

date

10

0

Y

N

预约时间

5

physical_examination_content

text

65535

0

Y

N

体检内容

6

other_remarks

text

65535

0

Y

N

其他备注

7

examine_state

varchar

16

0

N

N

未审核

审核状态

8

examine_reply

varchar

16

0

Y

N

审核回复

9

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表praise (点赞)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

praise_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

status

bit

1

0

N

N

1

点赞状态:1为点赞,0已取消

表recruitment_of_caregivers (护工聘请)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

recruitment_of_caregivers_id

int

10

0

N

Y

护工聘请ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

name_of_caregiver

varchar

64

0

Y

N

护工姓名

5

elderly_care_services

varchar

64

0

Y

N

养老服务

6

hiring_fees

varchar

64

0

Y

N

聘请费用

7

pay_state

varchar

16

0

N

N

未支付

支付状态

8

pay_type

varchar

16

0

Y

N

支付类型: 微信、支付宝、网银

9

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表registration_information (报名信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

registration_information_id

int

10

0

N

Y

报名信息ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

activity_name

varchar

64

0

Y

N

活动名称

5

event_location

varchar

64

0

Y

N

活动地点

6

activity_time

varchar

64

0

Y

N

活动时间

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表regular_users (普通用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

regular_users_id

int

10

0

N

Y

普通用户ID

2

user_name

varchar

64

0

Y

N

用户姓名

3

user_gender

varchar

64

0

Y

N

用户性别

4

contact_information

varchar

64

0

Y

N

联系方式

5

examine_state

varchar

16

0

N

N

已通过

审核状态

6

user_id

int

10

0

N

N

0

用户ID

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表sensitive_vocabulary (敏感词汇)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

sensitive_vocabulary_id

int

10

0

N

Y

敏感词汇ID

2

sensitive_vocabulary

varchar

64

0

Y

N

敏感词汇

3

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表slides (轮播图)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

slides_id

int

10

0

N

Y

轮播图ID:

2

title

varchar

64

0

Y

N

标题:

3

content

varchar

255

0

Y

N

内容:

4

url

varchar

255

0

Y

N

链接:

5

img

varchar

255

0

Y

N

轮播图:

6

hits

int

10

0

N

N

0

点击量:

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表upload (文件上传)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

upload_id

int

10

0

N

Y

上传ID

2

name

varchar

64

0

Y

N

文件名

3

path

varchar

255

0

Y

N

访问路径

4

file

varchar

255

0

Y

N

文件路径

5

display

varchar

255

0

Y

N

显示顺序

6

father_id

int

10

0

Y

N

0

父级ID

7

dir

varchar

255

0

Y

N

文件夹

8

type

varchar

32

0

Y

N

文件类型

表user (用户账户:用于保存用户登录信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_id

mediumint

8

0

N

Y

用户ID:[0,8388607]用户获取其他与用户相关的数据

2

state

smallint

5

0

N

N

1

账户状态:[0,10](1可用|2异常|3已冻结|4已注销)

3

user_group

varchar

32

0

Y

N

所在用户组:[0,32767]决定用户身份和权限

4

login_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

上次登录时间:

5

phone

varchar

11

0

Y

N

手机号码:[0,11]用户的手机号码,用于找回密码时或登录时

6

phone_state

smallint

5

0

N

N

0

手机认证:[0,1](0未认证|1审核中|2已认证)

7

username

varchar

16

0

N

N

用户名:[0,16]用户登录时所用的账户名称

8

nickname

varchar

16

0

Y

N

昵称:[0,16]

9

password

varchar

64

0

N

N

密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成

10

email

varchar

64

0

Y

N

邮箱:[0,64]用户的邮箱,用于找回密码时或登录时

11

email_state

smallint

5

0

N

N

0

邮箱认证:[0,1](0未认证|1审核中|2已认证)

12

avatar

varchar

255

0

Y

N

头像地址:[0,255]

13

open_id

varchar

255

0

Y

N

针对获取用户信息字段

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

15

vip_level

varchar

255

0

Y

N

会员等级

16

vip_discount

double

11

2

Y

N

0.00

会员折扣

表user_group (用户组:用于用户前端身份和鉴权)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

group_id

mediumint

8

0

N

Y

用户组ID:[0,8388607]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]

3

name

varchar

16

0

N

N

名称:[0,16]

4

description

varchar

255

0

Y

N

描述:[0,255]描述该用户组的特点或权限范围

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

register

smallint

5

0

Y

N

0

注册位置:

9

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5 系统详细设计   

5.1管理员功能模块

管理员登录,管理员通过输入用户,密码,角色等信息进行系统登录,如图5-1所示。

图5-1管理员登录界面图

登录关键代码如下:

const md5 = require("md5");

var Controller = require("../core/controller.js");

class Login extends Controller {

constructor(config) {

super(

Object.assign({

tpl: "./login/",

service: "user",

},

config

)

);

}

}

Login.prototype.api = async function(ctx) {

var body = ctx.request.body;

var obj = await $.services["user"].get_obj({

username: body.username

},{like:false});

if (obj) {

var group = await $.services["user_group"].get_obj({

name:obj.user_group

})

if (group){

if (group.name!=="管理员"){

var sql = "select examine_state from "+ group.source_table +" WHERE user_id = " + obj.user_id;

var userExamine = await $.mysql.run(sql);

if (userExamine && userExamine.length > 0 && userExamine[0].examine_state!=="已通过"){

return {

error: {

code: 70000,

message: "该用户审核未通过"

},

};

}

}

if (obj.state!==1){

return {

error: {

code: 70000,

message: "用户非可用状态,不能登录"

},

};

}

var password = md5(body.password);

if (password === obj.password) {

ctx.session.user = obj;

var date = Date.parse(new Date());

var token = md5(obj.user_id + "_" + date);

await $.services["access_token"].add({

token,

info: JSON.stringify(obj),

user_id:obj.user_id

});

obj.token = token;

return {

result: {obj}

};

} else {

return {

error: {

code: 70000,

message: "密码错误"

},

};

}

}else {

return {

error: {

code: 70000,

message: "用户组不存在"

},

};

}

} else {

return {

error: {

code: 70000,

message: "账户不存在"

}

};

}

};

管理员登录进入养老服务系统可以查看管理员:后台首页、个人中心、系统用户管理、养老机构管理、活动信息管理、报名信息管理、护工服务管理、护工聘请管理、护理计划管理、健康档案管理、体检预约管理、系统管理、通知公告管理等内容,如图5-2所示。

图5-2管理员功能界面图

用户管理,在用户管理页面可以查看信息:用户昵称 、姓名、用户姓名、头像、性别、联系方式等信息,并可根据需要进行新增、详情、修改或删除等操作,如图5-3所示。

图5-3用户管理界面图

养老机构管理,在养老机构管理页面可以查看列表详情:机构名称、机构类型、图片、规模、位置、介绍等信息,并可根据需要进行新的养老机构添加信息填写、新增、详情、修改或删除等操作,如图5-4所示。养老机构新增如图5-5所示。

图5-4养老机构管理界面图

          图5-5  养老机构的新增管理界面图

活动信息管理,在服务项目管理页面可以查看列表详情和评论:机构名称、机构类型、图片、规模、位置、介绍等信息,并可根据需要进行新的活动信息的添加信息填写、详情、新增、详情、修改、查看评论或删除等操作,如图5-6所示。活动信息新增如图 5-7所示。

图5-6活动信息管理界面图

  图5-7活动信息的新增管理界面图

报名信息管理,在报名信息管理页面可以查看列表详情:普通用户、用户姓名、活动名称、活动地点、活动时向等信息,并可根据需要进行详情、修改或删除等操作,如图5-8所示。

图5-8报名信息管理界面图

护工服务管理,在上门服务管理页面可以查看列表详情和评论:护工姓名、护工性别、护工图片、养老服务、聘请费用、服务介绍等信息,并可根据需要进行新的护工服务信息的添加信息填写、详情、修改或删除等操作,如图5-9所示。护工服务新增如图5-10所示。

图5-9护工服务管理界面图

   图5-10护工服务的新增管理界面图

护工聘请管理,在护工聘请管理页面可以查看列表详情、护理计划和支付状态:普通用户、用户姓名、护工姓名、养老服务、聘请费用、支付状态、支付类型等信息,并可根据需要进行详情、修改或删除等操作,如图5-11所示。

图5-11护工聘请管理界面图

护理计划管理,在护工聘请管理页面可以查看列表详情、普通用户、用户姓名、护理日期、护理计划、护理进度等信息,并可根据需要进行详情、修改或删除等操作,如图5-12所示。

           图5-12护理计划管理界面图

健康档案管理,在健康档案管理页面可以查看列表详情:普通用户、用户姓名、健康状况、评估时问、健康评估等信息,并可根据需要进行新的健康档案信息的添加信息填写新增、详情、修改或删除等操作,如图5-9所示;商品分类的新增如图5-13所示。健康档案新增如图5-14所示。

图5-13健康档案管理界面图

图5-14健康档案的新增界面图

体检预约管理,在体检预约管理页面可以查看列表详情:普通用户、用户姓名、预约时间、体检内容、其他备注、审核状态、审核回复等信息,并可根据需要进行新的体检预约信息的添加信息填写新增、详情、修改、查看评论或删除等操作,如图5-15所示;商品信息信息的新增如图5-16所示。

图5-15体检预约管理界面图

图5-16体检预约的新增界面图

系统管理包括:轮播图管理;轮播图管理如图5-17所示; 

图5-17轮播图管理界面图

5.2用户功能模块

用户注册,在用户注册页面通过填写用户账号、密码、用户姓名、头像、性别、手机、地址等信息完成用户注册,如图5-18所示。

图5-18用户注册界面图

用户注册关键代码如下:

Register.prototype.index = async function(ctx) {

var group_list = await $.services["user_group"].get_list({}, Object.assign({}, this.config));

return await ctx.render(this.config.tpl + "index.html", {

group_list

});

};

Register.prototype.api = async function(ctx) {

var user = $.services.user;

var body = ctx.request.body;

var username = body.username;

var obj = await user.get_obj({

username

});

if (obj) {

return {

error: {

code: 70000,

message: "账户名已存在",

},

};

} else {

var password = md5(body.password);

var nickname = body.nickname;

var user_group = body.user_group;

var email = body.email;

var email_state= body.hasOwnProperty('email_state') ? body.email_state : 0;

var phone = body.phone;

var phone_state= body.hasOwnProperty('phone_state') ? body.phone_state : 0;

var avatar = body.avatar;

var bl_reg = await user.add({

username,

password,

nickname,

user_group,

email,

email_state,

phone,

phone_state,

avatar

});

if (bl_reg) {

return {

result: "注册成功"

};

} else {

return {

error: {

code: 70000,

message: "注册失败",

},

};

}

}

};

用户登录:用户通过输入用户账号,密码,角色等信息进行系统登录;如图5-19所示。

图5-19用户登录界面图

在首页这里用户可以咨询心理问题跟其他问题,用户登录进入后台可以查看首页、通知公告、养老机构、活动信息、护工服务、个人中心等内容,如图5-20所示。用户咨询功能如图5-21所示。

图5-20用户功能界面图

图5-21用户咨询功能界面图

个人中心:在个人中心页面可以查看内容详情:个人首页、报名信息、护工聘请、护理计划、健康档案、体检预约、收藏等信息,如图5-22所示;护工聘请里能进行支付费用,如图5-23所示.

图5-22个人中心界面图

图5-23护工聘请支付费用界面图

活动信息:在活动信息页面可以查看各种详细的活动信息发表评论;并可对喜欢的活动进行报名,如图5-24所示.

图5-24活动信息界面图

护工服务:在护工服务页面可以查看系统里的护工服务人员介绍,可对护工进行挑选聘请;如图5-25所示。护工聘请如图5-26所示。

图5-22护工服务界面图

图5-26护工聘请界面图

6 系统测试

6.1系统测试的目的 

程序设计不能保证没有错误,这是一个开发过程,在错误或错误的过程中都是难以避免的。虽然这是不可避免的,但我们不能使这些错误始终存在于系统中,错误可能会造成无法估量的后果,如系统崩溃,安全信息泄露,系统无法正常启动等,为了避免这些问题我们需要测试程序,在测试过程中发现问题并纠正它们,从而使系统更长时间稳定成熟。

本章的作用是发现这些问题,并对其进行修改,虽然耗时费力,但对于长期使用而言是非常重要和必要系统的开发。 

软件在设计后必须进行测试,调试过程中使用的方法是软件测试方法。在开发新软件时,系统测试是检查软件是否合格的关键步骤,以及是否符合设计目标的参考。测试主要是查看软件中数据的准确性,正确的操作与否,以及操作的结果,还有哪些方面需要改进。 

养老服务系统的实现,对于系统中功能模块的实现及操作都必须通过测试进行来评判系统是否可以准确的实现。在养老服务系统正式上传使用之前必须做的一步就是系统测试,对于测试发现的错误及时修改处理,保证系统准确无误的供给用户使用。 

6.2系统测试方法 

在对养老服务系统进行测试的时候,在找到问题的情况下必须在第一时间找到解决问题的办法,不要存在侥幸的心理,这样才能让养老服务系统开发的质量可以过关,并且开发的周期会大大缩短,还有就是在测试时,不要出现重复性的错误,遇到一个错误问题,要将整个养老服务系统开发所牵扯的该问题都必须一一解决,提高养老服务系统的安全性、稳定性。 

白盒测试与黑盒测试是测试中比较常用的两种方法。 

①结构测试俗称白盒测试:这种测试是在对程序的处理过程与结构都有详尽谅解的前提下,顺从程序内部的逻辑而完成的系统测试,以确定系统中所有的通路都能够遵照设计要求正常工作,不出现任何偏差。 

②功能测试又成黑盒测试:主要是针对程序功能能够按照设计正常实现的一种检测,在程序接口处进行,检测程序手法数据是否正常,与外部信息的交换是否完整。 

6.3测试过程

在软件的测试过程中,通常测试人员需要针对不同的功能模块设计多种测试用例。通过测试用例能够及时发现代码业务逻辑上是否与真实的业务逻辑相对应,及时发现代码上或逻辑上的缺陷,以此来来完善系统,提高软件产品的质量,使软件具有良好的用户体验。

注册测试用例表如下所示。

表6-1注册测试用例

测试性能

新用户注册

用例目的

测试系统新用户个人信息注册功能的功能和安全性

前提条件

进入注册页面填写个人信息

输入条件

预期输出

实际情况

各项基本信息输入不完整

不允许注册,无法点击注册按钮

一致

填写已存在的用户名

系统显示出提示信息,要求重新填写

一致

两次密码输入不一致

系统显示出提示信息,要求重新填写

一致

填写的各项信息没有符合提示的长度和字符要求

系统显示出提示信息,要求重新填写

一致

胡乱填写电话号码

收不到验证码

一致

填写验证码与收到的不一致

系统显示提示信息告知用户验证码错误,不予注册

一致

登录测试用例表如下所示。

表6-2登录测试用例

测试性能

用户或操作员登录系统

用例目的

测试用户或操作员登录系统时功能是否正常

前提条件

进入用户登录页面或操作员登录页面

输入条件

预期输出

实际情况

各项信息不予填写,直接点击登陆按钮

不允许登录,提示填写账号相关信息

一致

填写错误的登录名或密码后点击登录系统

提示用户名或密码错误,要求重新填写进行登录

一致

填写与验证码信息不一致的信息

系统显示出提示信息,表明验证码错误,要求重新填写

一致

6.4 测试结果

经过对一系列测试结果的有效分析,本平台开发系统符合用户的要求和需求。所有的基本功能相对齐全,操作起来简单方便,测试系统性能良好,作为大众化系统使用是比较值得推广宣传的。

结论

本系统通过对Node.js和Mysql数据库的简介,从硬件和软件两反面说明了养老服务系统的可行性,本文结论及研究成果如下:实现了Node.js与Mysql相结合构建的养老服务系统,网站可以响应式展示。通过本次养老服务系统的研究与实现,我感到学海无涯,学习是没有终点的,而且实践出真知,只有多动手才能尽快掌握它,经验对系统的开发非常重要,经验不足,就难免会有许多考虑不周之处。比如要有美观的界面,更完善的功能,才能吸引更多的用户。

由于在此之前对于Node.js知识没有深入了解,所以从一开始就碰到许多困难,例如一开始的页面显示不规范、数据库连接有问题已经无法实现参数的传递等等,不过通过在网上寻找有关资料以及同学的帮助下最后都得到了解决,在此过程中,我不仅学到了很多知识,也提高了自己解决问题的能力,尤其是学会如何从大量的信息中筛选出所需有用的信息,同时我更加深刻的体会到了,虽然书本上的大部分知识都是有价值,正确的,但实际上每个人编程的思路和对数据处理的方法、思想都是不同的,这就要求我们一定要通过实践才能找到解决问题的方案。在此次毕业设计活动中,我不断的提高了自己,也得到了宝贵的经验,我相信这些对我以后的发展都会有很大帮助。

通过这次养老服务系统的开发,我参考了很多相关系统的例子,取长补短,吸取了其他系统的长处,逐步对该系统进行了完善,但是该系统还是有很多的不足之处,有待以后进一步学习。

实践证明,养老服务系统有着非常好的发展前景,经过测试运行,系统各项功能都十分完善,界面漂亮,使用方便,操作容易,在技术理论上已经成熟。

致 谢

毕业设计结束的同时也意味着四年的大学生活就要结束了。养老服务系统的完成以及如何在系统运行过程中实现的更好,这其中付出了很大的努力,这段时光将会终身难忘。 

在毕业设计的这一段时间里,离不开导师的细心指导,还有同学们的热情帮助,有时候几个同学在一起讨论系统中的某个功能模块如何实现,如何实现的更好,或是问题没得到有效的解决,就会没有心思做其他的事情,让我们对学习充满了动力。

在毕业设计即将结束之时,首先要感谢我的指导老师,谢谢您在毕业设计和毕业论文中对我的指导。在您的细心指导下我才能快速的掌握系统的相关功能,在您的大力帮助下我才能将课本上的知识与自己的项目结合,真正的做到学以致用。感谢您经常牺牲自己的休息时间,利用其丰富的教学和项目经验对我进行指导。课堂上,您教会我们如何学习、教会我们新的知识,在课下,您又像朋友一样亲切,教会了我很多道理,让我意识到先做人、后做事。感谢所有教过我的老师,为我倾注了大量的心血,正是你们的谆谆教诲、严谨教学才使我能顺利的完成学业,再此向你们表示深深的感谢。感谢大学里教过我的每一位老师,真心祝福您们。

在这里还得感谢我的战友们,也就是同学们对我的大力支持及帮助。正是因为有你们的不断帮助、鼓励,熬夜通宵,不停的调试、测试程序,给我带来了极大的动力,才能最终完成网站的运行。我们在一起交流、谈论的时光,都将是我们在通往未来道路上的宝贵财富。我要深深地感谢你们!

毕业在即,在今后的工作和生活中,我会铭记师长们的教诲、同学们的帮助,继续不懈努力和追求,来报答所有支持和帮助过我的人!

最后,我要向牺牲了休息时间来对本文进行审阅,评议和参与论文答辩的各位老师表示深深的感谢。在此,衷心的谢谢您们!

参考文献

[1]Zhen L ,He X ,Zhang N , et al. Optimizing high-speed railway express system under uncertainty [J]. Computers and Operations Research, 2024, 165 106565-.

[2]陈静怡,黄美娇,吕庆华. 数字化情境下智慧养老服务生态系统的演化博弈分析 [J/OL]. 复杂系统与复杂性科学, 1-10[2024-02-20]. http://kns.cnki.net/kcms/detail/37.1402.N.20240130.1756.004.html.

[3]Kabamba M H ,Khouzam M ,Dagenais R M . Vnode: Low-Overhead Transparent Tracing of Node.js-Based Microservice Architectures [J]. Future Internet, 2023, 16 (1):

[4]李兵,朱赫. 促进养老服务系统政策一致性:理论策略和治理策略 [J]. 老龄科学研究, 2023, 11 (11): 1-14.

[5]陈琳,宋永发. 社区养老服务PPP项目收益系统动力学分析 [J]. 工程管理学报, 2023, 37 (05): 64-68.

[6]郭寒. 技术赋能养老:我国城市养老服务系统的信息化再造研究[D]. 南京邮电大学, 2023.

[7]赵斌,陈俊生. Medical Express未来医疗无人机 [J]. 包装工程, 2023, 44 (20): 463.

[8]胡芮瑞,金燕红,邹萍萍. 基于“互联网+”的乡村智慧养老服务设计研究 [J]. 工业设计, 2023, (10): 109-112.

[9]马震. 基于大数据技术的养老服务供给系统分析 [J]. 电子技术, 2023, 52 (10): 274-275.

[10]葛英刚,韩云. 智慧化背景下社区养老服务网格化管理系统建设研究 [J]. 佳木斯大学社会科学学报, 2023, 41 (05): 50-52+56.

[11]许远,杨苗. 关于适应养老产业发展的养老服务技能人才队伍建设的系统思考 [J]. 中国职业技术教育, 2023, (29): 17-27.

[12]曲敏,任昭贤,黄景勇. 面向视障老人的居家养老服务设计及住宅适老化改进研究 [J]. 家具与室内装饰, 2023, 30 (10): 18-24. DOI:10.16771/j.cn43-1247/ts.2023.10.004.

[13]系统谋划 聚力打造江城养老服务新名片 [J]. 中国民政, 2023, (16): 33.

[14]李莉. 基于物联网技术的智能养老服务系统设计 [J]. 工业控制计算机, 2023, 36 (08): 54-55+57.

[15]范传宏. 系统谋划 聚力打造养老服务新名片[N]. 中国社会报, 2023-08-04 (003).

[16]崔会巧. 基于系统动力学的医养结合养老服务供需平衡优化研究[D]. 燕山大学, 2023.

[17]Karthik G ,Debashish M ,Jagoda C , et al. Developing a MySQL Database for the Provenance of Black Tiger Prawns (Penaeus monodon). [J]. Foods (Basel, Switzerland), 2023, 12 (14):

[18]李诗卉. CAS理论视角下养老服务产业高质量发展的动力要素及系统构建 [J]. 中国商论, 2023, (11): 158-161.

[19]林闽钢. 基本养老服务体系建设应强化系统集成 [J]. 中国社会工作, 2023, (17): 12.

[20]赵率宏. 基于Node.js的ORM框架研究与实现[D]. 西南科技大学, 2023.

免费领取项目源码,请关注❤点赞收藏并私信博主,谢谢-

  • 11
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值