计算机毕业设计原创定制(免费送源码):Node.JS+Express+MySQL Express 流浪动物救助系统

摘 要

随着互联网大趋势的到来,社会的方方面面,各行各业都在考虑利用互联网作为媒介将自己的信息更及时有效地推广出去,而其中最好的方式就是建立网络管理系统,并对其进行信息管理。由于现在网络的发达,流浪动物救助系统的资讯信息通过网络进行信息管理掀起了热潮,所以针对用户需求开发出一个流浪动物救助系统。

整个开发过程首先对软件系统进行需求分析,得出系统的主要功能。接着对系统进行总体设计和详细设计。总体设计主要包括系统功能设计、系统总体结构设计、系统数据结构设计和系统安全设计等;详细设计主要包括系统数据库访问的实现,主要功能模块的具体实现,模块实现关键代码等。最后对系统进行功能测试,并对测试结果进行分析总结,得出系统中存在的不足及需要改进的地方,为以后的系统维护提供了方便,同时也为今后开发类似系统提供了借鉴和帮助。

关键字:流浪动物救助系统,Mysql,Node.JS,Express框架

Abstract

With the arrival of the internet trend, various sectors of society are considering using the internet as a medium to promote their information more timely and effectively. The best way is to establish a network management system and manage its information. Due to the current development of the internet, the information management of stray animal rescue systems through the internet has sparked a trend. Therefore, a stray animal rescue system has been developed to meet user needs.

The entire development process starts with a requirement analysis of the software system to determine its main functions. Then proceed with the overall and detailed design of the system. The overall design mainly includes system functional design, system overall structure design, system data structure design, and system security design; The detailed design mainly includes the implementation of system database access, the specific implementation of main functional modules, and the key code for module implementation. Finally, functional testing was conducted on the system, and the test results were analyzed and summarized to identify the shortcomings and areas for improvement in the system. This provided convenience for future system maintenance and also provided reference and assistance for the development of similar systems in the future.

Keywords: stray animal rescue system, MySQL, Node.JS, Express framework

目 录

