首页 > 编程语言 >NodeJS“学雷锋”志愿者管理系统-计算机毕设 附源码 39269

NodeJS“学雷锋”志愿者管理系统-计算机毕设 附源码 39269

时间:2025-01-17 17:58:28浏览次数:3  
标签:毕设 学雷锋 志愿者 NodeJS 用户 源码 志愿 活动 管理系统

NodeJS“学雷锋”志愿者管理系统

目  录

摘要

1 绪论

1.1研究背景与意义

1.2开发现状

1.3论文结构与章节安排

2 “学雷锋”志愿者管理系统系统分析

2.1 可行性分析

2.1.1 技术可行性分析

2.1.2 经济可行性分析

2.1.3 操作可行性分析

2.2 系统功能分析

2.2.1 功能性分析

2.2.2 非功能性分析

2.3 系统用例分析

2.4 系统流程分析

2.4.1 数据流程

2.4.2 业务流程

2.5本章小结

3 “学雷锋”志愿者管理系统总体设计

3.1 系统功能模块设计

3.1.1整体功能模块设计

3.1.2用户模块设计

3.1.3 评论管理模块设计

3.1.4志愿活动管理模块设计

3.1.5报名管理模块设计

3.2 数据库设计

3.2.1 数据库概念结构设计

3.3.2 数据库逻辑结构设计

3.4本章小结

4 “学雷锋”志愿者管理系统详细设计与实现

4.1用户功能模块

4.1.1 前台首页界面 20

4.1.2 用户注册界面 22

4.1.3 用户登录界面 22

4.1.4志愿新闻界面 23

4.1.5志愿活动详情界面 23

4.1.6 报名界面 24

4.1.7培训活动详情界面

4.2管理员功能模块

4.2.1系统用户管理界面

4.2.2志愿活动管理界面

4.2.3活动报名管理界面

4.2.4政策文件管理界面

4.2.5留言咨询管理界面

4.2.6资源管理界面

5系统测试 30

5.1 系统测试用例 30

5.2 系统测试结果 31

结论 32

参考文献 33

   35

摘要

本课题的研究对象是“学雷锋”志愿者管理系统,该系统实现了系统用户、活动类型、志愿活动、活动报名、培训活动、政策文件、评级申请等功能。本系统在设计上,考虑到系统内容以及系统的受众群体,在系统的美工方面采用了比较正规的设计,同时也提供了友好的页面以及简单的操作,系统采用koa、Mysql,这样的组合不但利用上了在大学中所学到的知识,并且能够使系统真正的发布到互联网上,而不是一个单纯的演示系统。本系统经过测试,运行效果稳定,操作方便、快捷。在具体的应用过程中,有可能会出现一些问题,今后还会对本系统不断地进行完善、更新,使其功能更强大,应用更广泛。

关键词:NodeJS;koa;“学雷锋”志愿者管理系统 ;MySQL

Abstract

The research object of this project is the "Learn from Lei Feng" volunteer management system, which implements functions such as system users, activity types, volunteer activities, activity registration, training activities, policy documents, rating applications, etc. In the design of this system, taking into account the system content and the audience of the system, we have adopted a more formal design in the art of the system, and also provided friendly pages and simple operations. The system uses koa and MySQL. This combination not only makes use of the knowledge learned in college, but also enables the system to be truly published on the Internet, rather than a simple demonstration system. This system has been tested and runs stably, with convenient and fast operation. In the specific application process, there may be some problems, and in the future, this system will be continuously improved and updated to make its functions more powerful and its applications more widespread.

Keywords: NodeJS; Koa; "Learn from Lei Feng" volunteer management system; MySQL

1 绪论

1.1研究背景与意义

“学雷锋”志愿者管理系统着社会一些活动信息事务,平时信息管理和活动事务的具体管理都是依靠各个部门的人员反复沟通交流和核对。这种管理方式存在着许多缺点,如:效率低、另外时间一长,将产生大量的文件和数据,这对于查找、更新和管理都带来了不少的困难。

随着计算机技术的飞速发展,计算机在企业和大学管理中应用的普及,利用计算机实现活动事务的管理势在必行。利用计算机支持协会组织高效率完成活动管理的日常事务,是适应现代社会发展要求,推动大学活动事务管理走向科学化、规范化的必要条件 。

“学雷锋”志愿者管理系统系统的实现可以让减轻比较繁琐的手工活动管理,让人力资源管理人员从繁重琐碎的案头工作和频繁低效的部门组织交流中解脱出来,去完成更重要的工作。它具有手工管理所无法比拟的优点,比如信息流通到位及时、组织管理责任明确、文件查找方便、档案处理可靠性高、存储量大、寿命长等。这些都可以让我们更加针对性、便捷性地科学进行活动信息事务的管理,极大地提高活动效率,更好地为热心的志愿者提供信息支持而和活动平台,同时也为社会志愿者活动的发展奠定了一个坚实的基础,所有这些都将大大提升活动效果和积极地影响志愿者们的价值观念,为培养是三能人才添砖加瓦。

