垃圾分类是城市环境治理的重要环节,提高垃圾分类的便捷性和智能化水平对于推动可持续发展具有重要意义。基于Spring Boot和微信小程序的垃圾分类管理平台,通过搭建高效的后台管理系统和用户交互界面,实现垃圾分类信息管理、回收预约、回收站查询、积分兑换等功能。管理员可在后台管理系统中维护系统用户、回收站、垃圾分类、回收预约、兑换中心等模块,确保数据的有效管理和信息更新。普通用户可通过小程序进行垃圾识别、预约回收、查看回收记录、参与积分兑换,并获取最新的垃圾分类资讯,提升垃圾分类的便捷性与用户体验。系统支持回收数据的记录和统计,提供用户个人中心功能,便于跟踪个人垃圾回收情况和兑换记录。垃圾分类管理平台的构建能够有效提升垃圾分类效率,提高用户参与度,为环境保护和资源回收提供技术支持。

关键词:Spring Boot,微信小程序,垃圾分类,回收管理,积分兑换

ABSTRACT

Garbage classification is an important part of urban environmental governance, and improving the convenience and intelligence level of garbage classification is of great significance for promoting sustainable development. A garbage classification management platform based on Spring Boot and WeChat Mini Program, which achieves functions such as garbage classification information management, recycling reservation, recycling station query, and point redemption by building an efficient backend management system and user interaction interface. Administrators can maintain modules such as system users, recycling bins, garbage classification, recycling appointments, and redemption centers in the backend management system to ensure effective data management and information updates. Ordinary users can use the mini program to identify garbage, schedule recycling, view recycling records, participate in point redemption, and obtain the latest garbage classification information, improving the convenience and user experience of garbage classification. The system supports the recording and statistics of recycled data, providing users with a personal center function for easy tracking of personal garbage collection status and exchange records. The construction of a garbage classification management platform can effectively improve the efficiency of garbage classification, increase user participation, and provide technical support for environmental protection and resource recycling.

key word: Spring Boot, WeChat mini program, garbage classification, recycling management, points redemption

目  录

第1章 绪  论

1.1 研究背景

1.2 研究意义

1.3 国内现状

1.4 国外现状

第2章 相关技术介绍

2.1 SpringBoot框架介绍

2.2 MySQL数据库

2.3 Java语言

2.4 微信小程序

第3章 系统分析

3.1 可行性分析

3.1.1 技术可行性

3.1.2 经济可行性

3.1.3 操作可行性

3.1.4 社会可行性

3.2 系统功能需求

3.2.1 普通用户主要功能

3.2.2 管理员主要功能

3.3 非功能性需求分析

3.4 系统用户用例分析

3.4.1 普通用户用例图

3.4.2 管理员用例图

第4章 系统设计

4.1 功能模块设计

4.2 数据库设计

4.2.1 概念设计

4.2.2 逻辑设计

第5章 系统实现

5.1 普通用户主要功能实现

5.1.1 用户注册

5.1.2 用户登录

5.1.3 普通用户首页

5.1.4 回收站界面

5.1.5 垃圾识别

5.1.6 个人中心

5.2 管理员模块主要功能实现

5.2.1 后台首页

5.2.2 回收站管理

5.2.3 回收预约管理

5.2.4 兑换中心管理

5.2.5 资源管理

第6章 系统测试

6.1 测试目的

6.2 测试用例

6.3 测试结果

结  论

参考文献

致  谢

附录

系统核心代码设计

用户注册

用户登录

修改密码

修改数据

删除数据

获取列表

图片上传

第1章 绪  论

    1. 研究背景

随着城市化进程的加快和生活水平的提高,垃圾产量持续增长,垃圾分类成为环境保护和资源回收的重要手段。合理的垃圾分类不仅能减少环境污染,还能提高垃圾回收利用率,促进可持续发展。然而,当前垃圾分类管理仍面临诸多挑战,如分类意识不足、信息获取不便、回收体系不完善等,影响分类工作的推广和实施。近年来,数字化技术的应用为垃圾分类管理提供了新的解决方案,利用信息技术优化垃圾分类流程、提升用户体验成为行业发展的新方向。微信小程序作为轻量化应用,依托广泛的用户基础,能够高效连接普通用户与垃圾分类服务,实现信息查询、回收预约、积分兑换等功能,为垃圾分类的推广和管理提供便捷的技术支持。

    1. 研究意义

垃圾分类管理系统的构建能够提高垃圾分类的效率,优化资源回收流程,并提升公众的环保意识。通过Spring Boot后端开发和微信小程序前端交互,实现垃圾分类查询、回收预约、积分兑换等功能,使用户能够方便地参与垃圾分类,提高分类准确率。管理端提供垃圾分类数据管理、回收站维护、回收记录统计等功能,增强垃圾回收工作的可操作性和数据管理能力。该系统不仅能优化垃圾分类流程,还能通过积分兑换机制提高用户参与度,增强环保行为的激励效应。借助信息化手段推动垃圾分类的普及与规范化,有助于提升城市垃圾管理水平,促进生态环境改善,为构建绿色可持续社会提供技术支撑。

    1. 国内现状

近年来,垃圾分类管理逐渐成为国内城市治理的重要课题,各大城市纷纷出台垃圾分类政策,并推动智能化垃圾管理平台的建设。2019年,《上海市生活垃圾管理条例》的实施标志着国内垃圾分类进入强制执行阶段,北京、深圳、广州等城市也相继出台相关政策,推动垃圾分类的普及与规范化。为提升分类效率,多地政府和企业结合信息技术开发智能垃圾分类系统。例如,阿里巴巴推出“垃圾分类小助手”,基于大数据提供垃圾分类查询服务,方便用户快速识别垃圾类别。美团、支付宝等平台也陆续上线垃圾分类功能,通过用户扫码识别或语音输入查询垃圾分类规则,提升用户的垃圾分类意识。部分城市还建设了智能垃圾回收站,如深圳、杭州等地部署的垃圾回收积分系统,用户投放垃圾可获得积分奖励,用于兑换生活用品,提升垃圾分类的积极性。然而,国内垃圾分类管理仍然存在推广覆盖面不均、用户分类习惯不稳定、回收体系不完善等问题,仍需进一步优化管理方式,提高公众参与度。

    1. 国外现状

