基于BS结构宠物领养及健康管理系统的设计与开发 毕业设计-附源码00420

 目  录

摘要

第一章 绪论

1.1 研究背景

1.2研究意义

1.3论文章节安排

第二章 系统分析

2.1 可行性分析

2.2 系统功能性分析

2.3.非功能性分析

2.4 系统用例分析

2.5系统流程分析

2.5.1 用户登录流程

2.5.2 数据删除流程

第3章 系统设计

3.1 系统架构设计

3.2 系统功能模块设计

3.2.1系统整体功能模块设计

3.2.2系统用户模块设计

3.2.3领养中心模块设计

3.3 数据库设计

3.3.1 数据库概念结构设计

3.3.2 数据库逻辑结构设计

第4章系统实现

4.1发布人功能模块

4.1.1用户注册界面

4.1.2用户登录界面

4.1.3首页界面

4.1.4 论坛动态界面

4.1.5健康知识界面

4.1.6个人中心界面

4.2领养人功能模块

4.2.1通知公告界面

4.2.2领养中心界面

4.2.3个人中心界面

4.3管理员功能模块

4.3.1系统用户界面

4.3.2动物种类管理界面

4.3.3系统管理界面

4.3.3通知公告管理界面

4.3.4资源管理界面

4.3.5交流管理界面

5系统测试

5.1 系统测试目的

5.2系统测试用例

5.3 系统测试结果

6 总结

参考文献

致谢 29

摘要

随着社会经济的发展,人们的生活水平不断提高,宠物产业逐渐兴起。越来越多的人选择领养宠物,宠物已成为人们生活中的重要组成部分。然而,宠物领养及健康管理方面的问题日益凸显。为此,本文提出并实现了一种基于BS结构宠物领养及健康管理系统。BS结构具有便捷操作、高效数据传输和跨平台性等技术优势。在宠物领养及健康管理系统中,用户只需通过浏览器即可访问系统,无需安装额外的客户端软件,大大降低了使用门槛。

本系统是采用基于Java语言的Spring Boot框架进行开发。Spring Boot是一款轻量级、简单易用的开发框架,具有很高的扩展性和灵活性。采用Spring Boot框架开发宠物领养及健康管理系统是一个理想的选择。本系统主要包括发布人、领养人和管理员这三大功能模块,实现了用户管理、领养中心管理、通知公告管理、交流管理等核心功能。研究此系统旨在为用户提供高效、便捷的宠物领养和健康管理服务。

关键词:宠物领养;健康管理;BS结构;Spring Boot 

Abstract

With the development of social economy, people's living standards are constantly improving, and the pet industry is gradually emerging. More and more people are choosing to adopt pets, which have become an important part of people's lives. However, issues related to pet adoption and health management are becoming increasingly prominent. Therefore, this article proposes and implements a pet adoption and health management system based on BS structure. The BS structure has technological advantages such as convenient operation, efficient data transmission, and cross platform capability. In the pet adoption and health management system, users only need to access the system through a browser without installing additional client software, greatly reducing the threshold for use.

This system is developed using the Spring Boot framework based on the Java language. Spring Boot is a lightweight, easy-to-use development framework with high scalability and flexibility. Developing a pet adoption and health management system using the Spring Boot framework is an ideal choice. This system mainly includes three functional modules: publisher, adopter, and administrator, achieving core functions such as user management, adoption center management, notification and announcement management, and communication management. The research on this system aims to provide users with efficient and convenient pet adoption and health management services.

Keywords Pet adoption; Health management; BS structure; Spring Boot

第一章 绪论

1.1 研究背景

随着社会发展和人们生活水平的提高,宠物已经成为越来越多家庭的重要成员。宠物的健康问题也日益受到关注,但很多宠物主人在面对宠物健康问题时往往缺乏专业的指导和建议。传统的宠物管理方式往往依赖于纸质记录或简单的电子表格,这种方式不仅效率低下,而且容易出错,无法满足现代宠物管理的需求。如何更好地领养和照顾宠物,提高宠物的生活质量,成为当下亟待解决的问题。随着信息技术的不断发展,越来越多的技术被应用于宠物行业。

BS结构(Browser/Server结构)是一种网络结构模式,客户端可以通过浏览器访问服务器上的应用程序。这种结构具有分布性强、维护方便、成本较低等优点,非常适合用于开发宠物领养及健康管理系统。通过BS结构,用户可以随时随地通过互联网访问系统,查看宠物的信息、健康状况、领养情况等,同时也可以进行领养申请、评论等操作。

1.2研究意义

随着社会的进步,人们的生活水平不断提高,宠物已经逐渐成为人们生活中的重要伙伴。然而,宠物领养和管理工作面临诸多问题,如信息不对称、宠物健康难以保证等。因此,基于BS结构的宠物领养及健康管理系统的研究具有重要意义。其研究意义主要体现在以下几个方面:

首先,可以提高宠物领养效率。通过BS结构的宠物领养及健康管理系统,可以实现宠物信息的集中管理和查询,方便想要领养宠物的人快速找到合适的宠物,提高宠物领养效率。

其次,可以促进宠物健康管理。系统可以为用户提供宠物健康知识,如宠物疾病预防和治疗知等,帮助宠物主人更好地照顾宠物,提高宠物的生活质量。