1.2开发现状

国内的志愿者服务平台体系结构对中国而言最主要的一块就是能够随时得到政府的支持,所以就主要的志愿者协会中必然有一个部门是与政府直接相关的,可以很快的领略政府的精神和含义,在此基础上件起起了志愿者管理组织的其他部门,例如:社区义工联以及共青团学生信息,这种小型的社区网站体系结构主要是建立在了上述的部门上,而其自身又衍生去了很多管理部门,其主要的组成是由志愿者、志愿者直接管理者、志愿者协会管理专员、以及志愿者协会的团支部来组成的。所以大学生志愿者是这个系统架构的主要成员。而这些志愿者又被分为在职志愿者以及临时志愿者,在职志愿者主要从事的是一些全职的工作由他们负责管理整个学生信息,而临时志愿者则是来自于社会各界人士,他们平时都有自己的工作,而在空暇之余来参加活动信息。

西方国家的志愿者的服务管理工作早已经有了完善的制度,活动信息本身已经成为了西方社会制度化、专业化的社会工作了。所以从以上的叙述可以看出,这样的结果不仅是因为许多西方国家的志愿服务活动起步早且规模大,更大的原因则是政府管理措施严谨,所以让活动信息产生了极高的社会效益。当然,现在国内也在政府的管理下慢慢的开始步入组织化、规范化和系统化的道路,政府已经意识到志愿者的服务活动不仅仅是国家进行公民的道德教育的机会,更是一种维护社会稳定的无形力量和有力措施,现在国内建立学生信息的目标就是为了对志愿者服务的管理形成一套很是完整的运作机制。

1.3论文结构与章节安排

本文共分为六章,章节内容安排如下:

第一章为引言,此章节对所设计和实现的系统的研究背景和意义进行详细的论述以及说明,同时进行了论文整体框架的结构的简要介绍。

第二章为系统需求分析,章节所做的主要的工作是对系统进行了技术、经济和操作方面可行性的分析;对系统实行了总体功能的需求、用例分析。

第三章为系统的设计,主要是对系统的功能结构进行设计,并对系统数据库的概念结构以及物理结构的设计进行了分析。

第四章就是对系统的实现,根据系统功能的划分,分别的对系统所需要实现的前台客户功能和后台管理员功能进行了分析和说明。

第五章:系统测试。主要对系统的部分界面进行测试并对主要功能进行测试

第六章:总结。

2 “学雷锋”志愿者管理系统系统分析

系统需求分析是系统开发的一个关键环节,它在系统的设计和实现上起到了一个承上启下的位置。系统需求分析是对所需要做的系统进行一个需求的挖掘,如果分析的准确可以精准的解决现实中碰到的问题。如果分析不到位会影响后期系统的实现。一个系统的优秀程度需求分析也是占据了非常大的比例,如果需求分析不到位,后面的系统设计要实现就是一个偏离导航的设计。

2.1 可行性分析

系统可行行分析是对系统对系统可行性进行一个探讨。在探讨系统的可行性上我们主要从技术上的可行性和经济上的可行性以及法律层面的可行性上进行分析,如果三个层面度通过,我们则认为系统是比较可行的。

2.1.1 技术可行性分析

“学雷锋”志愿者管理系统设计与实现是一个基于Web的交易、管理平台,我们在实现这个系统所采用的技术方案是基于NodeJS语言,koa框架,MYSQL数据库,在大学的学习中这两门课程都已经学过,而且自己也用这些技术开发过小的项目,在平时的课程设计以及作业也经常用到NodeJS和MYSQL,在技术上实现自己的自主开发是可行的。

2.1.2 经济可行性分析

从经济可行性上看项目在开发阶段需要一台开发PC,在生产阶段需要web服务器和数据库服务器。一台个人PC从经济上来看也不是太多问题,在后期的系统部署生产上来说,服务器的投入也不会过高,在经济层面上是一个比较可行的。

2.1.3 操作可行性分析

操作方面主要考虑的是用户在使用以及管理人员在管理的时候,是否简单可行,没有任何计算机基础的用户能否使用,开发的“学雷锋”志愿者管理系统在设计的时候秉承简单易学的理念,在用户进入系统后都会有固定的导航按钮,只要认字就可以操作完成,而且管理员在管理方面也只需简单的增删改查即可完成,因此在操作上也是可行的。

2.2 系统功能分析

2.2.1 功能性分析

“学雷锋”志愿者管理系统我划分为了志愿用户管理模块和管理员模块这两大部分。

志愿用户管理模块:

(1)用户注册登录:游客可以随时进入到系统中,对系统中的信息浏览,但是想要实现报名等操作,就必须有这个系统的账号,如果没有账号的话,可以注册志愿用户进行相关的操作,同时用户还可以对个人信息以及操作的信息进行管控。