国外垃圾分类起步较早,尤其是日本、德国、瑞典等国家在垃圾分类管理方面已形成较为成熟的体系,并通过信息技术不断优化垃圾回收和管理流程。日本实行严格的垃圾分类制度,不仅在政策上规定详细的垃圾分类标准,还利用智能垃圾分类系统,如东京部分地区使用RFID(射频识别)技术对垃圾袋进行追踪,确保垃圾分类的准确性。德国推行“垃圾四分法”,并通过智能垃圾桶监控垃圾投放情况,提升垃圾回收效率。瑞典采用垃圾能源转化系统,结合智能回收站,实现垃圾的高效处理与再利用。此外,美国部分城市推出了智能垃圾回收应用,如“RecycleNation”,帮助用户查询垃圾分类规则,并提供最近的回收站信息,方便居民处理垃圾。近年来,智能化垃圾分类管理成为国际研究重点,多个国家通过物联网、大数据等技术优化垃圾回收体系,提高垃圾管理的自动化和智能化水平。

  1. 相关技术介绍
    1. SpringBoot框架介绍

SpringBoot是Spring家族中的一个重要成员,它简化了Spring应用的初始搭建和开发过程[1]。通过提供一系列默认配置和自动装配机制,SpringBoot使得开发者能够更快地构建出生产级别的Spring应用。它支持多种开发工具和框架,如Maven、Gradle等,并且可以与多种数据库和缓存技术无缝集成[2]。SpringBoot的简洁性和高效性使其成为开发企业级应用的首选框架之一。在本次毕业设计中,SpringBoot框架为微信小程序垃圾分类系统的设计与实现的后端开发提供了强大的支持。

    1. MySQL数据库

MySQL是一款开源的关系型数据库管理系统,它以其高性能、高可靠性和易用性而著称。MySQL支持多种存储引擎,如InnoDB、MyISAM等,能够满足不同应用场景的需求[3]。它提供了丰富的SQL语法和函数,使得开发者能够方便地进行数据查询、更新和删除操作。MySQL还支持事务处理、索引优化和复制等高级功能,为数据的完整性和安全性提供了有力保障。在本次毕业设计中,MySQL数据库作为微信小程序垃圾分类系统的设计与实现的数据存储核心,承担着存储和管理垃圾回收信息、用户信息等重要数据的任务。而且通过合理的数据库设计和优化,确保了系统的数据访问效率和数据安全性[4]。

    1. Java语言

JAVA是一种广泛使用的编程语言,具有跨平台、面向对象、安全性高等特点。JAVA语言提供了丰富的类库和API,使得开发者能够轻松地进行网络编程、数据库操作、图形界面开发等任务[4]。JAVA还支持多线程编程和分布式计算,为开发高性能和可扩展的应用提供了有力支持[5]。所以本次毕设选择了JAVA作为微信小程序垃圾分类系统的设计与实现的开发语言。通过利用JAVA的面向对象特性和丰富的类库资源,成功实现了系统的各个功能模块,并保证了系统的稳定性和可扩展性。而且JAVA的跨平台特性也使得此次毕业设计能够在不同的操作系统和硬件平台上运行,为用户提供了更加便捷的使用体验。

    1. 微信小程序

微信小程序基于轻量化架构,结合 前端 WXML、WXSS、JavaScript 进行页面开发,并通过 小程序API 实现用户交互,如垃圾分类查询、预约管理等。后端采用 Spring Boot 提供 RESTful API,结合 MySQL 和 Redis 进行数据存储和缓存优化,确保系统高效运行。小程序依托 微信云开发(CloudBase) 支持云函数、云数据库等服务,提升扩展性和运维效率。前后端通过 HTTPS 和 WebSocket 进行数据通信,确保信息安全与实时更新。微信公众平台提供 版本管理、用户反馈、性能监控,优化系统稳定性。该技术体系使垃圾分类小程序具有高效、便捷、易维护的特性,提升垃圾分类管理的智能化和用户体验。

  1. 系统分析
    1. 可行性分析
      1. 技术可行性

基于Spring Boot框架开发微信小程序垃圾分类系统的设计与实现具有显著优势。Spring Boot以其简洁的配置、高效的性能以及强大的集成能力,为快速构建稳定、可扩展的Web应用提供了坚实基础[7]。结合MySQL数据库的高效存储与检索能力,以及Java语言的广泛应用与成熟生态,系统能够实现复杂的数据处理与业务逻辑[8]。此外前端采用Vue.js等现代前端框架,可确保用户界面的流畅与互动性,技术实现路径清晰可行。

      1. 经济可行性

该系统开发成本相对较低,主要投入在于人力与硬件资源。Spring Boot及MySQL均为开源技术,无需额外购买软件许可,降低了开发成本。如果系统上线可通过提供便捷、透明的服务,可吸引大量用户,进而通过广告、增值服务等方式实现盈利,具有良好的经济回报预期。此外,系统维护成本适中,便于长期运营与迭代升级。

      1. 操作可行性

基于Spring Boot的微信小程序垃圾分类系统采用成熟的技术架构,前端使用微信小程序实现用户交互,后端基于Spring Boot提供稳定的服务端支持,并结合MySQL数据库进行数据存储,确保系统的高效性和可扩展性。微信小程序具有轻量化、易于访问的特点,无需下载即可使用,降低了用户的使用门槛。系统功能包括垃圾分类查询、回收预约、回收站管理、积分兑换等,后台管理员可高效管理垃圾分类数据、用户预约记录及回收站运营情况,确保垃圾分类流程的顺畅执行。系统支持多终端访问,具备良好的用户体验和数据处理能力,能够适应不同地区垃圾分类管理需求,保证了系统的可行性和可操作性。

      1. 社会可行性