最后,有助于推动宠物产业的发展。基于BS结构的宠物领养及健康管理系统可以有效解决宠物领养和健康管理方面的问题,为宠物产业的发展提供有力支持,进一步推动我国宠物产业的繁荣。

1.3论文章节安排

论文将分层次进行编排,除去论文摘要致谢文献参考部分,正文部分主要结构如下:

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

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

第三章:系统设计,主要是对系统架构、功能结构进行设计,并对系统数据库的概念结构设计进行了分析。

第四章:系统详细设计与实现,根据系统功能的划分,分别的对系统所需要实现的前台用户功能和后台管理员功能进行了分析和说明。

第五章:系统测试,主要介绍了系统测试目的和对系统的部分功能界面进行测试并对测试结果作出总结。

第六章:总结。对整个研究工作进行了总结。

第二章 系统分析 

系统分析是开发一个项目的先决条件,通过系统分析可以很好的了解系统的主体用户的基本需求情况,同时这也是项目的开发的原因。进而对系统开发进行可行性分析,通常包括技术可行性、经济可行性等,可行性分析同时也是从项目整体角度进行的分析。然后就是对项目的具体需求进行分析,分析的手段一般都是通过用户的用例图来实现。下面是详细的介绍。

2.1 可行性分析

(1)技术可行性

B/S结构(Browser/Server结构)是一种常见的网络应用架构,具有跨平台、易维护、低成本等优点,基于B/S结构的系统在各个领域得到了广泛应用。此外,Spring Boot是一种基于Java的开源框架,具有高度的灵活性和可扩展性,适用于快速搭建Web应用程序。同时,Spring Boot与MySQL数据库也有良好的集成性,为宠物领养及健康管理系统的开发提供了有力的技术保障。因此,从技术层面分析是可行的。

(2)经济可行性

Spring Boot的自动配置功能可以根据应用程序的依赖和环境来进行自动配置,减少了大量的手动配置工作,可以降低开发成本;另外,Spring Boot的代码质量和可维护性较高,可以降低后期维护成本。因此,从经济角度分析是可行的。

  1. 操作可行性

系统采用B/S架构,用户只需要通过浏览器即可访问系统,无需安装额外的软件。同时,系统的操作界面简洁明了,易于理解和使用,用户无需具备专业的计算机知识即可进行操作。因此,从操作角度分析是可行的。

(4)社会可行性

随着社会的发展,越来越多的人开始养宠物,对宠物领养和健康管理系统的需求也在不断增加。同时一些地方政府可能会提供政策支持,鼓励开发这样的系统,以提高社会的宠物管理和服务水平。因此,从社会角度分析是可行的。

2.2 系统功能性分析

按照基于BS结构宠物领养及健康管理系统的角色,主要包括发布人、领养人和管理员这三大功能模块,各模块功能内容如下:

  1. 发布人功能
  1. 注册登录:新用户可以通过注册成为系统用户,注册后可以使用账号密码登录。
  2. 首页:用户可以查看首页展示的轮播图、健康知识等信息。
  3. 论坛动态:用户可以发布论坛内容,可以查看论坛动态列表中某个论坛的详情并可以进行点赞、收藏和评论。
  4. 通知公告:用户可以查看系统发布的网站公告、关于我们、联系方式、网站介绍等信息。
  5. 健康知识:用户可以查看健康知识列表中某个知识的详细信息并可以点赞、收藏和评论。
  6. 私信中心:用户可以添加好友进行私信聊天。
  7. 领养中心:用户可以查看领养中心列表中某个动物信息的详情并可以收藏和评论。
  8. 我的:用户点击我的头像的下拉按钮“我的账户”进入页面可以修改密码和个人资料;点击“个人中心”进入页面可以查看和管理个人中心中的个人首页、领养中心、领养申请、领养记录、评价记录、动态论坛和收藏信息;点击“退出”即可退出系统的登录。
  1. 领养人功能
  1. 注册登录:新用户可以通过注册成为系统用户,注册后可以使用账号密码登录。
  2. 首页:用户可以查看首页展示的轮播图、健康知识等信息。
  3. 论坛动态:用户可以发布论坛内容,可以查看论坛动态列表中某个论坛的详情并可以进行点赞、收藏和评论。
  4. 通知公告:用户可以查看系统发布的网站公告、关于我们、联系方式、网站介绍等信息。
  5. 健康知识:用户可以查看健康知识列表中某个知识的详细信息并可以点赞、收藏和评论。
  6. 私信中心:用户可以添加好友进行私信聊天。
  7. 领养中心:用户可以查看领养中心列表中某个动物信息的详情并可以申请领养、收藏和评论。
  8. 我的:用户点击我的头像的下拉按钮“我的账户”进入页面可以修改密码和个人资料;点击“个人中心”进入页面可以查看和管理个人中心中的个人首页、领养申请、领养记录、评价记录、动态论坛和收藏信息;点击“退出”即可退出系统的登录。
  1. 管理员功能
  1. 后台首页:管理员可以查看后台首页展示的相关信息。
  2. 系统用户:管理员可以查看系统用户(管理员、发布人、领养人)列表中某个用户的详情,可以对用户信息进行增删改查操作。
  3. 领养中心管理:管理员可以查看领养中心列表中某个动物的详情和评论,可以对领养中心信息进行增删改查操作。
  4. 动物种类管理:管理员可以查看动物种类列表中某个种类的详情,可以对动物种类信息进行增删改查操作。
  5. 领养申请管理:管理员可以查看领养申请列表中某个用户的领养申请详情,可以对领养申请信息进行查询、重置和删除操作。
  6. 领养记录管理:管理员可以查看领养记录列表中某个动物的领养记录详情和评论,可以对领养记录信息进行查询、重置和删除操作。
  7. 评价记录管理:管理员可以查看评价记录列表中某个评价记录详情,可以对评价记录信息进行查询、重置和删除操作。
  8. 系统管理:在系统管理界面,管理员对轮播图进行管控,可以对轮播图信息进行增删改查操作。
  9. 通知公告管理:管理员可以查看所有通知公告信息,可以对通知公告信息进行增删改查操作。
  10. 资源管理:在“资源管理”菜单管理员对健康知识和分类列表信息进行管控,可以对健康知识、分类列表信息进行增删改查操作。
  11. 交流管理:在“交流管理”菜单管理员对动态论坛和论坛分类信息进行管控,可以对动态论坛、论坛分类信息进行增删改查操作。