(2)查看“学雷锋”志愿者管理系统的首页信息:“学雷锋”志愿者管理系统的首页信息包含了首页、通知公告、志愿新闻、留言咨询、志愿活动、培训活动、评级申请、政策文件等。

(3)通知公告:用户点击“通知公告”菜单显示管理员在后台发布的所有的通知公告信息,可以查看通知公告详情。

(4)志愿新闻:用户点击“志愿新闻”菜单显示所有的志愿新闻信息,可以按照条件进行志愿新闻的筛选或者输入关键词进行局部搜索,点击可以进入志愿新闻详细展示界面,在此界面用户可以收藏、点赞和评论。

(5)志愿活动:用户可以查看志愿活动,在查询到自己想要了解的活动的时候,可以进入查看详细的介绍,点击“报名”这一按钮以后会跳转到报名信息填写的界面,根据提示填写好报名的信息,点击“提交”以后报名就完成了,在志愿活动详情这个界面,同时支持用户对喜欢的志愿活动进行收藏、点赞、评论的功能。

(6)我的账户:当用户点击右上角“我的”这个按钮,会出现子菜单,点击“我的账户”可以对个人的资料、登录系统的密码的信息进行设置管理;

(7)政策文件:用户可以查看政策文件信息支持通过搜索关键词的方式对政策文件进行查询,在查询到自己想要了解的政策文件的时候,可以进入查看详细的介绍。

(8)评级申请:点击“评级申请”后跳转到评级申请提交界面,选择申请类型,输入申请用户、用户电话、用户姓名、志愿等级,然后点击提交评级申请就完成了。

管理员管理模块:

(1)系统用户:管理员可以对“学雷锋”志愿者管理系统中的管理员以及前台注册的游客用户进行增删改查。

(2)志愿活动管理:管理员点击“志愿活动”会显示出所有的志愿活动,支持通过活动名称或者活动编号对志愿活动进行查询,如果想要添加新的志愿活动,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条志愿活动,点击“删除”进行删除,也可以对用户提交的志愿活动评论的信息进行管控。

(3)活动报名管理:管理员点击“活动报名”会显示出所有的活动报名,支持输入活动日期或者活动地区对活动报名进行查询,同时可以选择某一条活动报名,点击“删除”进行删除;

(4)培训活动管理:管理员点击“培训活动”会显示出所有的培训活动,支持通过培训名称或者发布日期对培训活动进行查询,如果想要添加新的培训活动,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条培训活动,点击“删除”进行删除,也可以对用户提交的培训活动评论的信息进行管控。

(5)系统管理:管理员点击“系统管理”菜单可以对首页展示的轮播图进行增删改查。

(6)通知公告:管理员点击“通知公告”菜单可以查看到系统中的所有通知公告信息,对已经存在的通知公告,管理员可以修改,也可以添加新的通知公告或者删除通知公告。

(7)资源管理:管理员可以对“学雷锋”志愿者管理系统前台展示的志愿新闻以及新闻所属的分类进行管控。

2.2.2 非功能性分析

“学雷锋”志愿者管理系统的非功能性需求比如“学雷锋”志愿者管理系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:

3-1“学雷锋”志愿者管理系统非功能需求表

安全性

主要指“学雷锋”志愿者管理系统数据库的安装,数据库的使用和密码的设定必须合乎规范。

可靠性

可靠性是指“学雷锋”志愿者管理系统能够按照用户提交的指示进行操作,经过测试,可靠性90%以上。

性能

性能是影响“学雷锋”志愿者管理系统占据市场的必要条件,所以性能最好要佳才好。

可扩展性

比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。

易用性

用户只要跟着“学雷锋”志愿者管理系统的页面展示内容进行操作,就可以了。

可维护性

“学雷锋”志愿者管理系统开发的可维护性是非常重要的,经过测试,可维护性没有问题

2.3 系统用例分析

“学雷锋”志愿者管理系统的完整UML用例图分别是图2-1和图2-2。

图2-1就是志愿用户角色的用例展示。

图2-1 “学雷锋”志愿者管理系统志愿用户角色用例图

图2-2就是管理员角色的用例展示。

图2-2 “学雷锋”志愿者管理系统管理员角色用例图

2.4 系统流程分析

2.4.1 数据流程

开发“学雷锋”志愿者管理系统最主要的一个目的就是实现用户对活动的在线报名,图2-3就是系统的数据流图。

图2-3活动报名操作展开图

2.4.2 业务流程

分析完“学雷锋”志愿者管理系统的数据流,那么接下来我们来看系统的业务流程,图2-4就是业务流程图:

图2-4业务流程图

2.5本章小结

本章主要通过对“学雷锋”志愿者管理系统的可行性分析、功能需求分析、系统用例分析、系统流程分析,确定整个“学雷锋”志愿者管理系统要实现的功能。同时也为“学雷锋”志愿者管理系统的代码实现和测试提供了标准。