垃圾分类已成为全球环境治理的重要议题,国家政策的推动为垃圾分类管理提供了强有力的支持。近年来,我国出台了《生活垃圾分类制度实施方案》等政策,各大城市相继推行垃圾分类法规,要求社区、企业、学校等公共场所建立完善的垃圾分类制度。公众环保意识逐步提高,对垃圾分类的接受度和参与度不断上升。该系统通过信息化手段提升垃圾分类的便捷性,提供垃圾分类查询、预约回收、积分兑换等功能,能够激励用户积极参与垃圾分类。企业、政府机构也可借助该系统优化垃圾回收体系,提高垃圾资源化利用率,减少环境污染。结合社会需求与政策支持,该系统具备较强的社会可行性,有助于推动垃圾分类工作的普及与规范化。

    1. 系统功能需求

Springboot微信小程序垃圾分类系统的设计与实现包含普通用户和管理员两个角色划分每个角色对应的主要功能如下:

      1. 普通用户主要功能

普通用户可通过系统进行垃圾分类、回收预约和积分兑换,主要功能如下:

  1. 推荐:获取个性化垃圾分类相关内容和建议。
  2. 回收站:查询附近回收站点,进行垃圾回收预约。
  3. 兑换中心:使用积分兑换物品,提升垃圾分类积极性。
  4. 垃圾识别:快速查询垃圾分类规则,提高分类准确性。
  5. 新闻资讯:浏览垃圾分类政策、环保知识和行业动态。
  6. 个人中心:管理个人信息,包括收藏、评论、统计数据。
  7. 回收预约:提交回收预约,查看预约状态。
  8. 回收记录:查询历史回收数据,跟踪个人垃圾分类情况。
  9. 兑换记录:查看兑换详情,跟踪积分使用情况。
      1. 管理员主要功能

管理员负责系统运营和管理,确保垃圾分类和回收流程高效运行,主要功能如下:

  1. 后台首页:查看系统概览,快速访问各管理模块。
  2. 系统用户管理:管理用户信息,分配权限,确保系统安全。
  3. 回收站管理:维护回收站点信息,支持新增、修改、删除。
  4. 垃圾分类管理:更新垃圾分类标准,提高分类准确性。
  5. 回收预约管理:审核用户预约,管理预约记录,优化回收流程。
  6. 回收记录管理:追踪垃圾回收情况,确保数据准确。
  7. 兑换中心管理:维护兑换物品,管理兑换流程。
  8. 物品类型管理:分类管理兑换物品,提高兑换规范性。
  9. 兑换记录管理:查询和管理用户兑换数据。
  10. 系统管理:维护系统运行,保障稳定性。
  11. 网站公告管理:发布垃圾分类公告,提升用户知晓度。
  12. 资源管理:维护新闻资讯,提供垃圾分类知识。
    1. 非功能性需求分析
  1. 性能需求:系统应支持至少1000个并发用户,响应时间小于3秒,确保用户在高峰期仍能顺畅使用。
  2. 可靠性需求:系统可用性需达到99.9%,故障恢复时间不超过30分钟,确保稳定运行。
  3. 安全性需求:用户数据需加密存储和传输,支持身份认证和授权机制,防止SQL注入等安全漏洞。
  4. 可用性需求:界面应简洁、直观,支持多平台兼容,如安卓和iOS,确保用户操作便捷。
  5. 扩展性需求:系统应具备良好的模块化设计,支持未来功能扩展和数据增长。
  6. 可维护性需求:代码应遵循编程规范,记录日志便于系统排查和维护。
  7. 法律和合规性需求:系统需符合数据保护法律和支付合规性要求,确保用户隐私安全。
  8. 支持性需求:应支持多角色管理并提供帮助文档和客服支持,提升用户体验。
    1. 系统用户用例分析
      1. 普通用户用例图

普通用户用例图展示了用户在垃圾分类小程序中的主要交互功能和系统响应。普通用户可通过小程序执行 垃圾识别、回收预约、回收记录查询、兑换中心使用、新闻资讯浏览 等操作。用户可以在 回收站模块 查找附近回收点并预约垃圾回收,在 兑换中心 使用积分兑换物品,并在 个人中心 管理收藏、评论、统计数据、回收预约和兑换记录。系统提供垃圾分类查询、回收进度反馈、积分兑换管理等服务,以提升垃圾分类的便捷性和用户体验。普通用户用例图如下所示:

图3-1 普通用户用例图

      1. 管理员用例图

管理员用例图展示了管理员在垃圾分类小程序后台的主要管理功能及其与系统的交互关系。管理员可在 系统后台 执行 系统用户管理、回收站管理、垃圾分类维护、回收预约审核、回收记录管理、兑换中心管理、物品类型维护、兑换记录查询、系统公告发布、资源管理 等操作。通过后台,管理员能够维护用户权限、优化垃圾分类规则、审核用户预约、跟踪回收数据、管理兑换流程,确保垃圾分类系统的稳定运行和高效管理。管理员用例图如下所示:

图3-3 管理员用例图


  1. 系统设计
    1. 功能模块设计

功能模块设计围绕垃圾分类、回收管理和积分兑换三大核心,划分 普通用户端 和 管理员端,确保系统高效运行。普通用户端包含 垃圾识别、回收站查询、回收预约、回收记录、兑换中心、新闻资讯和个人中心,支持用户便捷查询垃圾分类规则、预约回收、管理积分兑换及查看相关资讯。管理员端提供 系统用户管理、回收站管理、垃圾分类管理、回收预约审核、回收记录管理、兑换中心管理、公告发布和资源管理,确保数据维护、预约审核和系统运维的规范化。各功能模块相互协作,形成完整的垃圾分类与回收管理体系,提高垃圾分类效率和用户参与度。每个角色对应的功能模块如图所示。