2.3.非功能性分析

基于BS结构宠物领养及健康管理系统的非功能性需求比如系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:

3-1基于BS结构宠物领养及健康管理系统非功能需求表

安全性

主要指基于BS结构宠物领养及健康管理系统数据库的安装,数据库的使用和密码的设定必须合乎规范。

可靠性

可靠性是指基于BS结构宠物领养及健康管理系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。

性能

性能是影响基于BS结构宠物领养及健康管理系统占据市场的必要条件,所以性能最好要佳才好。

可扩展性

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

易用性

用户只要跟着基于BS结构宠物领养及健康管理系统的页面展示内容进行操作,就可以了。

可维护性

基于BS结构宠物领养及健康管理系统开发的可维护性是非常重要的,经过测试,可维护性没有问题

2.4 系统用例分析

通过2.2功能的分析,得出了本系统的用例图:

发布人用例图如下图2-1所示。

图2-1 发布人用例图

领养人用例图如下图2-2所示。

图2-2 领养人用例图

管理员用例图如下图2-3所示。

图2-3 管理员用例图

2.5系统流程分析

系统流程是用一些特定的符合和线条来进行演示用户在使用系统时的过程,在进行系统分析的时候,业务流程可以帮助开发人员更好的理解业务,发现错误,完善系统。

2.5.1 用户登录流程

用户通过登录才能访问系统及权限以内的功能,对此将实现各种应用及管理等功能,用户登录流程图如下图2-4所示。

图2-4  用户登录流程图

2.5.2 数据删除流程

如果系统里面存在一些没有用的数据,相关的管理人员还可以对这些数据进行删除,数据删除时流程图如下图2-5所示。

图2-5  数据删除流程图

  1. 系统设计

本章主要讨论的内容包括基于BS结构宠物领养及健康管理系统的架构设计、功能模块设计、数据库系统设计。

3.1 系统架构设计

本系统从架构上分为三层:表现层(UI)、业务逻辑层(BLL)以及数据层(DL)。

图3-1系统架构设计图

表现层(UI):又称UI层,主要完成本系统的UI交互功能,一个良好的UI可以打打提高用户的用户体验,增强用户使用本系统时的舒适度。UI的界面设计也要适应不同版本的系统以及不同尺寸的分辨率,以做到良好的兼容性。UI交互功能要求合理,用户进行交互操作时必须要得到与之相符的交互结果,这就要求表现层要与业务逻辑层进行良好的对接。

业务逻辑层(BLL):主要完成本系统的数据处理功能。用户从表现层传输过来的数据经过业务逻辑层进行处理交付给数据层,系统从数据层读取的数据经过业务逻辑层进行处理交付给表现层。

数据层(DL):由于本系统的数据是放在服务端的MySQL数据库中,因此本属于服务层的部分可以直接整合在业务逻辑层中,所以数据层中只有数据库,其主要完成本系统的数据存储和管理功能。

3.2 系统功能模块设计

3.2.1系统整体功能模块设计

在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本基于BS结构宠物领养及健康管理系统中的用例。根据前面章节的需求分析得出系统的整体功能结构,其总体设计模块图如下图3-2所示。

图3-2 系统功能结构图

3.2.2系统用户模块设计

系统用户模块是系统中一个重要的功能模块,它涉及用户的注册、登录、个人信息管理等操作。在用户模块设计中,我们将定义用户数据的结构和属性,包括用户名、密码、邮箱等。同时,还需要实现用户注册、登录、修改密码等功能,并对用户输入进行验证和处理。用户模块的结构图如下图3-3所示:

图3-3 系统用户模块结构图

3.2.3领养中心模块设计

领养中心模块是本系统中的重要功能之一。该模块的设计旨在提供对待领养的动物信息的发布、编辑、删除和查看等管理功能,以便及时、准确地向系统用户发布相关的动物信息。其模块功能结构图如下图3-4所示:

图3-4 领养中心模块结构图

3.3 数据库设计

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

3.3.1 数据库概念结构设计

下面是整个基于BS结构宠物领养及健康管理系统中主要的数据库表总E-R实体关系图。

图3-5 系统总E-R关系图

3.3.2 数据库逻辑结构设计

通过上一小节中基于BS结构宠物领养及健康管理系统中总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

用户编号:

表adoption_application (领养申请)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

adoption_application_id

int

10

0

N

Y

领养申请ID

2

adoption_number

varchar

64

0

Y

N

领养编号