3 “学雷锋”志愿者管理系统总体设计

本章主要讨论的内容包括“学雷锋”志愿者管理系统的功能模块设计、数据库系统设计。

3.1 系统功能模块设计

3.1.1整体功能模块设计

在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本“学雷锋”志愿者管理系统中的用例。那么接下来就要开始对本“学雷锋”志愿者管理系统的架构、主要功能和数据库开始进行设计。“学雷锋”志愿者管理系统根据前面章节的需求分析得出,其总体设计模块图如图3-1所示。

图3-1 “学雷锋”志愿者管理系统功能模块图

3.1.2用户模块设计

本系统的用户包括管理员和用户两种用户模块的功能基本是相同的,用户比管理员多了一个注册功能,所以以用户模块的结构图为例进行分析,用户模块结构图为例进行分析,如下图:

图3-2用户模块结构图

3.1.3 评论管理模块设计

“学雷锋”志愿者管理系统是一个交流性质的公开平台,用户在平台上提交评论,增加用户之间的互动性。但是同时也为了更好的规范评论的内容,给予管理员删除不合适的评论的功能,所以需要专门设计一个评论管理模块,具体的结构图如下:

图3-3评论管理模块结构图

3.1.4志愿活动管理模块设计

“学雷锋”志愿者管理系统是中需要存储不少志愿活动信息,其模块功能结构,具体的结构图如下:

图3-4志愿活动信息模块结构图

3.1.5报名管理模块设计

“学雷锋”志愿者管理系统最重要的一个功能就是报名,其模块功能结构,具体的结构图如下:

图3-5报名信息模块结构图

3.2 数据库设计

数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。

3.2.1 数据库概念结构设计

在数据库概念模型设计的时候,一般都采用E-R实体图进行展示,在实体图中可以展示出数据库表中的所有字段名称,本“学雷锋”志愿者管理系统中的主要的数据库E-R模型图如下图所示。

图3-6志愿用户E-R关系图

图3-7 志愿活动信息E-R关系图

图3-8 培训活动信息E-R关系图

图3-9 活动报名信息E-R关系图

下面是整个“学雷锋”志愿者管理系统中主要的数据库表总E-R实体关系图。

图3-10 “学雷锋”志愿者管理系统总E-R关系图

3.3.2 数据库逻辑结构设计

通过上一小节中“学雷锋”志愿者管理系统中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。

表event_registration (活动报名)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

event_registration_id

int

10

0

N

Y

活动报名ID

2

activity_name

varchar

64

0

Y

N

活动名称

3

activity_number

varchar

64

0

Y

N

活动编号

4

activity_type

varchar

64

0

Y

N

活动类型

5

event_date

date

10

0

Y

N

活动日期

6

fields_of_operation

varchar

64

0

Y

N

活动地区

7

detailed_address

varchar

64

0

Y

N

详细地址

8

number_of_participants

int

10

0

Y

N

0

活动人数

9

registered_users

int

10

0

Y

N

0

报名用户

10

user_name

varchar

64

0

Y

N

用户姓名

11

user_phone_number

varchar

64

0

Y

N

用户电话

12

number_of_applicants

varchar

64

0

Y

N

报名人数

13

examine_state

varchar

16

0

N

N

未审核

审核状态

14

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表message (留言板)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

message_id

int

10

0

N

Y

留言板ID:

2

user_id

int

10

0

N

N

0

用户ID:

3

title

varchar

64

0

Y

N

标题:

4

content

longtext

2147483647

0

N

N

内容:

5

nickname

varchar

32

0

N

N

昵称:

6

avatar

varchar

255

0

Y

N

头像:

7

email

varchar

125

0

Y

N

留言者邮箱

8

phone

varchar

11

0

Y

N

留言者手机号码

9

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

11

reply

longtext

2147483647

0

Y

N

回复

12

reply_state

tinyint

4

0

Y

N

0

回复状态

表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

更新时间:

表policy_document (政策文件)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

policy_document_id

int

10

0

N

Y

政策文件ID

2

policy_name

varchar

64

0

Y

N

政策名称

3

release_date

date

10

0

Y

N

发布日期

4

cover_photo

varchar

255

0

Y

N

封面图片

5

policy_document

varchar

255

0

Y

N

政策文件

6

related_regulations

text

65535

0

Y

N

相关规定

7

policy_guidance

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

更新时间

表rating_application (评级申请)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

rating_application_id

int

10

0

N

Y

评级申请ID

2

applying_for_users

int

10

0

Y

N

0

申请用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

user_phone_number

varchar

64

0

Y

N

用户电话

5

volunteer_level

varchar

64

0

Y

N

志愿等级

6

evaluation_application

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

更新时间

表training_activities (培训活动)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

training_activities_id

int

10

0

N

Y

培训活动ID

2

training_name

varchar

64

0

Y

N

培训名称

3

release_date

date

10

0

Y

N