图4-1系统功能结构图

    1. 数据库设计
      1. 概念设计

概念设计通过 E-R(实体-关系)图 直观展示垃圾分类小程序的数据库结构和核心实体之间的关系。系统主要涉及 用户、回收站、垃圾分类、回收预约、回收记录、兑换中心、兑换记录、系统管理员 等实体。普通用户可进行 垃圾分类查询、预约回收、兑换积分,其数据与回收站、垃圾分类、兑换中心等实体关联;管理员负责 用户管理、回收站维护、分类规则管理、预约审核,确保数据的完整性和系统的稳定运行。E-R 图明确各实体的属性和相互关系,为数据库设计提供逻辑支撑,确保数据存储和调用的高效性。E-R实体关系图。

图4-2总体ER图

      1. 逻辑设计

通过上一小节微信小程序垃圾分类系统的设计与实现平台中总E-R关系图上得出一共需要创建很多个数据表。在此主要罗列几个主要的数据库表结构设计。

介绍了一些根据各类别主要数据库表的设计结构以及基本功能建立数据库表:

表 4-1-access_token(登陆访问时长)

数据库表结构文档

表 4-1-access_token(登陆访问时长)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

token_id

int

临时访问牌ID

2

token

varchar

64

临时访问牌

3

info

text

65535

信息

4

maxage

int

最大寿命:默认2小时

5

create_time

timestamp

创建时间

6

update_time

timestamp

更新时间

7

user_id

int

用户编号

表 4-2-article(文章)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

article_id

mediumint

文章id

2

title

varchar

125

标题

3

type

varchar

64

文章分类

4

hits

int

点击数

5

praise_len

int

点赞数

6

create_time

timestamp

创建时间

7

update_time

timestamp

更新时间

8

source

varchar

255

来源

9

url

varchar

255

来源地址

10

tag

varchar

255

标签

11

content

longtext

4294967295

正文

12

img

varchar

255

封面图

13

description

text

65535

文章描述

表 4-3-article_type(文章分类)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

type_id

smallint

分类ID

2

display

smallint

显示顺序

3

name

varchar

16

分类名称

4

father_id

smallint

上级分类ID

5

description

varchar

255

描述

6

icon

text

65535

分类图标

7

url

varchar

255

外链地址

8

create_time

timestamp

创建时间

9

update_time

timestamp

更新时间

表 4-4-auth(用户权限管理)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

auth_id

int

授权ID

2

user_group

varchar

64

用户组

3

mod_name

varchar

64

模块名

4

table_name

varchar

64

表名

5

page_title

varchar

255

页面标题

6

path

varchar

255

路由路径

7

parent

varchar

64

父级菜单

8

parent_sort

int

父级菜单排序

9

position

varchar

32

位置

10

mode

varchar

32

跳转方式

11

add

tinyint

是否可增加

12

del

tinyint

是否可删除

13

set

tinyint

是否可修改

14

get

tinyint

是否可查看

15

field_add

text

65535

添加字段

16

field_set

text

65535

修改字段

17

field_get

text

65535

查询字段

18

table_nav_name

varchar

500

跨表导航名称

19

table_nav

varchar

500

跨表导航

20

option

text

65535

配置

21

create_time

timestamp

创建时间

22

update_time

timestamp

更新时间

表 4-5-code_token(验证码)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

code_token_id

int

验证码ID

2

token

varchar

255

令牌

3

code

varchar

255

验证码

4

expire_time

timestamp

失效时间

5

create_time

timestamp

创建时间

6

update_time

timestamp

更新时间

表 4-6-collect(收藏)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

collect_id

int

收藏ID

2

user_id

int

收藏人ID

3

source_table

varchar

255

来源表

4

source_field

varchar

255

来源字段

5

source_id

int

来源ID

6

title

varchar

255

标题

7

img

varchar

255

封面

8

create_time

timestamp

创建时间

9

update_time

timestamp

更新时间

表 4-7-comment(评论)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

comment_id

int

评论ID

2

user_id

int

评论人ID

3

reply_to_id

int

回复评论ID

4

content

longtext

4294967295

内容

5

nickname

varchar

255

昵称

6

avatar

varchar

255

头像地址

7

create_time

timestamp

创建时间

8

update_time

timestamp

更新时间

9

source_table

varchar

255

来源表

10

source_field

varchar

255

来源字段

11

source_id

int

来源ID

表 4-8-exchange_records(兑换记录)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

exchange_records_id

int

兑换记录ID

2

exchange_number

varchar

64

兑换号

3

serial_number

varchar

64

物品编号

4

item_name

varchar

64

物品名称

5

type_of_item

varchar

64

物品类型

6

item_specifications

varchar

64

物品规格

7

unit_price_points

double

单价积分

8

exchange_users

int

兑换用户

9

user_name

varchar

64

用户姓名

10

phone_number

varchar

16

手机号码

11

exchange_quantity

double

兑换数量

12

spend_points

varchar

64

花费积分

13

create_time

datetime

创建时间

14

update_time

timestamp

更新时间

15

source_table

varchar

255

来源表

16

source_id

int

来源ID

17

source_user_id

int

来源用户

表 4-9-hits(用户点击)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

hits_id

int

点赞ID

2

user_id

int

点赞人

3

create_time

timestamp

创建时间

4

update_time

timestamp

更新时间

5

source_table

varchar

255

来源表

6

source_field

varchar

255

来源字段

7

source_id

int

来源ID

表 4-10-item_type(物品类型)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

item_type_id

int

物品类型ID

2

item_type

varchar

64

物品类型

3

create_time

datetime

创建时间

4

update_time

timestamp

更新时间

表 4-11-notice(公告)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

notice_id

mediumint

公告ID

2

title

varchar

125

标题

3

content

longtext

4294967295

正文

4

create_time

timestamp

创建时间

5

update_time

timestamp

更新时间

表 4-12-ordinary_users(普通用户)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

ordinary_users_id

int

普通用户ID

2

user_name