3

animal_names

varchar

64

0

Y

N

动物名称

4

animal_species

varchar

64

0

Y

N

动物种类

5

animal_cover

varchar

255

0

Y

N

动物封面

6

animal_gender

varchar

64

0

Y

N

动物性别

7

vaccine_situation

varchar

64

0

Y

N

疫苗情况

8

personality_description

varchar

64

0

Y

N

性格简述

9

publisher

int

10

0

Y

N

0

发布人

10

name_of_publisher

varchar

64

0

Y

N

发布人姓名

11

publishers_mobile_phone

varchar

16

0

Y

N

发布人手机

12

application_date

date

10

0

Y

N

申请日期

13

adoptive_person

int

10

0

Y

N

0

领养人

14

name_of_adoptive_person

varchar

64

0

Y

N

领养人姓名

15

adopters_mobile_phone

varchar

16

0

Y

N

领养人手机

16

reason_for_adoption

text

65535

0

Y

N

领养原因

17

examine_state

varchar

16

0

N

N

未审核

审核状态

18

examine_reply

varchar

16

0

Y

N

审核回复

19

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

20

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表adoption_center (领养中心)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

adoption_center_id

int

10

0

N

Y

领养中心ID

2

animal_names

varchar

64

0

Y

N

动物名称

3

animal_species

varchar

64

0

Y

N

动物种类

4

animal_cover

varchar

255

0

Y

N

动物封面

5

animal_gender

varchar

64

0

Y

N

动物性别

6

vaccine_situation

varchar

64

0

Y

N

疫苗情况

7

personality_description

varchar

64

0

Y

N

性格简述

8

animal_details

longtext

2147483647

0

Y

N

动物详情

9

publisher

int

10

0

Y

N

0

发布人

10

name_of_publisher

varchar

64

0

Y

N

发布人姓名

11

publishers_mobile_phone

varchar

16

0

Y

N

发布人手机

12

hits

int

10

0

N

N

0

点击数

13

recommend

int

10

0

N

N

0

智能推荐

14

location_address

varchar

64

0

Y

N

当前位置

15

location_lng

varchar

64

0

Y

N

当前位置经度

16

location_lat

varchar

64

0

Y

N

当前位置纬度

17

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

18

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表adoption_records (领养记录)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

adoption_records_id

int

10

0

N

Y

领养记录ID

2

adoption_number

varchar

64

0

N

N

领养编号

3

animal_names

varchar

64

0

Y

N

动物名称

4

animal_species

varchar

64

0

Y

N

动物种类

5

animal_cover

varchar

255

0

Y

N

动物封面

6

animal_gender

varchar

64

0

Y

N

动物性别

7

vaccine_situation

varchar

64

0

Y

N

疫苗情况

8

personality_description

varchar

64

0

Y

N

性格简述

9

publisher

int

10

0

Y

N

0

发布人

10

name_of_publisher

varchar

64

0

Y

N

发布人姓名

11

publishers_mobile_phone

varchar

16

0

Y

N

发布人手机

12

adoptive_person

int

10

0

Y

N

0

领养人

13

name_of_adoptive_person

varchar

64

0

Y

N

领养人姓名

14

adopters_mobile_phone

varchar

16

0

Y

N

领养人手机

15

adoption_date

date

10

0

Y

N

领养日期

16

publisher_review

text

65535

0

Y

N

发布者评价

17

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

18

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表adoptive_person (领养人)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

adoptive_person_id

int

10

0

N

Y

领养人ID

2

name_of_adoptive_person

varchar

64

0

Y

N

领养人姓名

3

adopters_mobile_phone

varchar

16

0

Y

N

领养人手机

4

examine_state

varchar

16

0

N

N

已通过

审核状态

5

user_id

int

10

0

N

N

0

用户ID

6

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