发布日期

4

cover_photo

varchar

255

0

Y

N

封面图片

5

training_videos

varchar

255

0

Y

N

培训视频

6

training_introduction

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

更新时间

表volunteer_activities (志愿活动)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

volunteer_activities_id

int

10

0

N

Y

志愿活动ID

2

activity_name

varchar

64

0

Y

N

活动名称

3

activity_number

varchar

64

0

Y

N

活动编号

4

activity_type

varchar

64

0

Y

N

活动类型

5

event_date

date

10

0

Y

N

活动日期

6

fields_of_operation

varchar

64

0

Y

N

活动地区

7

detailed_address

varchar

64

0

Y

N

详细地址

8

number_limit

int

10

0

Y

N

0

人数限制

9

number_of_participants

int

10

0

Y

N

0

活动人数

10

event_cover

varchar

255

0

Y

N

活动封面

11

event_details

text

65535

0

Y

N

活动详情

12

hits

int

10

0

N

N

0

点击数

13

praise_len

int

10

0

N

N

0

点赞数

14

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表volunteer_users (志愿用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

volunteer_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

user_phone_number

varchar

64

0

Y

N

用户电话

5

volunteer_level

varchar

64

0

Y

N

志愿等级

6

examine_state

varchar

16

0

N

N

未审核

审核状态

7

user_id

int

10

0

N

N

0

用户ID

8

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

3.4本章小结

整个“学雷锋”志愿者管理系统的需求分析主要对系统总体架构以及功能模块的设计,通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。

4 “学雷锋”志愿者管理系统详细设计与实现

“学雷锋”志愿者管理系统的详细设计与实现主要是根据前面的“学雷锋”志愿者管理系统的需求分析和“学雷锋”志愿者管理系统的总体设计来设计页面并实现业务逻辑。主要从“学雷锋”志愿者管理系统界面实现、业务逻辑实现这两部分进行介绍。

4.1用户功能模块

4.1.1 前台首页界面

当进入“学雷锋”志愿者管理系统的时候,系统以上中下的布局进行展示,首先映入眼帘的是系统的导航栏,下面是轮播图,再往下是公告信息,其主界面展示如下图4-1所示。

图4-1 前台首页界面图

4.1.2 用户注册界面

“学雷锋”志愿者管理系统的游客可以进行注册登录,当用户右上角“注册”按钮的时候,当填写上自己的账号+密码+确认密码+昵称+邮箱+手机号等后再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可注册成功。其用用户注册界面展示如下图4-2所示。

图4-2注册界面图

注册关键代码如下:

 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: "注册失败",

},

};

}

}

};

4.1.3 用户登录界面

“学雷锋”志愿者管理系统中的前台上注册后的用户是可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名+密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到“学雷锋”志愿者管理系统的首页中;否则将会提示相应错误信息,用户登录界面如下图4-3所示。

图4-3用户登录界面图

登录关键代码如下:

 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: "账户不存在"

}

};

}

};

4.1.4志愿新闻界面

用户点击“志愿新闻”菜单显示所有的志愿新闻信息,可以按照条件进行志愿新闻的筛选或者输入关键词进行局部搜索,点击可以进入志愿新闻详细展示界面,在此界面用户可以收藏、点赞和评论。界面如图4-4所示。

图4-4志愿新闻界面图

4.1.5志愿活动详情界面

当访客点击“志愿活动”后就可以看到所有的志愿活动,可以输入活动名称进行搜索查询,选择你想要了解的活动后将会进入该款活动的详情界面,可以了解到该活动的活动名称、活动编号、活动类型、活动日期、活动地区、详细地址、人数限制、活动人数等,同时可以对点击下方的“报名”、“点赞”、“收藏”进行相关操作,志愿活动详情展示界面如图4-5所示。

图4-5志愿活动详情界面图

4.1.6 报名界面

当用户在志愿活动详情界面想要进行报名,点击下方的“报名”按钮,就会跳转到报名信息填写界面,根据界面提示输入报名信息,点击“提交”按钮,报名就完成了,报名界面如下图4-6所示。

图4-6 报名界面图

4.1.7培训活动详情界面

用户可以查看培训活动详信息,在查询到自己想要了解的培训活动详的时候,可以进入查看详细的介绍,支持用户对喜欢的培训活动详进行收藏、点赞的功能。培训活动详详情界面如下图4-7所示。

图4-7培训活动详情界面图

4.2管理员功能模块

4.2.1系统用户管理界面

“学雷锋”志愿者管理系统中的管理人员在“系统用户”这一菜单是中可以对注册的游客用户以及管理员进行管控。界面如下图4-8所示。

图4-8系统用户管理界面图

用户管理关键代码如下:

Controller.prototype.add = async function(ctx) {

var result = await this.service.add(ctx.request.body, this.config);

if (this.service.error) {

return {

error: this.service.error,

};

}

return {

result,

};

};

4.2.2志愿活动管理界面