[++++摘 要++++ II](#摘 要 II)

[++++Abstract++++ III](#Abstract III)

[++++第一章 绪 论++++ 1](#第一章 绪 论 1)

[++++1.1背景及意义++++ 1](#1.1背景及意义 1)

[++++1.2国内外研究概况++++ 1](#1.2国内外研究概况 1)

[++++1.3 研究的内容++++ 1](#1.3 研究的内容 1)

[++++第二章 关键技术的研究++++ 3](#第二章 关键技术的研究 3)

[++++2.1 Express框架++++ 3](#2.1 Express框架 3)

[++++2.2 node.js主要功能++++ 3](#2.2 node.js主要功能 3)

[++++2.3 MVVM模式介绍++++ 4](#2.3 MVVM模式介绍 4)

[++++2.4 B/S体系工作原理++++ 4](#2.4 B/S体系工作原理 4)

[++++2.5 MySQL数据库++++ 5](#2.5 MySQL数据库 5)

[++++第三章 系统分析++++ 6](#第三章 系统分析 6)

[++++3.1 系统设计目标++++ 6](#3.1 系统设计目标 6)

[++++3.2 系统可行性分析++++ 6](#3.2 系统可行性分析 6)

[++++3.3 系统功能分析和描述++++ 6](#3.3 系统功能分析和描述 6)

[++++3.4系统流程分析++++ 7](#3.4系统流程分析 7)

[++++3.4.1添加信息流程++++ 7](#3.4.1添加信息流程 7)

[++++3.4.2操作流程++++ 7](#3.4.2操作流程 7)

[++++3.4.3删除信息流程++++ 8](#3.4.3删除信息流程 8)

[++++4.1 系统体系结构++++ 9](#4.1 系统体系结构 9)

[++++4.2 数据库设计原则++++ 10](#4.2 数据库设计原则 10)

[++++4.3 数据表++++ 10](#4.3 数据表 10)

[++++第五章 系统实现++++ 24](#第五章 系统实现 24)

[++++5.1用户功能模块++++ 24](#5.1用户功能模块 24)

[++++5.2管理员功能模块++++ 28](#5.2管理员功能模块 28)

[++++第六章 系统测试++++ 33](#第六章 系统测试 33)

[++++6.1测试定义及目的++++ 33](#6.1测试定义及目的 33)

[++++6.2性能测试++++ 33](#6.2性能测试 33)

[++++6.3测试模块++++ 33](#6.3测试模块 33)

[++++6.4测试结果++++ 34](#6.4测试结果 34)

[++++总 结++++ 35](#总 结 35)

[++++致 谢++++ 36](#致 谢 36)

[++++参考文献++++ 37](#参考文献 37)

第一章 绪 论

1.1背景及意义

近年来,随着经济的发展,人民的生活水平日益提高,许多的家庭开始饲养宠物,城市中的宠物数量也是随之大幅度增长。然而,在人们享受着宠物为生活所带来的乐趣的同时,一系列的安全威胁和宠物丢弃等问题也是铺天盖地地袭来。在城市宠物数量在快速增长的同时,许多的宠物由于主人的疏忽而走失,或者因为主人的某些生活原因,一些宠物在主人短暂的宠爱之后被无情的丢弃,这一系列的原因,导致城市中的流浪动物数量快速增长,给居民的安居、交通、卫生、人身安全等造成了严重的威胁。面对以上问题,虽然城市中存在着一些宠物救助机构和热心居民,时常为它们送去关怀和救助,但是庞大的流浪动物基数以及流浪位置的分散性和不确定性,导致难以管理和救助效果不佳。因此有必要建立一个流浪动物救助系统。

1.2 国内外 研究概况

流浪动物问题是一个世界性难题,无论是国内国外形式都很严峻。在国外通常采取"收容、认养"的方式来解决流浪动物问题,收容站既有地方政府办的,也有民办的。但是总的收容所数量有限,能够收容处理的流浪动物也是极少数能够被人们所发现的,大多数流浪动物依旧没有被收容甚至是发现。针对流浪动物问题,在国内,目前北京、上海等地也实行"收养、绝育、接种、认养"的方式,并且还建立了一些宠物医院。一些大学校园中也是开设了流浪动物救助的社团,用于解决学校周边的一些流浪动物问题。总的来说,无论是国内国外,对于流浪动物的处理最大问题依旧是流浪动物分散位置的信息获得以及如何有效的将爱心人士统一在一起,共同对更多的流浪动物进行专业科学的管理和救助。但并没有形成一个互通的救助平台,因此,开发一个流浪动物救助系统是有充分需求的。

1.3 研究的内容

目前许多人仍将传统的纸质工具作为信息管理的主要工具,而网络技术的应用只是起到辅助作用。在对网络工具的认知程度上,较为传统的office软件等仍是人们使用的主要工具,而相对全面且专业的信息管理软件仍没有得到大多数人的了解或认可。本选题则旨在通过标签分类管理等方式,实现流浪动物救助系统的各种功能,从而达到对流浪动物救助系统的管理。

详细内容介绍,将在以下六章中详细阐述:

第一章、绪论,介绍了研究课题选择的背景及意义、研究现状,简要介绍了本文的章节内容。

第二章、引入技术知识,通过引入关键技术进行开发,向系统中涉及直观表达的技术知识。

第三章、重点分析了系统的分析,从系统强大的供需市场出发,对系统开发的可行性,系统流程以及系统性能和功能进行了探讨。

第四章、介绍了系统的详细设计方案,包括系统结构设计和数据库设计。

第五章、系统设计的实现,通过对系统功能设计的详细说明,论证了系统的结构。

第六章、系统的整体测试,评判系统是否可以上线运行。

第二章 关键技术的研究

2.1 Express框架

Express是目前流行的基于Node.js运行环境的Web应用程序开发框架,它简洁且灵活,为Web应用程序提供了强大的功能。Express提供了一个轻量级模块,类似于jQuery(封装的工具库),它把Node.js的HTTP模块的功能封装在一个简单易用的接口中,用于扩展HTTP模块的功能,能够轻松地处理服务器的路由、响应、Cookie和HTTP请求的状态。

Express的优势:

(1)简洁的路由定义方式。

(2)简化HTTP请求参数的处理。

(3)提供中间件机制控制HTTP请求。

(4)拥有大量第三方中间件。

(5)支持多种模版引擎。

2.2 node.js主要功能

Node使用Module模块去划分不同的功能,以简化应用的开发。Modules模块有点像C++语言中的类库。每一个Node的类库都包含了十分丰富的各类函数,比如http模块就包含了和http功能相关的很多函数,可以帮助开发者很容易地对比如http,tcp/udp等进行操作,还可以很容易的创建http和tcp/udp的服务器。

要在程序中使用模块是十分方便的,只需要如下:

在这里,引入了http类库,并且对http类库的引用存放在http变量中了。这个时候,Node会在我们应用中搜索是否存在node_modules的目录,并且搜索这个目录中是否存在http的模块。如果Node.js找不到这个目录,则会到全局模块缓存中去寻找,用户可以通过相对或者绝对路径,指定模块的位置,比如:

var myModule = require('./myModule.js');

模块中包含了很多功能代码片断,在模块中的代码大部分都是私有的,意思是在模块中定义的函数方法和变量,都只能在同一个模块中被调用。当然,可以将某些方法和变量暴露到模块外,这个时候可以使用exports对象去实现。

2.3 MVVM模式介绍

MVVM是Model-View-ViewModel的简写。它本质上就是MVC 的改进版。MVVM 就是将其中的View 的状态和行为抽象化,让我们将视图 UI 和业务逻辑分开。当然这些事 ViewModel 已经帮我们做了,它可以取出 Model 的数据同时帮忙处理 View 中由于需要展示内容而涉及的业务逻辑。微软的WPF带来了新的技术体验,如Silverlight、音频视频3D动画......,这导致了软件UI层更加细节化、可定制化。同时,在技术层面,WPF也带来了 诸如Binding、Dependency Property、Routed Events、Command、DataTemplate、ControlTemplate等新特性。MVVM(Model-View-ViewModel)框架的由来便是MVP(Model-View-Presenter)模式与WPF结合的应用方式时发展演变过来的一种新型架构框架。它立足于原有MVP框架并且把WPF的新特性糅合进去,以应对客户日益复杂的需求变化。

2.4 B/S体系工作原理

B/S架构采取浏览器请求,服务器响应的工作模式。

用户可以通过浏览器去访问Internet上由Web服务器产生的文本、数据、图片、动画、视频点播和声音等信息;

而每一个Web服务器又可以通过各种方式与数据库服务器连接,大量的数据实际存放在数据库服务器中;

Web服务器上下载程序到本地来执行,在下载过程中若遇到与数据库有关的指令,由Web服务器交给数据库服务器来解释执行,并返回给Web服务器,Web服务器又返回给用户。在这种结构中,将许许多多的网连接到一块,形成一个巨大的网,即全球网。而各个企业可以在此结构的基础上建立自己的Internet。

在 B/S 模式中,用户是通过浏览器针对许多分布于网络上的服务器进行请求访问的,浏览器的请求通过服务器进行处理,并将处理结果以及相应的信息返回给浏览器,其他的数据加工、请求全部都是由Web Server完成的。通过该框架结构以及植入于操作系统内部的浏览器,该结构已经成为了当今软件应用的主流结构模式。

2.5 MySQL数据库

Mysql的语言是非结构化的,用户可以在数据上进行工作。MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL是管理内容最好的选择。并且因为Mysql的语言和结构比较简单,但是功能和存储信息量很强大,所以得到了普遍的应用。

Mysql数据库在编程过程中的作用是很广泛的,为用户进行数据查询带来了方便。Mysql数据库的应用因其灵活性强,功能强大,所以在实现某功能时只需要一小段代码,而不像其他程序需要编写大段代码。总体来说,Mysql数据库的语言相对要简洁很多。

数据流程分析主要就是数据存储的储藏室,它是在计算机上进行的,而不是现实中的储藏室。数据的存放是按固定格式,而不是无序的,其定义就是:长期有固定格式,可以共享的存储在计算机存储器上。数据库管理主要是数据存储、修改和增加以及数据表的建立。为了保证系统数据的正常运行,一些有能力的处理者可以进行管理而不需要专业的人来处理。数据表的建立,可以对数据表中的数据进行调整,数据的重新组合及重新构造,保证数据的安全性。介于数据库的功能强大等特点,本系统的开发主要应用了Mysql进行对数据的管理。

第三章 系统分析

3.1 系统设计目标

流浪动物救助系统主要是为了方便爱心人士通过合法合理途径领养宠物。也是为了更好的让管理员进行更好存储所有数据信息及快速方便的检索功能,对系统的各个模块是通过许多今天的发达系统做出合理的分析来确定考虑用户的可操作性,遵循开发的系统优化的原则,经过全面的调查和研究。

系统所要实现的功能分析,对于现在网络方便的管理,系统要实现分别实现管理员和用户的功能,根据分管工作内容不同及权限不同,管理员又可分为管理员,审核管理员,回访管理者,商品管理者,动物管理者,用户管理者。

系统主要功能如下:首页,公告栏管理,商城管理(宠物商城,分类列表,订单列表),轮播图,资源管理(新闻列表,新闻分类列表),系统用户,模块管理(动物信息,动物分类,申请管理,领养记录,回访记录,黑名单)。根据自己的需求购买商品或者领养宠物等。流浪动物救助系统的开发不仅仅是能满足用户的需求,还能提高管理员的工作效率,减少原有不必要的工作量。

3.2 系统可行性分析

系统的开发环境和配置都是可以自行安装的,系统使用Node.JS的Express开发工具,使用比较成熟的Mysql数据库进行对系统用户和管理员之间相关的数据交互,根据技术语言对数据库,结合需求进行修改维护,可以使得系统运行更具有稳定性和安全性,从而完成实现系统的开发。

(1)硬件可行性分析

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

(2)软件可行性分析

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

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

3.3 系统功能分析和描述

使用流浪动物救助系统系统的用户分管理员、普通用户两中角色的权限子模块。

管理员所能使用的功能主要有:首页,公告栏管理,商城管理(宠物商城,分类列表,订单列表),轮播图,资源管理(新闻列表,新闻分类列表),系统用户(管理员,审核管理员,回访管理者,商品管理者,动物管理者,用户管理者,普通用户)模块管理(动物信息,动物分类,申请管理,领养记录,回访记录,黑名单)等。

3.4系统流程分析

3.4.1添加信息流程

添加信息,编号系统使用自动编号模式,没有用户填写,用户添加信息输入信息,系统将自动确认的信息和数据,验证的成功是有效的信息添加到数据库,信息无效,重新输入信息。添加信息流程如图3-4所示。

图3-3 添加信息流程图

3.4.2操作流程

用户想进入系统,首先进入系统登录界面,通过正确的用户名、密码等信息,系统会检查登录信息,信息正确,然后输入相应的功能界面,提示信息错误,登录失败。系统操作流程如图3-4所示。

图3-4操作流程图

3.4.3删除信息流程

用户选择要删除的信息并单击Delete按钮。系统提示是否删除信息。如果用户想要删除信息,系统将删除信息。系统数据库删除信息。删除信息流程图如图3-5所示。

图3-5 删除信息流程图

第四章 系统设计

4.1 系统体系结构

流浪动物救助系统开发系统的结构图4-1所示:

图4-1 系统结构

模块包括管理员:首页,公告栏管理,商城管理(宠物商城,分类列表,订单列表),轮播图,资源管理(新闻列表,新闻分类列表),系统用户(管理员,审核管理员,回访管理者,商品管理者,动物管理者,用户管理者,普通用户)模块管理(动物信息,动物分类,申请管理,领养记录,回访记录,黑名单)等进行相应的操作。

登录系统结构图,如图4-2所示:

图4-2 登录结构图

这些功能可以充分满足宠物购买领养的需求。此系统功能较为全面如下图系统功能结构如图4-3所示。

图4-3系统功能结构图

4.2 数据库设计原则

每个数据库的应用它们都是和区分开的,当运行到一定的程序当中,它就会与自己相关的协议与客户端进行通讯。那么这个系统就会对使这些数据进行连接。当我们选择哪个桥段的时候,接下来就会简单的叙述这个数据库是如何来创建的。当点击完成按钮的时候就会自动在对话框内弹出数据源的名称,在进行点击下一步即可,直接在输入相对应的身份验证和登录密码。

流浪动物救助系统的数据流程:

图4-4 系统数据流程图

4.3 数据表

将数据库概念设计的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 | 用户编号: |

表address (收货地址:)

|----|-------------|-----------|-----|-----|------|----|-------------------|----------------------------------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | address_id | int | 10 | 0 | N | Y | | 收货地址: |
| 2 | name | varchar | 32 | 0 | Y | N | | 姓名: |
| 3 | phone | varchar | 13 | 0 | Y | N | | 手机: |
| 4 | postcode | varchar | 8 | 0 | Y | N | | 邮编: |
| 5 | address | varchar | 255 | 0 | N | N | | 地址: |
| 6 | user_id | mediumint | 8 | 0 | N | N | | 用户ID:[0,8388607]用户获取其他与用户相关的数据 |
| 7 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
| 8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
| 9 | default | bit | 1 | 0 | N | N | 0 | 默认判断 |

表adoption_record (领养记录)

|----|--------------------|-----------|-----|-----|------|----|-------------------|--------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | adoption_record_id | int | 10 | 0 | N | Y | | 领养记录ID |
| 2 | animal_number | varchar | 64 | 0 | Y | N | | 动物编号 |
| 3 | animal_name | varchar | 64 | 0 | Y | N | | 动物名称 |
| 4 | animal_species | varchar | 64 | 0 | Y | N | | 动物品种 |
| 5 | adoptive_user | int | 10 | 0 | Y | N | 0 | 领养用户 |
| 6 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 7 | id_number | varchar | 255 | 0 | Y | N | | 身份证号 |
| 8 | contact_number | varchar | 64 | 0 | Y | N | | 联系电话 |
| 9 | date_of_adoption | date | 10 | 0 | Y | N | | 领养日期 |
| 10 | receiving_method | varchar | 64 | 0 | Y | N | | 领取方式 |
| 11 | user_address | varchar | 64 | 0 | Y | N | | 用户地址 |
| 12 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 13 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
| 14 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |

表animal_information (动物信息)

|----|-----------------------|-----------|------------|-----|------|----|-------------------|--------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | animal_information_id | int | 10 | 0 | N | Y | | 动物信息ID |
| 2 | animal_number | varchar | 64 | 0 | N | N | | 动物编号 |
| 3 | animal_name | varchar | 64 | 0 | Y | N | | 动物名称 |
| 4 | animal_species | varchar | 64 | 0 | Y | N | | 动物品种 |
| 5 | animal_age | varchar | 64 | 0 | Y | N | | 动物年龄 |
| 6 | animal_photos | varchar | 255 | 0 | Y | N | | 动物照片 |
| 7 | animal_details | longtext | 2147483647 | 0 | Y | N | | 动物详情 |
| 8 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
| 9 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
| 10 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
| 12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |

表animal_manager (动物管理者)

|----|-------------------|-----------|----|-----|------|----|-------------------|---------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | animal_manager_id | int | 10 | 0 | N | Y | | 动物管理者ID |
| 2 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 3 | gender | varchar | 64 | 0 | Y | N | | 性别 |
| 4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
| 5 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 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 | 更新时间 |

表application_management (申请管理)

|----|---------------------------|-----------|-----|-----|------|----|-------------------|--------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | application_management_id | int | 10 | 0 | N | Y | | 申请管理ID |
| 2 | animal_number | varchar | 64 | 0 | Y | N | | 动物编号 |
| 3 | animal_name | varchar | 64 | 0 | Y | N | | 动物名称 |
| 4 | animal_species | varchar | 64 | 0 | Y | N | | 动物品种 |
| 5 | adoptive_user | int | 10 | 0 | Y | N | 0 | 领养用户 |
| 6 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 7 | contact_number | varchar | 64 | 0 | Y | N | | 联系电话 |
| 8 | id_number | varchar | 255 | 0 | Y | N | | 身份证号 |
| 9 | adoption_data | varchar | 255 | 0 | Y | N | | 领养资料 |
| 10 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
| 11 | examine_reply | varchar | 16 | 0 | Y | N | | 审核回复 |
| 12 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 13 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
| 14 | 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 | 更新时间: |

表audit_manager (审核管理者)

|----|------------------|-----------|----|-----|------|----|-------------------|---------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | audit_manager_id | int | 10 | 0 | N | Y | | 审核管理者ID |
| 2 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 3 | gender | varchar | 64 | 0 | Y | N | | 性别 |
| 4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
| 5 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 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 | 更新时间 |

表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 | 更新时间: |

表blacklist (黑名单)

|----|------------------------|-----------|----|-----|------|----|-------------------|-------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | blacklist_id | int | 10 | 0 | N | Y | | 黑名单ID |
| 2 | adoptive_user | int | 10 | 0 | Y | N | 0 | 领养用户 |
| 3 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 4 | contact_number | varchar | 64 | 0 | Y | N | | 联系电话 |
| 5 | return_visit_personnel | int | 10 | 0 | Y | N | 0 | 回访人员 |
| 6 | comment_message | varchar | 64 | 0 | Y | N | | 备注消息 |
| 7 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 8 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
| 9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |

表cart (购物车)

|----|-------------|-----------|-----|-----|------|----|-------------------|----------------------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | cart_id | int | 10 | 0 | N | Y | | 购物车ID: |
| 2 | title | varchar | 64 | 0 | Y | N | | 标题: |
| 3 | img | varchar | 255 | 0 | N | N | 0 | 图片: |
| 4 | user_id | int | 10 | 0 | N | N | 0 | 用户ID: |
| 5 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
| 6 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
| 7 | state | int | 10 | 0 | N | N | 0 | 状态:使用中,已失效 |
| 8 | price | double | 9 | 2 | N | N | 0.00 | 单价: |
| 9 | price_ago | double | 9 | 2 | N | N | 0.00 | 原价: |
| 10 | price_count | double | 11 | 2 | N | N | 0.00 | 总价: |
| 11 | num | int | 10 | 0 | N | N | 1 | 数量: |
| 12 | goods_id | mediumint | 8 | 0 | N | N | | 商品id:[0,8388607] |
| 13 | type | varchar | 64 | 0 | N | N | 未分类 | 商品分类: |
| 14 | description | varchar | 255 | 0 | Y | N | | 描述:[0,255]用于产品规格描述 |

表classification_of_animals (动物分类)

|----|------------------------------|-----------|----|-----|------|----|-------------------|--------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | classification_of_animals_id | int | 10 | 0 | N | Y | | 动物分类ID |
| 2 | animal_species | varchar | 64 | 0 | Y | N | | 动物品种 |
| 3 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 4 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
| 5 | 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: |

表commodity_manager (商品管理者)

|----|----------------------|-----------|----|-----|------|----|-------------------|---------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | commodity_manager_id | int | 10 | 0 | N | Y | | 商品管理者ID |
| 2 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 3 | gender | varchar | 64 | 0 | Y | N | | 性别 |
| 4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
| 5 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 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 | 更新时间 |

表goods (商品信息)

|----|-----------------|-----------|------------|-----|------|----|-------------------|------------------------------------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | goods_id | mediumint | 8 | 0 | N | Y | | 产品id:[0,8388607] |
| 2 | title | varchar | 125 | 0 | Y | N | | 标题:[0,125]用于产品和html的<title>标签中 |
| 3 | img | text | 65535 | 0 | Y | N | | 封面图:用于显示于产品列表页 |
| 4 | description | varchar | 255 | 0 | Y | N | | 描述:[0,255]用于产品规格描述 |
| 5 | price_ago | double | 8 | 2 | N | N | 0.00 | 原价:[1] |
| 6 | price | double | 8 | 2 | N | N | 0.00 | 卖价:[1] |
| 7 | sales | int | 10 | 0 | N | N | 0 | 销量:[0,1000000000] |
| 8 | inventory | int | 10 | 0 | N | N | 0 | 商品库存 |
| 9 | type | varchar | 64 | 0 | N | N | | 商品分类: |
| 10 | hits | int | 10 | 0 | N | N | 0 | 点击量:[0,1000000000]访问这篇产品的人次 |
| 11 | content | longtext | 2147483647 | 0 | Y | N | | 正文:产品的主体内容 |
| 12 | img_1 | text | 65535 | 0 | Y | N | | 主图1: |
| 13 | img_2 | text | 65535 | 0 | Y | N | | 主图2: |
| 14 | img_3 | text | 65535 | 0 | Y | N | | 主图3: |
| 15 | img_4 | text | 65535 | 0 | Y | N | | 主图4: |
| 16 | img_5 | text | 65535 | 0 | Y | N | | 主图5: |
| 17 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
| 18 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
| 19 | customize_field | text | 65535 | 0 | Y | N | | 自定义字段 |
| 20 | source_table | varchar | 255 | 0 | Y | N | | 来源表: |
| 21 | source_field | varchar | 255 | 0 | Y | N | | 来源字段: |
| 22 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
| 23 | user_id | int | 10 | 0 | Y | N | 0 | 添加人 |

表goods_type (商品类型)

|----|--------------|-----------|-----|-----|------|----|-------------------|--------------------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | type_id | int | 10 | 0 | N | Y | | 商品分类ID: |
| 2 | father_id | smallint | 5 | 0 | N | N | 0 | 上级分类ID:[0,32767] |
| 3 | name | varchar | 255 | 0 | Y | N | | 商品名称: |
| 4 | desc | varchar | 255 | 0 | Y | N | | 描述: |
| 5 | icon | varchar | 255 | 0 | Y | N | | 图标: |
| 6 | source_table | varchar | 255 | 0 | Y | N | | 来源表: |
| 7 | source_field | 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 | 更新时间: |

表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 | 更新时间: |

表order (订单)

|----|-----------------|-----------|-----|-----|------|----|-------------------|--------------------------------------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | order_id | int | 10 | 0 | N | Y | | 订单ID: |
| 2 | order_number | varchar | 64 | 0 | Y | N | | 订单号: |
| 3 | goods_id | mediumint | 8 | 0 | N | N | | 商品id:[0,8388607] |
| 4 | title | varchar | 32 | 0 | Y | N | | 商品标题: |
| 5 | img | varchar | 255 | 0 | Y | N | | 商品图片: |
| 6 | price | double | 10 | 2 | N | N | 0.00 | 价格: |
| 7 | price_ago | double | 10 | 2 | N | N | 0.00 | 原价: |
| 8 | num | int | 10 | 0 | N | N | 1 | 数量: |
| 9 | price_count | double | 8 | 2 | N | N | 0.00 | 总价: |
| 10 | norms | varchar | 255 | 0 | Y | N | | 规格: |
| 11 | type | varchar | 64 | 0 | N | N | 未分类 | 商品分类: |
| 12 | contact_name | varchar | 32 | 0 | Y | N | | 联系人姓名: |
| 13 | contact_email | varchar | 125 | 0 | Y | N | | 联系人邮箱: |
| 14 | contact_phone | varchar | 11 | 0 | Y | N | | 联系人手机: |
| 15 | contact_address | varchar | 255 | 0 | Y | N | | 收件地址: |
| 16 | postal_code | varchar | 9 | 0 | Y | N | | 邮政编码: |
| 17 | user_id | int | 10 | 0 | N | N | 0 | 买家ID: |
| 18 | merchant_id | mediumint | 8 | 0 | N | N | 0 | 商家ID: |
| 19 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
| 20 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
| 21 | description | varchar | 255 | 0 | Y | N | | 描述:[0,255]用于产品规格描述 |
| 22 | state | varchar | 16 | 0 | N | N | 待付款 | 订单状态:待付款,待发货,待签收,已签收,待退款,已退款,已拒绝,已完成 |

表ordinary_users (普通用户)

|----|-------------------|-----------|-----|-----|------|----|-------------------|--------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | ordinary_users_id | int | 10 | 0 | N | Y | | 普通用户ID |
| 2 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 3 | gender | varchar | 64 | 0 | Y | N | | 性别 |
| 4 | id_number | varchar | 255 | 0 | Y | N | | 身份证号 |
| 5 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
| 6 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 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 | 更新时间 |

表pet_mall (宠物商城)

|----|------------------|-----------|------------|-----|------|----|-------------------|--------------------------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | pet_mall_id | int | 10 | 0 | N | Y | | 宠物商城ID |
| 2 | specifications | varchar | 64 | 0 | Y | N | | 规格 |
| 3 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 4 | cart_title | varchar | 125 | 0 | Y | N | | 标题:[0,125]用于产品html的标签中 |
| 5 | cart_img | text | 65535 | 0 | Y | N | | 封面图:用于显示于产品列表页 |
| 6 | cart_description | varchar | 255 | 0 | Y | N | | 描述:[0,255]用于产品规格描述 |
| 7 | cart_price_ago | double | 8 | 2 | N | N | 0.00 | 原价:[1] |
| 8 | cart_price | double | 8 | 2 | N | N | 0.00 | 卖价:[1] |
| 9 | cart_inventory | int | 10 | 0 | N | N | 0 | 商品库存 |
| 10 | cart_type | varchar | 64 | 0 | N | N | 未分类 | 商品分类: |
| 11 | cart_content | longtext | 2147483647 | 0 | Y | N | | 正文:产品的主体内容 |
| 12 | cart_img_1 | text | 65535 | 0 | Y | N | | 主图1: |
| 13 | cart_img_2 | text | 65535 | 0 | Y | N | | 主图2: |
| 14 | cart_img_3 | text | 65535 | 0 | Y | N | | 主图3: |
| 15 | cart_img_4 | text | 65535 | 0 | Y | N | | 主图4: |
| 16 | cart_img_5 | text | 65535 | 0 | Y | N | | 主图5: |
| 17 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
| 18 | 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已取消 |

表return_visit_manager (回访管理者)

|----|-------------------------|-----------|----|-----|------|----|-------------------|---------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | return_visit_manager_id | int | 10 | 0 | N | Y | | 回访管理者ID |
| 2 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 3 | gender | varchar | 64 | 0 | Y | N | | 性别 |
| 4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
| 5 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 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 | 更新时间 |

表return_visit_record (回访记录)

|----|------------------------|-----------|----|-----|------|----|-------------------|--------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | return_visit_record_id | int | 10 | 0 | N | Y | | 回访记录ID |
| 2 | animal_number | varchar | 64 | 0 | Y | N | | 动物编号 |
| 3 | animal_name | varchar | 64 | 0 | Y | N | | 动物名称 |
| 4 | animal_species | varchar | 64 | 0 | Y | N | | 动物品种 |
| 5 | adoptive_user | int | 10 | 0 | Y | N | 0 | 领养用户 |
| 6 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 7 | contact_number | varchar | 64 | 0 | Y | N | | 联系电话 |
| 8 | date_of_return_visit | date | 10 | 0 | Y | N | | 回访日期 |
| 9 | animal_status | varchar | 64 | 0 | Y | N | | 动物状态 |
| 10 | return_visit_personnel | int | 10 | 0 | Y | N | 0 | 回访人员 |
| 11 | abuse_or_not | varchar | 64 | 0 | Y | N | | 是否虐待 |
| 12 | remarks | varchar | 64 | 0 | Y | N | | 备注信息 |
| 13 | recommend | 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 | 更新时间 |

表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 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |

表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 | 更新时间: |

表user_manager (用户管理者)

|----|-----------------|-----------|----|-----|------|----|-------------------|---------|
| 编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
| 1 | user_manager_id | int | 10 | 0 | N | Y | | 用户管理者ID |
| 2 | full_name | varchar | 64 | 0 | Y | N | | 姓名 |
| 3 | gender | varchar | 64 | 0 | Y | N | | 性别 |
| 4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
| 5 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
| 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 | 更新时间 |

第五章 系统实现

5.1用户功能模块

用户通过输入账号,设置密码,输入昵称,邮箱等个人信息注册账号,如图5-1所示。

图5-1用户注册界面图

用户登录后可以查看和操作首页,公告栏,新闻资讯,网上商城,个人账户,个人收藏,地址管理,购物管理,订单管理,动物信息。后台首页,申请管理,领养记录,回访记录等功能,如图5-2所示。

图5-2用户功能界面图

网上商城,用户可以查看推荐的宠物相关的商品列表,或者通过排序和筛选搜索感兴趣的宠物,如图5-4所示。

图5-3网上商城界面图

用户点击商品,可以查看商品详情,可以立即购买或者加入购物车,收藏,评论等操作,如图5-4所示。

图5-4商品详情界面图

动物信息,用户可以查看待领养的宠物列表,也可以通过搜索,排序等方式找到心仪的宠物,可以进行收藏,点赞,申请领养等操作,如图5-5,5-6所示。

图5-5动物信息界面图

图5-6宠物领养申请提交界面图

申请管理,用户在此页面可以查询领养申请的审核情况,如图5-7所示。

图5-7申请管理界面图

回访记录,用户在领养宠物后,相关管理员将进行回访和宠物状态的确认,之后将获取的信息维护至回访记录中,用户在此页面可以查询回访评价,如图5-8所示。

图5-8回访记录界面图

5.2管理员功能模块

管理员登录,通过填写用户名、密码、完成行为验证进行登录,如图5-9所示。

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

管理员根据分管工作内容不同及权限不同,管理员又可分为管理员,审核管理员,回访管理者,商品管理者,动物管理者,用户管理者。登录进入流浪动物救助系统可以查看首页,公告栏管理,商城管理(宠物商城,分类列表,订单列表),轮播图,资源管理(新闻列表,新闻分类列表),系统用户(管理员,普通用户)模块管理(动物信息,动物分类,申请管理,领养记录,回访记录,黑名单)等功能并进行操作,如图5-10所示。

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

用户管理,在此页面管理员可以添加其他实施详细分工的管理员,还进行查询,重置,删除等操作,如图5-11所示。

图5-11用户管理界面图

申请管理,在此页面审核管理员可以对用户提交的领养申请继进行审核,还可以进行查询,重置,删除,添加等操作,如图5-12,13所示。

图5-12申请管理界面图

图5-13申请审核界面图

回访记录,在此页面回访管理员可以在回访之后维护相关信息,还进行查询,重置,删除,添加等操作,如图5-14,15所示。

图5-14领养记录管理界面图

图5-15回访结果录入界面图

宠物商城,在此页面商品管理员可以管理商品信息,还进行查询,重置,删除,添加等操作,如图5-16,17所示。

图5-16商品信息管理界面图

图5-17商品添加界面图

第六章 系统测试

6.1测试定义及目的

关于系统实现的测试,英文名称是System TEST,简称ST,ST是使用完整其系统的各种功能多次、多案例、多环境测试,这是ST的简单描述。ST可以证明该功能对系统的要求是否得到满足以及是否有效。

对于系统开发的实现,不管开发过程多么努力,在系统运行的时候多少都会出现一些错误信息,所以为了系统的安全性及提高系统的使用率及给用户带来更好的体验,系统在完成之前,一定要进行一遍系统的测试,再完美的程序也会有漏洞,再细心的技术开发员也会有疏忽的时候,所以对于程序的测试是必须要做的一步。通过系统测试找到系统存在的问题,并根据问题的原因进行在线解决问题,如果找不到解决问题的办法可以进行通过咨询指导老师或者通过同学帮忙,一定将问题找出,否则将会出现更多的错误。所以程序出现错误时不可避免,系统测试虽然耗时费力,但是为了确保后期系统的长期使用,必须要进行系统测试,问题解决完成后还要再一步测试,直到没有任何问题后方可进行使用。

6.2性能测试

任何一款程序开发成功后都必须通过软件测试,它是保障软件稳定运行的前提。测试最主要的一步就是性能测试,性能测试内容如下:

(1)对于测试的速度有一定的要求,速度必须快,而且对于测试出来的错误问题一定以最快的速度进行处理解决,并且进行再次测试,保证整个系统运行的安全性。

(2)在系统测试的时候要将测试所用到的测试计划和测试报告保管好,方便后期系统的运行使用后的整体维护操作。

(3)软件测试整个过程中的聚类现象应优先考虑。

(4)对于整体系统测试,不要用自己的思想去认可整个系统,而是从公正的角度的进行对系统进行认可,是否符系统的整合应用。

6.3测试模块

测试系统是最新的Windows 10系统,通过对系统实现的功能模块进行每个功能模块的操作测试,查看每个用户的功能模块所对应的权限信息是否可以操作并且数据信息更新一致。

|--------|----------|--------|----|
| 测试需求 | 测试重点 | 是否达成需求 | 结果 |
| 用户登录 | 输入账号密码 | 需求达成 | 通过 |
| 用户注册 | 创建新的账号密码 | 需求达成 | 通过 |
| 登录失败 | 输入错误账号密码 | 需求达成 | 通过 |
| 修改信息 | 修改成功 | 需求达成 | 通过 |
| 添加信息管理 | 增删查改 | 需求达成 | 通过 |
| 留言管理 | 增删查改 | 需求达成 | 通过 |
| 回复管理 | 增删查改 | 需求达成 | 通过 |
| 搜索查询管理 | 增删查改 | 需求达成 | 通过 |

系统测试方面,我们通常运用的是白盒测试以及黑盒测试这两种方法。白盒测试是指在了解系统内部工作流程的前提下,可以根据需求规范验证系统内部操作是否能够正常运行的测试;而黑盒测试指的是,倘若知道了这个系统的全部功能,可以进行测试检测系统中的每一个功能是否满足正常使用。

为了方便用户使用"流浪动物救助系统",以及尽可能少的减少系统测试错误的发生,我们对该系统进行了相对应的测试。

对该系统的全部的功能界面进行测试,简单来说,就是我们输入一些数据并且对其进行提交,之后我们查看每个页面的反馈,检测页面的相关功能可不可以完全实现。

6.4测试结果

测试评估的结果是流浪动物救助系统满足要求中的所有功能,处理大多数错误条件,修复大多数错误并通过测试。流浪动物救助系统的基本功能都是可行的,不管是系统里面的功能还是界面的设计都是可值得推广宣传的。

总 结

流浪动物救助系统的整体功能模块的实现,主要是对自己在大学这几年时间所学内容的一个测试,对于系统,主要是通过现在智能化的流浪动物救助系统进行校园论坛,校园新闻的发布,查阅和管理。管理员根据问题信息进行科研成果信息及留言信息管理等操作,并且可以根据需求进行数据信息的增加修改删除等操作。

经过一个学期的毕业设计的实现完成已接近尾声,到目前为止,当我回想起整个学期的系统开发日,收获颇丰。毕业设计的主要任务是建立一个智能化的流浪动物救助系统的信息系统,对系统的每个功能模块进行相对应的操作,最后,系统调试结果表明系统基本可以满足功能要求。

流浪动物救助系统的开发对我大学学习的改进有很大帮助。它使我能够学习计算机知识的相关技术方面问题及与人交往的沟通交流方面,让我意识到无论我们做什么,我们都需要坚持不懈,努力工作,只有这样尝试了并且坚持去做了,我们才可以成功,才可以获得成功的喜悦,如果没有尝试,知识想,那连成功的机会都没有,实际操作进行做了,才会越来越近的靠近成功,随着道路一路向前,未来的路是美好的。

对于流浪动物救助系统的实现,是自己第一次完成的设计一个管理系统。在项目的设计过程中,我克服了各种困难,并且在面对这些困难,我积极的面对,想办法解决问题,并且更好的掌握了理论知识和动手操作实践能力,从系统的开发到设计完成,我完成了一个更全面、更完善、更安全的平台管理系统,这也让我取得了很大的成就感,也使我对未来的生活更有信心。

致 谢

时间飞快,毕业论文即时结束也意味着我大学四年的大学生活即将结束。论文写作乏味而富有挑战性,指导老师的指导,同学们的支持鼓励是我坚持完成系统设计和论文撰写的重要动力。首先,我要感谢我的导师老师在论文开篇,初稿,设计提出宝贵意见,没有老师对我的辛苦栽培,并且严格的要求,我是不可能顺利完成我的论文。在这里,我还要感谢我的妈妈和爸爸,多少感恩的话想要对你们说,我想通过我的学习成果来回报你们,永远祝你们健康幸福!最后,我要感谢所有帮助过我的老师,同学和朋友,并度过了许多快乐和难忘的日子。我希望你们永远幸福快乐。

四年的时间很难在我的漫长的人生旅程中短暂,但短短的四年是最真诚的青年;最纯粹的岁月;最美丽的大学生活。我会记住大学的每一点,记住大学里每个可爱的人。

参考文献

[1]高霞.基于uni-app+Express的亲子系统的设计与实现[J].电脑与信息技术,2023,31(02):49-52+58.DOI:10.19414/j.cnki.1005-1228.2023.02.012.

[2]. ERTC Express Is Now Helping American Businesses Maximize Their Claims for The Employee Retention Tax Credit[J]. M2 Presswire,2022.

[3]Paul Krill. Node.js trademarks move to OpenJS Foundation[J]. InfoWorld.com,2022.

[4]Matthew Tyson. A simple automated build pipeline for Node.js[J]. InfoWorld.com,2022.

[5]周雨贝. 基于Node.js框架的企业级软件包管理系统的设计与实现[D].华中科技大学,2022.DOI:10.27157/d.cnki.ghzku.2022.000069.

[6]马艳彬. 基于Node.js和Vue框架的竞赛类答题平台管理系统的设计[C]//中国新闻技术工作者联合会.中国新闻技术工作者联合会2021年学术年会论文集.中国新闻技术工作者联合会2021年学术年会论文集,2021:77-82.DOI:10.26914/c.cnkihy.2021.047236.

[7]柳海燕,郑健.基于React和Express的接待工作管理系统的设计与实现[J].电脑知识与技术,2021,17(17):10-13.DOI:10.14004/j.cnki.ckt.2021.1536.

[8]周粉妹,吴仁平,钱荣华,陈思.基于SSM的宠物领养网站设计[J].扬州职业大学学报,2021,25(01):32-35.DOI:10.15954/j.cnki.cn32-1529/g4.2021.01.009.

[9]陈荣鑫.基于NodeJS+Express框架的学院会议室预定系统设计与开发[J].信息与电脑(理论版),2021,33(02):95-97.

[10]姜苏. 基于互联网平台解决社会流浪动物问题的可行性研究[D].山东农业大学,2020.DOI:10.27277/d.cnki.gsdnu.2020.001043.

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

[12]杨芹. 宠物领养Web App的设计与实现[D].华中科技大学,2020.DOI:10.27157/d.cnki.ghzku.2020.006892.

[13]Carolina Abouzied. Research on adaptive clustering image segmentation method under big data framework[J]. Computer Informatization and Mechanical System,2020,2(5).

[14]黄云洁. 基于Node.js的商品包装管理系统的设计与实现[D].华中科技大学,2020.DOI:10.27157/d.cnki.ghzku.2020.006239.

[15]熊俊雄,陆海洪,周志文,兰伟发,朱师琳,徐元中.基于express的内容发布系统[J].电子世界,2019(11):14-16.DOI:10.19353/j.cnki.dzsj.2019.11.004.

[16]朱庆广. 基于Node.js的物流信息管理系统的研究与实现[D].北京邮电大学,2019.

[17]Grabowski Marcin,Sadecka Sabina,Cacko Andrzej,Michalak Marcin,Blicharz Leszek,Balsam Paweł,Opolski Grzegorz. Effectiveness of Medtronic CareLink Express System in identifying patients with high-energy electrotherapy devices requiring clinically significant intervention.[J]. Cardiology journal,2018,25(1).

[18]李草. 基于Node.js+Express框架的智能燃气监管系统应用研究[D].中国石油大学(北京),2018.DOI:10.27643/d.cnki.gsybu.2018.001168.

[19]杨涛. 基于Node.js的脑慢病管理系统的设计与实现[D].南京大学,2018.

[20]纪好. 流浪动物救助公益服务设计研究[D].武汉理工大学,2018.

免费领源码,麻烦一键三连,私信博主。谢谢。

相关推荐
工业互联网专业3 分钟前
基于springboot+vue的高校社团管理系统的设计与实现
java·vue.js·spring boot·毕业设计·源码·课程设计
Francek Chen3 分钟前
【深度学习基础】多层感知机 | 模型选择、欠拟合和过拟合
人工智能·pytorch·深度学习·神经网络·多层感知机·过拟合
iofomo40 分钟前
Android平台从上到下,无需ROOT/解锁/刷机,应用级拦截框架的最后一环,SVC系统调用拦截。
android
我叫特踏实1 小时前
SensorManager开发参考
android·sensormanager
V+zmm101342 小时前
教育培训微信小程序ssm+论文源码调试讲解
java·数据库·微信小程序·小程序·毕业设计
好评笔记2 小时前
AIGC视频扩散模型新星:Video 版本的SD模型
论文阅读·深度学习·机器学习·计算机视觉·面试·aigc·transformer
dddcyy2 小时前
利用现有模型处理面部视频获取特征向量(3)
人工智能·深度学习
樊南2 小时前
【esp32-uniapp小程序】uniapp小程序篇02——Hbuilder利用git连接远程仓库
git·小程序·gitee·uni-app·hbuilder·torisegit
liruiqiang052 小时前
机器学习-线性回归(简单回归、多元回归)
人工智能·机器学习
CM莫问2 小时前
<论文>用于大语言模型去偏的因果奖励机制
人工智能·深度学习·算法·语言模型·自然语言处理