7

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表animal_species (动物种类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

animal_species_id

int

10

0

N

Y

动物种类ID

2

animal_species

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

更新时间

表article (文章:用于内容管理系统的文章)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

article_id

mediumint

8

0

N

Y

文章id:[0,8388607]

2

title

varchar

125

0

N

Y

标题:[0,125]用于文章和html的title标签中

3

type

varchar

64

0

N

N

0

文章分类:[0,1000]用来搜索指定类型的文章

4

hits

int

10

0

N

N

0

点击数:[0,1000000000]访问这篇文章的人次

5

praise_len

int

10

0

N

N

0

点赞数

6

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

7

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

8

source

varchar

255

0

Y

N

来源:[0,255]文章的出处

9

url

varchar

255

0

Y

N

来源地址:[0,255]用于跳转到发布该文章的网站

10

tag

varchar

255

0

Y

N

标签:[0,255]用于标注文章所属相关内容,多个标签用空格隔开

11

content

longtext

2147483647

0

Y

N

正文:文章的主体内容

12

img

varchar

255

0

Y

N

封面图

13

description

text

65535

0

Y

N

文章描述

表article_type (文章分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

type_id

smallint

5

0

N

Y

分类ID:[0,10000]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]决定分类显示的先后顺序

3

name

varchar

16

0

N

N

分类名称:[2,16]

4

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

5

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

6

icon

text

65535

0

Y

N

分类图标:

7

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表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

更新时间:

表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:

表evaluation_records (评价记录)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

evaluation_records_id

int

10

0

N

Y

评价记录ID

2

adoption_number

varchar

64

0

N

N

领养编号

3

animal_names

varchar

64

0

Y

N

动物名称

4

animal_species

varchar

64

0

Y

N

动物种类

5

animal_cover

varchar

255

0

Y

N

动物封面

6

animal_gender

varchar

64

0

Y

N

动物性别

7

vaccine_situation

varchar

64

0

Y

N

疫苗情况

8

personality_description

varchar

64

0

Y

N

性格简述

9

publisher

int

10

0

Y

N

0

发布人

10

name_of_publisher

varchar

64

0

Y

N

发布人姓名

11

publishers_mobile_phone

varchar

16

0

Y

N

发布人手机

12

adoptive_person

int

10

0

Y

N

0

领养人

13

name_of_adoptive_person

varchar

64

0

Y

N

领养人姓名

14

adopters_mobile_phone

varchar

16

0

Y

N

领养人手机

15

adoption_date

date

10

0

Y

N

领养日期

16

publisher_review

text

65535

0

Y

N

发布者评价

17

adopter_evaluation

text

65535

0

Y

N

领养人评价

18

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

19

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表forum (论坛)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

forum_id

mediumint

8

0

N

Y

论坛id

2

display

smallint

5

0

N

N

100

排序

3

user_id

mediumint

8

0

N

N

0

用户ID

4

nickname

varchar

16

0

Y

N

昵称:[0,16]

5

praise_len

int

10

0

Y

N

0

点赞数

6

hits

int

10

0

N

N

0

访问数

7

title

varchar

125

0

N

N

标题

8

keywords

varchar

125

0

Y

N

关键词

9

description

varchar

255

0

Y

N

描述

10

url

varchar

255

0

Y

N

来源地址

11

tag

varchar

255

0

Y

N

标签

12

img

text

65535

0

Y

N

封面图

13

content

longtext

2147483647

0

Y

N

正文

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

16

avatar

varchar

255

0

Y

N

发帖人头像:

17

type

varchar

64

0

N

N

0

论坛分类:[0,1000]用来搜索指定类型的论坛帖

表forum_type (论坛分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

type_id

smallint

5

0

N

Y

分类ID:[0,10000]

2

name

varchar

16

0

N

N

分类名称:[2,16]

3

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

4

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

5

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

6

icon

varchar

255

0

Y

N

分类图标:

7

create_time

timestamp

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

更新时间:

表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已取消

表publisher (发布人)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

publisher_id

int

10

0

N

Y

发布人ID

2

name_of_publisher

varchar

64

0

Y

N

发布人姓名

3

publishers_mobile_phone

varchar

64

0

Y

N

发布人手机

4

examine_state

varchar

16

0

N

N

已通过

审核状态

5

user_id

int

10

0

N

N

0

用户ID

6

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

7

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_chat_friend

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_chat_friend_id

int

10

0

N

Y

id

2

user_id

int

10

0

N

N

用户id

3

friend_user_id

int

10

0

N

N

用户好友id

4

friend_user_name

varchar

255

0

Y

N

好友名称

5

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

表user_chat_group

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_chat_group_id

int

10

0

N

Y

id

2

group_id

int

10

0

Y

N

群聊id

3

group_name

varchar

255

0

Y

N

群聊名称

4

user_id

int

10

0

Y

N

用户id

5

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

表user_chat_read

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_chat_read_id

varchar

255

0

N

Y

id

2

user_id

int

10

0

Y

N

接收人id

3

send_user_id

int

10

0

Y

N

发送人id

4

group_id

int

10

0

Y

N

群聊id

5

type

int

10

0

Y

N

类型1-点对点消息,2-群聊消息

6

create_time

timestamp

19

0

Y

N

CURRENT_TIMESTAMP

时间

7

message

text

65535

0

Y

N

消息

表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

更新时间:

第4章系统实现

基于BS结构宠物领养及健康管理系统的详细设计与实现主要是根据前面的需求分析和总体设计来设计页面并实现业务逻辑。主要从系统界面实现、业务逻辑实现这两部分进行介绍。

4.1发布人功能模块

4.1.1用户注册界面

用户点击首页导航栏左上方的“注册”进入注册页面填写账号、密码、确认密码、昵称、邮箱、身份等信息后点击“注册”按钮,系统会对输入的信息进行验证,验证通过后即可完成注册。其界面展示如下图4-1所示。

图4-1用户注册界面图

注册代码如下:

    /**

     * 注册

     * @param user

     * @return

     */

    @PostMapping("register")

    public Map<String, Object> signUp(@RequestBody User user) {

        // 查询用户

        Map<String, String> query = new HashMap<>();

        Map<String,Object> map = JSON.parseObject(JSON.toJSONString(user));

        query.put("username",user.getUsername());

        List list = service.selectBaseList(service.select(query, new HashMap<>()));

        if (list.size()>0){

            return error(30000, "用户已存在");

        }

        map.put("password",service.encryption(String.valueOf(map.get("password"))));

        service.insert(map);

        return success(1);

}   

4.1.2用户登录界面

用户注册后通过后可以通过自己的账户名和密码进行登录,用户点击首页导航栏右上方的“登录”进入页面填写用户名和密码信息后点击“立即登录”,系统会对输入的信息进行验证,验证通过后即可完成登录。其界面如下图4-2所示。

图4-2用户登录界面图

登录的代码如下:

 /**

     * 登录

     * @param data

     * @param httpServletRequest

     * @return

     */

    @PostMapping("login")

    public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {

        log.info("[执行登录接口]");

        String username = data.get("username");

        String email = data.get("email");

        String phone = data.get("phone");

        String password = data.get("password");

        List resultList = null;

        Map<String, String> map = new HashMap<>();

        if(username != null && "".equals(username) == false){

            map.put("username", username);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(email != null && "".equals(email) == false){

            map.put("email", email);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(phone != null && "".equals(phone) == false){

            map.put("phone", phone);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }else{

            return error(30000, "账号或密码不能为空");

        }

        if (resultList == null || password == null) {

            return error(30000, "账号或密码不能为空");

        }

        //判断是否有这个用户

        if (resultList.size()<=0){

            return error(30000,"用户不存在");

        }

        User byUsername = (User) resultList.get(0);

        Map<String, String> groupMap = new HashMap<>();

        groupMap.put("name",byUsername.getUserGroup());

        List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));

        if (groupList.size()<1){

            return error(30000,"用户组不存在");

        }

        UserGroup userGroup = (UserGroup) groupList.get(0);

        //查询用户审核状态

        if (!StringUtils.isEmpty(userGroup.getSourceTable())){

            String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());

            if (res==null){

                return error(30000,"用户不存在");

            }

            if (!res.equals("已通过")){

                return error(30000,"该用户审核未通过");

            }

        }

        //查询用户状态

        if (byUsername.getState()!=1){

            return error(30000,"用户非可用状态,不能登录");

        }

        String md5password = service.encryption(password);

        if (byUsername.getPassword().equals(md5password)) {

            // 存储Token到数据库

            AccessToken accessToken = new AccessToken();

            accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));

            accessToken.setUser_id(byUsername.getUserId());

            Duration duration = Duration.ofSeconds(7200L);

            redisTemplate.opsForValue().set(accessToken.getToken(), accessToken,duration);

            // 返回用户信息

            JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));

            user.put("token", accessToken.getToken());

            JSONObject ret = new JSONObject();

            ret.put("obj",user);

            return success(ret);

        } else {

            return error(30000, "账号或密码不正确");

        }

}