点击“志愿活动”按钮会显示自己添加的志愿活动,如果想要添加新的志愿活动,点击“添加”按钮根据提示输入志愿活动,点击“提交”后在志愿活动界面就可以显示了,如果信息有错可以对志愿活动进行更新维护,也可以直接删除某一志愿活动,还可以管理评论信息,界面如下图4-9所示。

图4-9培训活动详情界面图

志愿活动管理关键代码如下:

Controller.prototype.del = async function(ctx) {

if (!Object.keys(ctx.query).length) {

return {

code: 30000,

message: "删除条件不能为空!",

};

}

var result = await this.service.del(ctx.request.query, this.config);

if (this.service.error) {

return {

error: this.service.error,

};

}

return {

result,

};

};

4.2.3活动报名管理界面

管理员点击“活动报名”会显示出所有的活动报名信息,支持通过活动名称或者活动编号对活动报名信息进行查询,也可以选择某一条活动报名信息,点击“删除”进行删除。界面如下图4-10所示。

图4-10活动报名管理界面图

活动报名管理关键代码如下:

Service.prototype.set = async function(query, body, config) {

var sql = $.mysql.toSetSql(query, body, Object.assign({}, this.config, config || {}));

var ret = await this.run(sql);

return ret;

};

4.2.4政策文件管理界面

点击“政策文件”按钮会显示自己添加的政策文件,如果想要添加新的政策文件,点击“添加”按钮根据提示输入政策文件,点击“提交”后在政策文件界面就可以显示了,如果信息有错可以对政策文件进行更新维护,也可以直接删除某一政策文件,还可以管理评论信息。界面如下图4-11所示。

图4-11政策文件管理界面图

政策文件管理关键代码如下:

Service.prototype.get_list = async function(query, config) {

var sql = $.mysql.toGetSql(query, Object.assign({}, this.config, config || {}));

return await this.run(sql);

};

Service.prototype.get_list = async function(query, config) {

var sql = $.mysql.toGetSql(query, Object.assign({}, this.config, config || {}));

return await this.run(sql);

};

4.2.5留言咨询管理界面

志愿用户和管理员都可以查看留言咨询信息,志愿用户可以对自己提交的留言咨询进行删除,管理员可以查看留言咨询,对用户提出的问题进行回复。界面如下图4-12所示。

图4-12 留言咨询管理界面图

4.2.6资源管理界面

管理员点击“资源管理”菜单能够对其下子菜单志愿新闻和志愿新闻的分类进行增删改查。界面如下图4-13所示。

图4-13 资源管理界面图

5系统测试

5.1 系统测试用例

系统测试包括:用户登录功能测试、志愿新闻展示功能测试、志愿活动添加、志愿活动搜索、密码修改、报名功能测试,如表5-1、5-2、5-3、5-4、5-5、5-6所示:

用户登录功能测试:

表5-1 用户登录功能测试表

用例名称

用户登录系统

目的

测试用户通过正确的用户名和密码可否登录功能

前提

未登录的情况下

测试流程

1) 进入登录页面

2) 输入正确的用户名和密码

预期结果

用户名和密码正确的时候,跳转到登录成功界面,反之则显示错误信息,提示重新输入

实际结果

实际结果与预期结果一致

志愿新闻查看功能测试:

表5-2 志愿新闻查看功能测试表

用例名称

志愿新闻查看

目的

测试志愿新闻查看功能

前提

用户登录

测试流程

点击志愿新闻列表

预期结果

可以查看到所有志愿新闻信息

实际结果

实际结果与预期结果一致

管理员添加志愿活动界面测试:

表5-3 管理员添加志愿活动界面测试表

用例名称

添加志愿活动测试用例

目的

测试志愿活动添加功能

前提

用户正常登录情况下

测试流程

1)点击志愿活动,然后点击添加后并填写信息。

2)点击进行提交。

预期结果

提交以后,页面首页会显示新的志愿活动 

实际结果

实际结果与预期结果一致

志愿活动搜索功能测试:

表5-4志愿活动搜索功能测试表

用例名称

志愿活动搜索测试

目的

测试志愿活动搜索功能

前提

测试流程

1)在搜索框填入搜索关键字。

2)点击搜索按钮。

预期结果

页面显示包含有搜索关键字的志愿活动

实际结果

实际结果与预期结果一致

密码修改搜索功能测试:

表5-5 密码修改功能测试表

用例名称

密码修改测试用例

目的

测试管理员密码修改功能

前提

管理员用户正常登录情况下

测试流程

1)管理员密码修改并完成填写。

2)点击进行提交。

预期结果

使用新的密码可以登录

实际结果

实际结果与预期结果一致

报名功能测试:

表5-6报名功能测试表

用例名称

报名测试用例

目的

测试用户报名功能

前提

用户正常登录情况下

测试流程

1)搜索查看志愿活动,点击报名。

2)填写报名信息,点击进行提交。