varchar

64

用户姓名

3

phone_number

varchar

16

手机号码

4

community_address

varchar

64

社区地址

5

total_score

double

总积分

6

examine_state

varchar

16

审核状态

7

user_id

int

用户ID

8

create_time

datetime

创建时间

9

update_time

timestamp

更新时间

表 4-13-praise(点赞)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

praise_id

int

点赞ID

2

user_id

int

点赞人

3

create_time

timestamp

创建时间

4

update_time

timestamp

更新时间

5

source_table

varchar

255

来源表

6

source_field

varchar

255

来源字段

7

source_id

int

来源ID

8

status

tinyint

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

表 4-14-recycle_bin(回收站)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

recycle_bin_id

int

回收站ID

2

name

varchar

64

站点名称

3

site_address

varchar

64

站点地址

4

cover_image

varchar

255

封面图

5

person_in_charge

varchar

64

负责人

6

contact_number

varchar

16

联系电话

7

detailed_introduction

text

65535

详细介绍

8

hits

int

点击数

9

collect_len

int

收藏数

10

comment_len

int

评论数

11

recommend

int

智能推荐

12

recycling_reservation_limit_times

int

预约限制次数

13

create_time

datetime

创建时间

14

update_time

timestamp

更新时间

表 4-15-recycling_records(回收记录)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

recycling_records_id

int

回收记录ID

2

reserve_number

varchar

64

预约编号

3

name

varchar

64

站点名称

4

site_address

varchar

64

站点地址

5

person_in_charge

varchar

64

负责人

6

contact_number

varchar

16

联系电话

7

appointment_personnel

int

预约人员

8

user_name

varchar

64

用户姓名

9

phone_number

varchar

16

手机号码

10

community_address

varchar

64

社区地址

11

refuse_classification

varchar

64

垃圾分类

12

recycling_specifications

varchar

64

回收规格

13

garbage_points

double

垃圾积分

14

screenshot

varchar

255

截图

15

recycling_quantity

double

回收数量

16

collect_points

varchar

64

回收积分

17

recycling_date

date

回收日期

18

create_time

datetime

创建时间

19

update_time

timestamp

更新时间

20

source_table

varchar

255

来源表

21

source_id

int

来源ID

22

source_user_id

int

来源用户

表 4-16-recycling_reservation(回收预约)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

recycling_reservation_id

int

回收预约ID

2

reserve_number

varchar

64

预约编号

3

name

varchar

64

站点名称

4

site_address

varchar

64

站点地址

5

person_in_charge

varchar

64

负责人

6

contact_number

varchar

16

联系电话

7

appointment_personnel

int

预约人员

8

user_name

varchar

64

用户姓名

9

phone_number

varchar

16

手机号码

10

community_address

varchar

64

社区地址

11

refuse_classification

varchar

64

垃圾分类

12

recycling_specifications

varchar

64

回收规格

13

garbage_points

varchar

64

垃圾积分

14

screenshot

varchar

255

截图

15

notes

text

65535

备注

16

examine_state

varchar

16

审核状态

17

examine_reply

varchar

16

审核回复

18

recycling_records_limit_times

int

确认回收限制次数

19

create_time

datetime

创建时间

20

update_time

timestamp

更新时间

21

source_table

varchar

255

来源表

22

source_id

int

来源ID

23

source_user_id

int

来源用户

表 4-17-redemption_center(兑换中心)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

redemption_center_id

int

兑换中心ID

2

serial_number

varchar

64

物品编号

3

item_name

varchar

64

物品名称

4

type_of_item

varchar

64

物品类型

5

cover_image

varchar

255

封面图

6

item_specifications

varchar

64

物品规格

7

unit_price_points

double

单价积分

8

quantity_of_items

double

物品数量

9

detailed_introduction

longtext

4294967295

详细介绍

10

hits

int

点击数

11

collect_len

int

收藏数

12

comment_len

int

评论数

13

exchange_records_limit_times

int

兑换限制次数

14

create_time

datetime

创建时间

15

update_time

timestamp

更新时间

表 4-18-score(评分)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

score_id

int

评分ID

2

user_id

int

评分人

3

nickname

varchar

64

昵称

4

score_num

double

评分

5

create_time

timestamp

创建时间

6

update_time

timestamp

更新时间

7

source_table

varchar

255

来源表

8

source_field

varchar

255

来源字段

9

source_id

int

来源ID

表 4-19-slides(轮播图)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

slides_id

int

轮播图ID

2

title

varchar

64

标题

3

content

varchar

255

内容

4

url

varchar

255

链接

5

img

varchar

255

轮播图

6

hits

int

点击量

7

create_time

timestamp

创建时间

8

update_time

timestamp

更新时间

表 4-20-upload(文件上传)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

upload_id

int

上传ID

2

name

varchar

64

文件名

3

path

varchar

255

访问路径

4

file

varchar

255

文件路径

5

display

varchar

255

显示顺序

6

father_id

int

父级ID

7

dir

varchar

255

文件夹

8

type

varchar

32

文件类型

表 4-21-user(用户账户)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

user_id

int

用户ID

2

state

smallint

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

3

user_group

varchar

32

所在用户组

4

login_time

timestamp

上次登录时间

5

phone

varchar

11

手机号码

6

phone_state

smallint

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

7

username

varchar

16

用户名

8

nickname

varchar

16

昵称

9

password

varchar

64

密码

10

email

varchar

64

邮箱

11

email_state

smallint

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

12

avatar

varchar

255

头像地址

13

open_id

varchar

255

针对获取用户信息字段

14

create_time

timestamp

创建时间

表 4-22-user_group(用户组)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

group_id

mediumint

用户组ID

2

display

smallint

显示顺序

3

name

varchar

16

名称

4

description

varchar

255

描述

5

source_table

varchar

255

来源表

6

source_field

varchar

255

来源字段

7

source_id

int

来源ID

8

register

smallint

注册位置

9

create_time

timestamp

创建时间

10