4.1.3首页界面

首页界面是用户访问系统的入口页面,系统首页以上中下的布局进行展示。用户可以查看首页展示的轮播图、健康知识等信息。其界面展示如下图4-3所示。

图4-3 首页界面图

4.1.4 论坛动态界面

用户可以查看论坛动态列表中某个论坛的详情并可以进行点赞、收藏和评论;点击“发布内容”进入页面填写标题、分类、正文等信息后点击“发表内容”即可完成论坛的发布。其界面如下图4-4所示。

图4-4 论坛动态界面图

4.1.5健康知识界面

用户可以查看健康知识列表中某个知识的详细信息并可以点赞、收藏和评论。支持通过关键字搜索、局部搜索等方式搜索查看健康知识。其界面如下图4-5所示。

图4-5 健康知识界面图

4.1.6个人中心界面

用户点击我的头像的下拉菜单“个人中心”进入页面可以查看和管理个人首页、领养中心、领养申请、领养记录、评价记录、动态论坛和收藏信息。点击“领养申请”进入页面可以查看列表中某个用户的领养申请详情并进行审核和回复,审核通过后点击“同意”进入页面可以向领养用户发送领养日期和评价信息;可以对领养中心信息进行增删改查操作;可以查询、重置和删除领养申请、动态论坛信息;可以查询和重置领养记录、评价记录;可以查看或删除收藏列表信息。其界面如下图4-6所示。

图4-6 个人中心界面图

4.2领养人功能模块

4.2.1通知公告界面

用户可以查看系统发布的网站公告、关于我们、联系方式、网站介绍等信息。点击网站公告进入页面可以查看该公告的详细信息。其界面如下图4-7所示。

图4-7 通知公告界面图

4.2.2领养中心界面

用户可以查看领养中心列表中某个动物信息的详情并可以申请领养、收藏和评论。点击详情下方的“申请领养”进入页面填写申请日期、领养原因等信息后点击“提交”即可完成申领领养信息的提交。支持通过关键字搜索、下拉搜索方式搜索查看宠物信息,同时支持定位地图功能。其界面如下图4-8所示。

图4-8 领养中心界面图

4.2.3个人中心界面

用户点击我的头像的下拉菜单“个人中心”进入页面可以查看和管理个人首页、领养申请、领养记录、评价记录、动态论坛和收藏信息。点击“领养记录”进入页面可以查看列表中某个领养记录的详情和发布领养评价信息;可以查询、重置和删除领养申请、动态论坛信息;可以查询和重置领养记录、评价记录;可以查看或删除收藏列表信息。其界面如下图4-9所示。

图4-9 个人中心界面图

4.3管理员功能模块

4.3.1系统用户界面

管理员可以查看系统用户(管理员、发布人、领养人)列表中某个用户的详情,可以对用户信息进行查询、重置、添加或删除操作。其界面如下图4-10所示:

4-10 系统用户界面图

添加的代码如下:

   @PostMapping("/add")

    @Transactional

    public Map<String, Object> add(HttpServletRequest request) throws IOException {

        service.insert(service.readBody(request.getReader()));

        return success(1);

    }

public Map<String, Object> addMap(Map<String,Object> map){

    service.insert(map);

     return success(1);

 }

4.3.2动物种类管理界面