预期结果

报名成功

实际结果

实际结果与预期结果一致

5.2 系统测试结果

通过编写“学雷锋”志愿者管理系统的测试用例,已经检测完毕用户登录模块、志愿新闻展示模块、志愿活动添加模块、志愿活动搜索模块、密码修改模块、报名模块功能测试,通过这6大模块为“学雷锋”志愿者管理系统的后期推广运营提供了强力的技术支撑。

结论

在“学雷锋”志愿者管理系统开发之前,需要先对用户的具体需求进行分析。包括系统的可行性分析、功能需求分析以及其他需求等。在可行性分析过程中,对系统实现的技术性、经济性以及管理等方面进行了分析。总体上证明了系统实施的可行性。

本文总结了“学雷锋”志愿者管理系统实现背景和意义,然后阐述了系统的具体业务需求,并根据系统需求对系统结构以及功能模块等进行了详细地设计,将整个系统划分为多个不同的功能模块。在分析系统功能需求时,对整个系统的总体架构以及功能模块等进行了分析,并选择合适的系统开发技术完成了对各个模块的开发工作。系统开发完成之后进行了部署,同时进行了系统的测试过程,通过测试证明了系统在功能以及性能等方面都达到了预期的要求,具有较高的稳定性与可靠性。

参考文献

[1]张啸杰. 一种基于志愿者计算的边缘AI任务调度和资源管理系统[P]. 湖南省: CN116932228B, 2023-12-12.

[2]赵停停. 基于MySQL数据库技术的Web动态网页设计研究 [J]. 信息与电脑(理论版), 2023, 35 (17): 174-176.

[3]李艳杰. MySQL数据库下存储过程的综合运用研究 [J]. 现代信息科技, 2023, 7 (11): 80-82+88.

[4]蔡明月. 冬奥会高校志愿者管理问题研究 [J]. 科技传播, 2022, 14 (01): 55-57.

[5]王鑫, 志愿者管理后台系统. 山西省, 山西华晟众慧信息科技有限公司, 2022-01-01.

[6]杨涛. 基于Node.js的高并发电商购物系统设计与实现[D]. 北京邮电大学, 2021.

[7]张倩,李旭英,林华焜等. 基于Vue.js+Koa框架的APP平台设计与实现——以酒类文化交流与电子商务为例 [J]. 现代信息科技, 2021, 5 (07): 63-66+70.

[8]曾丽娟,邱毅,段涛等. 基于B/S架构医院志愿者管理系统的设计与实现 [J]. 医学信息, 2021, 34 (07): 27-30+34.

[9]鲁迎春. 遵义市图书馆文化志愿者管理存在的问题及对策思考 [J]. 遵义师范学院学报, 2020, 22 (06): 172-174+178.

[10]索灏江,徐枫. 2022年冬奥会志愿者管理问题研究 [J]. 内蒙古煤炭经济, 2020, (20): 202-203.

[11]InitLive; InitLive Donates Volunteer Management System To Aid In COVID-19 Relief [J]. Medical Letter on the CDC & FDA, 2020,

[12]InitLive; InitLive Donates Volunteer Management System To Aid In COVID-19 Relief [J]. Medical Letter on the CDC & FDA, 2020,

[13]钟德福,张良国,艾红等. 基于NodeJS的渔业资源调查数据采集系统框架重构 [J]. 渔业现代化, 2019, 46 (06): 104-109.

[14]刘振东. 威海志愿者管理系统的设计与实现[D]. 哈尔滨工业大学, 2019.

[15]徐浪. 基于Node.js的Web应用框架研究与实现[D]. 安徽工业大学, 2019.

[16]毛英杰. 基于Koa框架的停车诱导系统 [J]. 福建电脑, 2019, 35 (01): 143-144+125.

[17]朱伟健,钟初雷,周庆标. 基于人脸识别技术的医院志愿者管理系统的建立与应用 [J]. 医院管理论坛, 2018, 35 (03): 73-74.

[18]户立恒, 民政 市社区志愿者管理系统在房山启用, 刘文江 主编, 北京房山年鉴, 方志出版社, 2019, 313, 年鉴.

[19]李元. 北京市海淀区社区体育志愿者管理研究[C]// 中国体育科学学会. 第八届全国体育科学大会论文摘要汇编(一). 北京体育大学;, 2019: 2.

 谢

逝者如斯夫,不舍昼夜。转眼间,大学生活便已经接近尾声,人面对着离别与结束,总是充满着不舍与茫然,我亦如此,仍记得那年秋天,我迫不及待的提前一天到了学校,面对学校巍峨的大门,我心里充满了期待:这里,就是我新生活的起点吗?那天,阳光明媚,学校的欢迎仪式很热烈,我面对着一个个对着我微笑的同学,仿佛一缕缕阳光透过胸口照进了我心里,同时,在那天我认识可爱的室友,我们携手共同度过了这难忘的两年。如今,我望着这篇论文的致谢,不禁又要问自己:现在,我们就要说再见了吗?