update_time

timestamp

更新时间

表 4-23-waste_sorting(垃圾分类)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

waste_sorting_id

int

垃圾分类ID

2

refuse_classification

varchar

64

垃圾分类

3

recycling_specifications

varchar

64

回收规格

4

garbage_points

double

垃圾积分

5

create_time

datetime

创建时间

6

update_time

timestamp

更新时间

  1. 系统实现
    1. 普通用户主要功能实现
      1. 用户注册

用户注册:点击注册,进入注册页面,填写好账号、密码、确认密码、昵称、邮箱、身份:普通用户、用户姓名、用户电话、社区地址等字段值,点击下方注册按钮,提示注册成功后,系统将自动跳转回到登录页面。注册界面如下图所示。

图5-1 注册界面

      1. 用户登录

用户登录:点击“登录”按钮,输入用户名、密码、验证码登录系统,登录时前端会自动校验用户名与密码以及该用户是否审核通过,审核通过的用户输入正确登录

成功,输入错误会有提示信息。登录界面如下图所示。

图5-2 登录界面

      1. 普通用户首页

普通用户首页提供垃圾分类与回收服务的便捷入口,包含 推荐、回收站、兑换中心、垃圾识别、新闻资讯、我的 等功能模块。用户可浏览个性化推荐内容,查找附近回收站进行垃圾投递,进入兑换中心兑换积分,使用垃圾识别功能快速分类垃圾,获取最新的环保资讯,并在“我的”页面管理个人信息和预约记录,提升垃圾分类的便捷性与互动体验。普通用户首页界面如下图所示。

图5-3 普通用户首页界面

      1. 回收站界面

回收站界面提供 回收站列表,用户可查看各回收站的 位置、联系方式、回收类别 等信息。支持 预约 功能,用户可在线预约垃圾回收服务,同时提供 评论 入口,让用户分享回收体验和反馈意见,优化回收站服务质量,提高用户参与度。回收站界面如下图所示。

图5-4 回收站界面

      1. 垃圾识别

垃圾识别界面提供 查询 功能,用户可输入垃圾名称进行搜索,系统将自动匹配对应的垃圾类别,并提供正确的分类及投放建议。该功能帮助用户快速了解垃圾分类,提高垃圾回收的准确性和便捷性。垃圾识别界面如下图所示。

图5-5 垃圾识别界面

      1. 个人中心

个人中心界面提供用户个人数据和操作管理,包含 收藏、评论、回收预约、回收记录、兑换记录、统计 等功能。用户可查看收藏的资讯或物品,管理评论内容,查询回收预约情况及历史回收记录,同时跟踪兑换中心的兑换记录。统计功能提供数据可视化分析,方便用户了解自身垃圾分类和回收情况,提高环保参与度。个人中心界面如下图所示。

图5-6 个人中心界面

    1. 管理员模块主要功能实现
      1. 后台首页

管理员首页提供系统管理的核心入口,展示系统概览,包括回收预约、回收记录、垃圾分类、兑换中心等关键数据。通过后台首页,管理员可以快速访问 系统用户管理、回收站管理、垃圾分类管理、兑换记录管理、公告发布 等功能模块,确保系统的正常运行和数据的有效管理,提高垃圾分类和回收服务的效率。管理员用户首页界面如下图所示。

图5-7后台首页界面图

      1. 回收站管理

回收站管理界面包含 回收站列表 和 回收站添加 功能,支持管理员查看、编辑和新增回收站信息。主要包括 站点名称、站点地址、封面图、负责人、联系电话、详细介绍 等内容。通过该界面,可优化回收站点的布局,确保垃圾分类和回收工作的高效开展。回收站管理界面如下图所示。

图5-8 回收站管理界面

      1. 回收预约管理

回收预约管理界面提供 回收预约列表,包含 预约编号、站点名称、垃圾分类、审核状态、用户姓名 等信息。管理员可通过 查询、重置、删除 等功能管理预约记录,并执行 查看详情、审核、确认回收 操作,确保回收预约的顺利进行,提高垃圾分类与回收效率。回收预约管理界面如下图所示。

图5-9回收预约管理界面图

      1. 兑换中心管理

兑换中心管理界面包含 兑换中心列表 和 兑换中心添加 功能,支持管理员管理可兑换物品的信息。主要字段包括 物品名称、物品类型,并提供 查询、重置、删除 等操作。管理员还可查看 详情 及 用户评论,确保兑换物品的管理有序,提高用户的兑换体验。兑换中心管理界面如下图所示。

图5-10 兑换中心管理界面图

      1. 资源管理

资源管理界面包含 新闻资讯 和 资讯分类 功能,支持管理员发布、编辑、删除新闻资讯,并对资讯进行分类管理。通过该界面,可确保垃圾分类相关信息的及时更新,提升用户环保意识,提高系统的信息传播和管理效率。资源管理界面如下图所示。

图5-11 资源管理界面图


  1. 系统测试
    1. 测试目的

在这个产品被投入使用前,首先需要进行试用,这是重要的环节。考虑到某个部分的开发没有缺陷情况下,把各种模块拼接,也有一定概率就存在矛盾。这就好比每个人都很独特,但聚在一起就显得杂乱无章,需要保证有默契的配合。对于测试,要看它的各项内容是否契合的原则[10]。若与最初定下的标准有一定程度上的出入,那么就需要做出一些调整,让最终的大方向朝着目标前进。

测试是为了发现在开发的程序中所存在的问题,测试这一工作是非常艰巨的,而又是非常困难的,这一部分在程序的设计中占有很大比例,可以说一个程序的开发工作量要是占据了百分至六十,那么剩下的百分之四十必然是测试这一部分,甚至更高。

    1. 测试用例

用户登录功能测试

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

用例名称

普通用户登录系统

目的

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

前提

未登录的情况下

测试流程

1) 进入登录页面

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

3)点击登录

预期结果

登录成功时跳转到首页,错误时提示重新输入

实际结果