管理员可以添加动物种类信息,可以对已有的动物种类信息进行查询、重置和删除操作。其界面如下图4-11所示:

4-11 动物种类管理界面图

删除的代码如下:

  @RequestMapping(value = "/del")

    @Transactional

    public Map<String, Object> del(HttpServletRequest request) {

        service.delete(service.readQuery(request), service.readConfig(request));

        return success(1);

    }

    @Transactional

    public void delete(Map<String,String> query,Map<String,String> config){

        QueryWrapper wrapper = new QueryWrapper<E>();

        toWhereWrapper(query, "0".equals(config.get(FindConfig.GROUP_BY)),wrapper);

        baseMapper.delete(wrapper);

        log.info("[{}] - 删除操作:{}",wrapper.getSqlSelect());

    }

4.3.3系统管理界面

在系统管理界面,管理员可以查看所有轮播图信息,可以添加新的轮播图信息,对已有的轮播图信息可以进行查询、重置和删除操作。其界面如下图4-12所示:

4-12 系统管理界面图

图片上传的代码如下:

 @PostMapping("/upload")

    public Map<String, Object> upload(@RequestParam("file") MultipartFile file) {

        log.info("进入方法");

        if (file.isEmpty()) {

            return error(30000, "没有选择文件");

        }

        try {

            String filePath = System.getProperty("user.dir") + "/src/main/resources/static/";

            File targetDir = new File(filePath);

            if (!targetDir.exists() && !targetDir.isDirectory()) {

                if (targetDir.mkdirs()) {

                    log.info("创建目录成功");

                } else {

                    log.error("创建目录失败");

                }

            }

            String fileName = file.getOriginalFilename();

            File dest = new File(filePath + fileName);

            log.info("文件路径:{}", dest.getPath());

            log.info("文件名:{}", dest.getName());

            file.transferTo(dest);

            JSONObject jsonObject = new JSONObject();

            jsonObject.put("url", "/api/upload/" + fileName);

            return success(jsonObject);

        } catch (IOException e) {

            log.info("上传失败:{}", e.getMessage());

        }

        return error(30000, "上传失败");

    }

4.3.3通知公告管理界面

通知公告管理界面是管理员用来管理系统中的通知公告的界面。管理员可以通过该界面进行通知公告的创建、编辑、发布和删除等操作,以便向用户传达各种重要信息、公告、更新或事件等内容。其界面如下图4-13所示:

4-13 通知公告管理界面图

4.3.4资源管理界面

在“资源管理”菜单管理员对健康知识和分类列表信息进行管控。管理员可以查看健康知识列表中某个知识的详情和评论,可以对健康知识、分类列表信息进行查询、重置、添加和删除操作。其界面如下图4-14所示:

4-14 系统管理界面图

4.3.5交流管理界面

在“交流管理”菜单管理员对动态论坛和论坛分类信息进行管控。管理员可以查看动态论坛列表中某个论坛的详情和评论,可以对动态论坛、论坛分类信息进行查询、重置、添加和删除操作。其界面如下图4-15所示:

4-15 交流管理界面图

5系统测试

5.1 系统测试目的

无论什么样的系统,测试都至关重要,通过测试可以检查出潜藏的缺陷,从而确保系统的性能和稳定性,避免Bug的出现,并确保系统的功能和性价比达到预期的要求。

5.2系统测试用例

系统测试包括:用户登录功能测试、健康中心查看功能、动物信息添加功能、密码修改功能测试,如表5-1、5-2、5-3、5-4所示:

用户登录功能测试:

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

测试用例编号

测试描述

预期结果

实际结果

是否通过

TC001

使用正确的用户名和密码进行登录

成功登录系统,跳转到用户首页

登录成功,跳转到用户首页

通过

TC002

使用不存在的用户名进行登录

显示错误提示信息:用户名不存在

显示错误提示信息:用户名不存在

通过

TC003

使用正确的用户名和错误的密码进行登录

显示错误提示信息:密码错误

显示错误提示信息:密码错误

通过

TC004

不输入用户名和密码直接点击登录按钮

显示错误提示信息:用户名和密码不能为空

显示错误提示信息:用户名和密码不能为空

通过

健康知识查看功能测试:

表5-2 健康知识查看功能测试表

测试用例编号

测试描述

预期结果

实际结果

是否通过

TC001

打开健康知识页面,检查是否能够正确展示健康知识列表信息

健康知识列表显示正确

健康知识列表显示正确

通过

TC002

点击健康知识查看按钮,检查是否能正常打开页面

健康知识详情页面显示正确

健康知识详情页面显示正确

通过

TC003

检查健康知识搜索功能

根据关键字搜索到相关健康知识并正确展示

根据关键字搜索到相关健康知识并正确展示

通过

管理员添加动物信息界面测试:

表5-3 管理员添加动物信息界面测试表

测试用例编号

测试描述

预期结果

实际结果

是否通过

TC001

使用合法的信息添加一个新的动物信息

动物信息成功添加到系统

动物信息成功添加到系统

通过

TC002

使用已存在的动物名称添加一个动物信息

显示错误提示信息:动物名称已存在

显示错误提示信息:动物名称已存在

通过

TC003

添加动物信息时不输入必填信息

显示错误提示信息:必填字段不能为空

显示错误提示信息:必填字段不能为空

通过

TC004

使用不存在的关键字进行搜索

搜索结果为空

搜索结果为空

通过

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