感慨莫名,不知所言。遥想当初刚来学校的时候,心里总是想着工科学校会过于板正,会缺乏一些柔情,当时心里甚至有一点点排斥,但是随着我对学校的慢慢认识与了解,我才认识到了她的美丽,她的柔情,并且慢慢的喜欢上了这个校园,但是时间太快了,快到我还没有好好体会她的美丽便要离开了,但是她带给我的回忆,永远不会离开我,也许真正离开那天我的眼里会满含泪水,我不是因为难过,我只是想将她的样子映在我的泪水里,刻在我的心里。最后,感谢我的老师们,是你们教授了我们知识与做人的道理;感谢我的室友们,是你们陪伴了我如此之久;感谢每位关心与支持我的人。

少年,追风赶月莫停留,平荒尽处是春山。

请关注点赞+私信博主,免费领取项目源码

标签:毕设,学雷锋,志愿者,NodeJS,用户,源码,志愿,活动,管理系统
From: https://blog.csdn.net/ID3461074420/article/details/145129173

相关文章

  • 基于协同过滤算法的电影购票系统的设计与实现-计算机毕设 附源码 38993
    基于协同过滤算法的电影购票系统的设计与实现目录摘要1绪论1.1选题背景与意义1.2国内外研究现状1.3论文结构与章节安排2系统分析2.1可行性分析2.2系统流程分析2.2.1系统开发流程2.2.2用户登录流程2.2.3系统操作流程2.2.4添加信息流程2.2.5......
  • SSM宠物救助系统小程序-计算机毕设 附源码 39244
    SSM宠物救助系统小程序摘 要随着现在网络的快速发展,网络的应用在各行各业当中它很快融入到了许多学校的眼球之中,他们利用网络来做这个洗衣店预约的网站,随之就产生了“宠物救助系统”,这样就让用户宠物救助系统更加方便简单。对于本宠物救助系统的设计来说,它主要是采......
  • springboot大学生兼职网站系统-计算机毕设 附源码 39473
    springboot大学生兼职网站系统摘 要随着大学生就业市场的竞争日益激烈,越来越多的大学生选择通过兼职工作来提升自己的能力和经验。为了方便大学生寻找合适的兼职机会并提供雇主与求职者的匹配服务,设计了一个基于SpringBoot框架的兼职网站系统。该系统使用Java语言和Sp......
  • SpringBoot实验课程管理系统8t062(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表学生,实验老师,班级,实验室,实验室预约,课程类型,课程信息,课表信息开题报告内容一、选题背景与意义随着信息技术的快速发展和教育改革的深入,实验课程管理在教......
  • SpringBoot实训实习职业技能管理系统9621h(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表学员,教师,工作类型,招聘信息,投简信息,视频类型,实训教学,实训技能,课程名称,教师评价,部门信息,实习,学员打卡开题报告内容一、项目背景与目的随着社会的发展......
  • JSP美发信息综合服务与管理系统5hxk2(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容一、研究背景与意义随着人们生活水平的提高,越来越多的人开始注重个人形象和美容美发。传统的手工管理方式已经无法满足现代美发店的需求,因此,开发美......
  • JSP芒果分销系统s94qu--程序+源码+数据库+调试部署+开发环境
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容一、题目芒果分销系统的设计与实现二、研究背景及意义随着信息技术的飞速发展,农业与信息技术的融合已成为推动农业现代化进程的关键力量。果农及......
  • Spark 源码解析(二) 根据 SparkRpc 自己动手实践一个跨节点通信
     目录一、框架流程:二、Maven搭建Scala导入POM依赖三、根据流程进行编写1、实例 Master2、创建 RpcEnv3、创建RpcEndpoint4、生成RpcEndpointRef5、RpcEndpointRef发送消息 6、防止还没收到消息程序就结束运行7、验证一下,看看结果四、完整代码一、框架......
  • 基于php购物商城在线购物网站电商系统蛋糕网站php+mysql毕业设计课程设计毕设指导计算
    一、功能介绍php在线购物商城电商网站详细技术:HTML+CSS+JS+PHP+MYSQL系统分为用户和管理员两种身份用户功能如下:1.登陆注册2.查看商品详情、蛋糕资讯3.加入购物车、结算订单4.评价5.修改密码6.搜索蛋糕7.退出登录管理员功能如下:1.登录退出2.蛋糕管理(添加、修改和......
  • 2025毕设springboot 华南地区走失人员信息管理系统论文+源码
    系统程序文件列表开题报告内容研究背景华南地区,作为中国人口密集、流动性大的区域之一,近年来随着社会经济的快速发展,人员流动频繁,这也导致了走失人员事件的频发。无论是因认知障碍、精神健康问题还是意外迷路,每一例走失事件都牵动着无数家庭的心。然而,传统的寻找走失人员的......