实际结果与预期结果一致

垃圾分类查询功能测试:

表6-2 垃圾分类查询功能测试表

用例名称

测试用户能否正确查询垃圾分类

目的

测试用户能否查看房间信息

前提

用户已登录

测试流程

进入垃圾识别页面

预期结果

系统返回正确的垃圾分类信息

实际结果

实际结果与预期结果一致

回收预约功能测试:

表6-3 回收预约功能测试表

用例名称

回收预约功能测试

目的

测试用户能否成功预约垃圾回收

前提

用户已登录

测试流程

1) 进入回收站模块

2) 选择回收站点

预期结果

预约成功后在个人中心显示预约记录

实际结果

实际结果与预期结果一致

回收记录查询功能测试:

表6-4回收记录查询功能测试表

用例名称

回收记录查询测试

目的

测试用户能否正确查看历史回收记录

前提

用户已登录

测试流程

1)进入个人中心

2)点击回收记录模块

预期结果

系统正确显示用户的历史回收记录

实际结果

实际结果与预期结果一致

管理员用户管理功能测试:

表6-5管理员用户管理功能测试表

用例名称

管理员用户管理功能测试

目的

测试管理员能否成功管理系统用户

前提

管理员已登录

测试流程

1) 进入系统用户管理模块

预期结果

系统成功更新用户数据

实际结果

实际结果与预期结果一致

回收站管理测试:

表6-6回收站管理测试表

用例名称

回收站管理测试

目的

测试管理员是否可以正确管理回收站信息

前提

用户已登录

测试流程

1) 进入回收站管理模块

预期结果

系统正确更新回收站信息

实际结果

实际结果与预期结果一致

公告信息管理测试:

表6-7公告信息管理测试表

用例名称

公告信息管理测试

目的

测试管理员是否可以正确发布和管理公布

前提

管理员已登录

测试流程

1) 进入公告管理模块

预期结果

公告信息正确显示在前端

实际结果

实际结果与预期结果一致

    1. 测试结果

本次测试围绕 基于Spring Boot的微信小程序垃圾分类系统 的核心功能,涵盖 用户登录、垃圾分类查询、回收预约、回收记录管理、管理员管理、回收站维护、公告信息管理等模块,确保系统功能的完整性和稳定性。

在用户端功能测试 中,用户能够顺利登录系统,正确查询垃圾分类信息,预约垃圾回收,并在个人中心查看回收记录,系统反馈符合预期,数据存储和展示准确。管理员功能测试验证了系统用户管理、回收站维护和公告发布等操作的可行性,确保管理员能够有效管理平台资源和用户数据,公告信息能够正确显示在前端。

所有测试用例均执行成功,实际测试结果与预期一致,表明系统运行稳定,数据存储、查询、更新等功能均符合业务需求。系统具备良好的可用性和可维护性,能够有效支持垃圾分类的在线管理和用户服务。后续可进一步优化性能,提升用户体验,提高垃圾分类和回收管理的智能化水平。

结  论

基于Spring Boot的微信小程序垃圾分类系统的设计与实现,旨在通过信息化手段优化垃圾分类流程,提高垃圾回收的便捷性和用户参与度。系统采用Spring Boot作为后端框架,结合微信小程序前端,实现了垃圾分类查询、回收预约、回收记录管理、积分兑换以及管理员后台管理等核心功能。通过该系统,用户可以方便地进行垃圾分类识别,预约回收服务,并通过积分兑换机制激励垃圾分类行为;管理员则能够高效管理回收站、垃圾分类规则、回收预约审核和公告发布,确保系统的稳定运行和数据的准确性。

系统测试表明,用户端和管理员端的各项功能均能够稳定运行,交互体验流畅,数据存储和调用准确,满足垃圾分类管理的实际需求。用户可以顺利完成垃圾分类查询、回收预约、回收记录查询和积分兑换,而管理员能够有效维护回收站信息、审核回收预约,并通过公告系统发布垃圾分类相关信息,提升用户的环保意识和参与度。

整体而言,该系统的构建不仅提升了垃圾分类的智能化管理水平,也为垃圾回收体系提供了有效的信息化支撑。未来可以结合大数据分析和机器学习技术,进一步优化垃圾分类推荐算法,提高系统的智能化程度。同时,可扩展回收站点布局优化、用户行为分析等功能,使垃圾分类和回收管理更加高效和精准,为环保和可持续发展提供更有力的技术支持。