测试用例编号

测试描述

预期结果

实际结果

是否通过

TC001

输入正确的原密码和新密码进行修改

密码成功修改

密码成功修改

通过

TC002

输入错误的原密码和新密码进行修改

显示错误提示信息:原密码错误

显示错误提示信息:原密码错误

通过

TC003

不输入原密码和新密码直接点击修改按钮

显示错误提示信息:密码不能为空

显示错误提示信息:密码不能为空

通过

5.3 系统测试结果

通过编写基于BS结构宠物领养及健康管理系统的测试用例,已经检测完毕用户登录功能测试、健康知识查看功能、动物信息添加功能、密码修改功能测试,通过这四大模块的测试为基于BS结构宠物领养及健康管理系统的后期推广运营提供了强力的技术支撑。

6 总结

本文描述了基于BS结构宠物领养及健康管理系统开发过程,该系统是通过采用现下比较流程的Java语言,采用Spring Boot框架进行开发,采用MySQL数据库存储和管理系统数据。在文中主要通过对系统进行可行性、功能、用例等方面进行分析,确定了本系统的具体功能,功能确定后就是对系统的设计以及功能的实现,最终完成系统的开发,对系统进行测试,确保系统运行的可靠性和稳定性。

在开发本系统的过程中我成长了很多,学习到了很多书本上没有的知识,目前系统虽然已经完成。由于自己专业知识有限,系统做的并不是十分完美,还有许多地方需要改进,比如界面布局方面,代码的编写方面,都可以进一步完善。以后本人将继续进行努力学习,对系统进行完善,同时希望此系统以后有机会能够投入到实际的使用当中,为用户提供便利的宠物领养和健康管理服务。

参考文献

[1]费天乐,刘君.宠物领养一站式服务平台可行性及运行模式研究[J].国际公关,2023,(12):170-172.

[2]陈鹏峰.浅谈中国宠物行业及其市场细分[J].中国洗涤用品工业,2023,(06):42-46.

[3]张天翼.中国宠物市场状况分析与研判[J].中国洗涤用品工业,2023,(06):52-59.

[4]王兵.中国宠物市场的发展现状及趋势分析[J].贵州畜牧兽医,2023,47(02):6-8.

[5]胡伟东.基于B/S结构的学生选课系统设计与实现[J].信息与电脑(理论版),2023,35(01):23-25.

[6]余嘉慧.宠物市场高速发展的原因及市场存在的问题分析[J].租售情报,2023,(01):101-103.

[7]赵亚洲,杨晓冬.动物领养管理系统的设计与实现[J].无线互联科技,2022,19(18):61-65+72.

[8]安琪.基于服务设计思维的城市流浪动物助养系统设计研究[D].北京化工大学,2022.

[9]叶欣若,肖松鸿,杨妍.“爱宠e+”宠物综合服务平台开发模式研究[J].电脑知识与技术,2021,17(28):79-80.

[10]张豪,朱石磊,胡建华等.基于B/S架构的校园论坛系统的设计与实现[J].电脑知识与技术,2023,19(33):32-35.

[11]韩丽萍.中国宠物市场发展的问题与对策研究[D].上海财经大学,2021.DOI:10.27296/d.cnki.gshcu.2021.000480.

[12]周粉妹,吴仁平,钱荣华,等.基于SSM的宠物领养网站设计[J].扬州职业大学学报,2021,25(01):32-35.

[13]吴文洋,刘世宇.基于B/S架构宠物领养管理系统设计[J].软件,2020,41(11):85-87.

[14]吴伶琳.基于SpringBoot的客户关系管理系统设计与实现[J].无线互联科技,2023,20(24):60-62.

[15]Liang C .School Vehicle Management System Based on JAVA Language[J].Academic Journal of Computing  Information Science,2023,6(9):

[16]Yang Y .Design and Implementation of Student Information Management System Based on Springboot[J].Advances in Computer, Signals and Systems,2022,6(6):

[17]Hejing W .Commerce Middle Office Management System Based on Springboot[J].International Journal of Advanced Network, Monitoring and Controls,2022,7(2):32-45.

[18]张文.基于SpringBoot的国有企业固定资产信息管理系统的设计与实现[D].华东师范大学,2023.

[19]任浩然,刘丹,景永强.JAVA在计算机软件开发中的应用研究[J].信息记录材料,2022,23(11):83-85.

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

致谢

首先,我要向我的论文指导老师献上最深的敬意和感谢。在整个论文创作的过程中,老师的指导是我前行道路上的明灯。他耐心地指导我,用他深厚的学识和敏锐的洞察力,提出了许多具有深远意义的建议。他的严谨治学态度、敬业务实的精神和高超的教学艺术,都为我树立了追求卓越的榜样,对我未来的人生道路和学业成就产生了深远的影响。

同时,我要向我班的同学们表达我的诚挚感谢。你们既是我的亲密战友,也是我生活中的良师。正是你们的鼓励和支持,使我在大学期间的学习和生活变得丰富多彩。我要对那些在我求学路上给予我帮助的所有老师和同学们表示衷心的感谢,是你们给了我继续前进的力量。

最后,我还要感谢我的父母,是他们用无私的爱抚养我成人,你们的养育之恩我永远不会忘记。在成长的道路上,我会不断努力,不负众望,用实际行动来回报你们对我的期望。

点赞+收藏+关注 → 私信领取本源代码、数据库

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值