参考文献

  1. 韦珍娜,陈宇佳. 基于Springboot的服装租赁系统设计 [J]. 电脑编程技巧与维护, 2025, (01): 35-38. DOI:10.16184/j.cnki.comprg.2025.01.005.
  2. 姚佰允,张豪,杜瑞庆. 基于SpringBoot与Vue的学院人员管理系统设计与实现 [J]. 无线互联科技, 2025, 22 (02): 78-83.
  3. 谢海明,张佐中,林顺福.基于自动化技术的MySQL故障处理系统的设计与实现[J].电脑知识与技术,2024,20(33):73-75.DOI:10.14004/j.cnki.ckt.2024.1721.
  4. 陈芳.基于MySQL数据库的数据录入系统设计研究[J].科技资讯,2024,22(20):35-37.DOI:10.16661/j.cnki.1672-3791.2405-5042-7194.
  5. 谢帅虎.基于Java语言的翻页功能接口程序设计与实现[J].数字通信世界,2024,(11):92-94.
  6. 贾琴.Java编程语言的应用策略分析[J].集成电路应用,2024,41(10):84-85.DOI:10.19339/j.issn.1674-2583.2024.10.034.
  7. 张靖旭,曾晓晶,郭玉坤. 基于SpringBoot的校园植物信息网建设研究 [J]. 信息与电脑(理论版), 2024, 36 (22): 119-121.
  8. 戴亚哲,李尤,赵利宏,等. 基于SpringBoot+Vue的文旅平台设计与研究 [J]. 无线互联科技, 2024, 21 (21): 70-72.
  9. 朴明,邱翠花,苗子. 基于SpringBoot+小程序的信息采集系统设计与实现 [J]. 电子技术, 2024, 53 (10): 47-49.
  10. 徐天鑫,宛楠,唐安琦,等.智能环保垃圾分类系统设计与实现[J].福建电脑,2024,40(12):88-92.DOI:10.16707/j.cnki.fjpc.2024.12.018.
  11. 黄明宇,曹一鹏,佟英芝,等.基于视觉分析的垃圾分类识别系统的设计与实现[J].物联网技术,2024,14(09):25-27.DOI:10.16667/j.issn.2095-1302.2024.09.006.
  12. 黄锦敬,成翠雄.微信小程序智能垃圾分类系统的设计与实现[J].现代计算机,2024,30(09):81-85.
  13. Huang D ,Gan B.Intelligent Garbage Recycling: Design and Implementation Exploration of Automatic Classification System[J].Meteorological and Environmental Research,2024,15(2):37-39,43.
  14. 储佳乐,宛楠,叶晓龙,等.医疗垃圾分类系统的设计与实现[J].福建电脑,2023,39(12):112-115.DOI:10.16707/j.cnki.fjpc.2023.12.024.
  15. 王文武.基于深度学习的智能垃圾分类系统设计与实现[D].内蒙古大学,2023.DOI:10.27224/d.cnki.gnmdu.2023.000666.
  16. 李艳平,张成昊.基于微信小程序的垃圾分类系统设计与实现[J].现代信息科技,2023,7(10):14-17+21.DOI:10.19850/j.cnki.2096-4706.2023.10.004.
  17. 余赞,李叶萱,高靖棠,等.基于Android的垃圾分类管理系统设计与实现[J].电脑编程技巧与维护,2023,(04):64-66.DOI:10.16184/j.cnki.comprg.2023.04.036.
  18. 许佳文,孙泽宇,陈浦灿.城市生活垃圾分类智能引导系统设计与实现[J].电子制作,2023,31(08):45-48.DOI:10.16589/j.cnki.cn11-3571/tn.2023.08.029.
  19. Wang L ,Jiang J ,Li N , et al.Design and Implementation of Garbage Classification System under the "Double Carbon" Target[J].International Journal of Frontiers in Sociology,2022,4.0(6.0):
  20. 张巧岭.基于微信小程序的垃圾分类系统的设计与实现[J].电子世界,2020,(21):185-186.DOI:10.19353/j.cnki.dzsj.2020.21.079.
  21. Quanfu W ,Bin W .Design and implementation of garbage classification and detection system based on YOLOv8[C]//Nanfang College (China),2024:

致  谢

在完成本次springboot微信小程序垃圾分类系统的设计与实现的过程中,我收获了诸多宝贵的经验,也感受到了成长的喜悦,也深刻体会到理论与实践相结合的重要性。在这里我特别感谢我毕设的导师。在整个毕设过程中老师不但给我指明方向也给予我专业的指导,给了我很大的帮助也让我在探索中不断突破自我不断提升我的专业能力,更让我学会了如何以科学的方法解决问题。

我也感谢学校为我提供了一个良好的学习环境和丰富的资源支持。让我得以接触到前沿的技术知识和开发工具,为毕业设计的顺利开展奠定了坚实基础。在开发过程中,我遇到了许多技术难题,但通过查阅大量文献资料和反复实践,我逐渐找到了解决方法。这一过程不仅锻炼了我的自主学习能力,也让我深刻体会到知识的力量。

最后我要感谢我的家人和亲朋们。在我为毕业设计忙碌的日子里,他们始终给予我无条件的支持和鼓励。他们的理解让我能够在紧张的学习中保持良好的心态,专注于项目的每一个细节。这份毕业设计是我大学生活的完美收官,也是我人生旅程中的一个重要里程碑。我将带着这份成长和感恩,继续在未来的道路上努力前行。


附录

系统核心代码设计

用户注册

注册页UserController.java,传入user对象,并将"user_id"、 "state"、 "user_group"、"login_time"、"phone"、"phone_state"、 "username"、"nickname"、"password"、"email"、"email_state"、"avatar"、"create_time"输入,重点是 "username"、"nickname"、"password"必须输入,通过获取username,数据库查询是否有该用户,如果存在,则提示“用户已存在”,否则执行将UserId置为空(数据库表中该字段已设置自动递增),代码如图所示。

图注册核心代码图

用户登录

登录页,首先传入"username"、"email"、"phone"、"password",用户可通过用户名、邮箱、手机号进行登陆,通过判断resultList来确定查询结果,然后执行查询用户组UserGroup,用户组里面不存在,依然报“用户不存在”,执行完以上代码,最后涉及到用户带有“审核”的,会查询examine_state(用户的审核状态),数据库表user_group中含有source_table和source_field进行查询,以上步骤完成,对输入的密码进行存储Token到数据库,匹对账号和密码,数据库中的AccessToken为令牌,用于身份认证,代码如图所示。

用用户登录核心代码图

修改密码

修改密码,通过请求data,获取旧密码,并将新密码重新赋值,期间都是需要通过加密,代码如图所示。

修改密码核心代码图

修改数据

修改一个数据,原理与add基本一致,不同点在于通过readConfig()读取关键字,以及通过readQuery()获取URL后面?指定位置的标识,转成Map对象后,执行update操作,同样通过拼接的sql语句执行,执行过程读取query,toWhereSql()语句完成数据库操作,body为修改对象的值,代码如图所示。

修改数据核心代码图

删除数据

删除一条数据,通过readQuery(),获取URL后面的对象地址,删除FROM具体的table,query删除查询FindConfig语句,代码如图示。

图4-11删除数据核心代码图

获取列表

通过请求的参数获取列表数据,代码如图所示。

图获取列表核心代码图

图片上传

通过请求的参数获取列表数据,代码如图4-13所示。

图片上传核心代码图

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

更多推荐