当前全球都在提倡环境保护,现在社会高速发展,我们每个人每天都会产生很多的垃圾,尤其是工业发展到一定阶段之后这些垃圾的种类也越来越多,如果随意丢弃很可能会造成环境污染,尤其是一些电池等重污染垃圾,所以一点要做好垃圾分类,一方面是做好环境保护,另一方面是对可以再次利用的垃圾进行重复利用。

基于java垃圾分类图像识别算法_spring boot


环境需要

1.运行环境:最好是java jdk 1.8,这是目前最稳定的JDK也是被使用最多的JDK版本。

2.IDE环境:IDEA,Eclipse都可以。推荐IDEA;

3.tomcat环境:Tomcat7/Tomcat8/Tomcat9版本均可

4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;

5.数据库:MySql 5.7版本;

6.是否Maven项目:是;

技术栈

后端:Spring+SpringMVC+Mybatis+Springboot

前端:vue+CSS+JavaScript+jQuery+elementui

基于java垃圾分类图像识别算法_基于java垃圾分类图像识别算法_02

垃圾分类网站的主要使用者分为管理员和用户、垃圾分类管理员,实现功能包括管理员:首页、个人中心、用户管理、垃圾分类管理员管理、垃圾分类管理、垃圾类型管理、垃圾图谱管理、系统管理,垃圾分类管理员;首页、个人中心、用户管理、垃圾分类管理员管理、垃圾分类管理、垃圾类型管理、垃圾图谱管理,用户前台;首页、垃圾分类、垃圾图谱、个人中心、后台管理等功能。由于本网站的功能模块设计比较全面,所以使得整个垃圾分类网站信息管理的过程得以实现。

基于java垃圾分类图像识别算法_基于java垃圾分类图像识别算法_03


1.项目内容 本项目利用IDEA,Visual Studio Code 开发工具,借助Mysql,Navicat for MySQL 工具,实现了一个基于springboot+vue的垃圾分类管理系统。系统为两种类型的用户提供服务,用户和管理员。 2.实现功能 (1)登陆功能 通过和数据库建立联系后,数据库内的用户和管理员可在登录页面输入账号和密码登陆网页。 (2)数据的增、查、改、删功能 ① 垃圾的增、查、改、删 ② 管理员的增、查、改、删 ③ 用户的增、查、改、删

基于java垃圾分类图像识别算法_java_04


Springboot代码结构介绍

src:这是用来存放Java源文件。

src/main/ava/com:该包下用来存放相应的Java代码,并根据对应的Java项目继续分层架构

一般分为一下几个软件包

web.xml:主要用来配置,它可以配置Filter、Listener、Servlet等。

pom.xml:作用类似ant的build.xml文件,功能则更强大。该文件用于管理:源代码、配置文件、开发者的信息和角色、问题追踪系统、组织信息、项目授权、项目的url、项目的依赖关系等等。事实上,在Maven的世界中,一个项目可以什么都没有,甚至没有代码,但是必须包含pom.xml文件。

main/webapp:这一层一般是用来放静态资源比如HTML、CSS、图片等文件。

main/webapp/WEB-INF目录下一般存在一下几个包:

controller包:封装类,一般是按照数据库的来写内容的,一个表一个类。

dao:对数据的操作, 主要是对于数据库中的数据做增删改查等操作进行封装

service:业务逻辑层,主要是进行业务判断,也可以进行数据库的事务管理等。

uilt:工具类,可以放各种写好的工具类,要用的调用就好

基于java垃圾分类图像识别算法_java_05

`

/**
• 登录相关
 */
 @RequestMapping(“users”)
 @RestController
 public class UserController{
@Autowired
 private UserService userService;
@Autowired
 private TokenService tokenService;
/**• 登录
 */
 @IgnoreAuth
 @PostMapping(value = “/login”)
 public R login(String username, String password, String captcha, HttpServletRequest request) {
 UserEntity user = userService.selectOne(new EntityWrapper().eq(“username”, username));
 if(user==null || !user.getPassword().equals(password)) {
 return R.error(“账号或密码不正确”);
 }
 String token = tokenService.generateToken(user.getId(),username, “users”, user.getRole());
 return R.ok().put(“token”, token);
 }/**
• 注册
 */
 @IgnoreAuth
 @PostMapping(value = “/register”)
 public R register(@RequestBody UserEntity user){
 // ValidatorUtils.validateEntity(user);
 if(userService.selectOne(new EntityWrapper().eq(“username”, user.getUsername())) !=null) {
 return R.error(“用户已存在”);
 }
 userService.insert(user);
 return R.ok();
 }/**
• 退出
 */
 @GetMapping(value = “logout”)
 public R logout(HttpServletRequest request) {
 request.getSession().invalidate();
 return R.ok(“退出成功”);
 }/**
• 密码重置
 */
 @IgnoreAuth
 @RequestMapping(value = “/resetPass”)
 public R resetPass(String username, HttpServletRequest request){
 UserEntity user = userService.selectOne(new EntityWrapper().eq(“username”, username));
 if(user==null) {
 return R.error(“账号不存在”);
 }
 user.setPassword(“123456”);
 userService.update(user,null);
 return R.ok(“密码已重置为:123456”);
 }/**
• 列表
 */
 @RequestMapping(“/page”)
 public R page(@RequestParam Map<String, Object> params,UserEntity user){
 EntityWrapper ew = new EntityWrapper();
 PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
 return R.ok().put(“data”, page);
 }/**
• 列表
 */
 @RequestMapping(“/list”)
 public R list( UserEntity user){
 EntityWrapper ew = new EntityWrapper();
 ew.allEq(MPUtil.allEQMapPre( user, “user”));
 return R.ok().put(“data”, userService.selectListView(ew));
 }/**
• 信息
 */
 @RequestMapping(“/info/{id}”)
 public R info(@PathVariable(“id”) String id){
 UserEntity user = userService.selectById(id);
 return R.ok().put(“data”, user);
 }/**
• 获取用户的session用户信息
 */
 @RequestMapping(“/session”)
 public R getCurrUser(HttpServletRequest request){
 Long id = (Long)request.getSession().getAttribute(“userId”);
 UserEntity user = userService.selectById(id);
 return R.ok().put(“data”, user);
 }/**
• 保存
 */
 @PostMapping(“/save”)
 public R save(@RequestBody UserEntity user){
 // ValidatorUtils.validateEntity(user);
 if(userService.selectOne(new EntityWrapper().eq(“username”, user.getUsername())) !=null) {
 return R.error(“用户已存在”);
 }
 userService.insert(user);
 return R.ok();
 }/**
• 修改
 */
 @RequestMapping(“/update”)
 public R update(@RequestBody UserEntity user){
 // ValidatorUtils.validateEntity(user);
 userService.updateById(user);//全部更新
 return R.ok();
 }/**
• 删除
 */
 @RequestMapping(“/delete”)
 public R delete(@RequestBody Long[] ids){
 userService.deleteBatchIds(Arrays.asList(ids));
 return R.ok();
 }
 }

  • `
    目录
    1 绪论 1
    1.1课题背景 1
    1.2课题研究现状 1
    1.3初步设计方法与实施方案 2
    1.4本文研究内容 2
    2 系统开发环境 4
    2.1 使用工具简介 4
    2.2 环境配置 4
    2.3 B/S结构简介 4
    2.4 MySQL数据库 5
    2.5 框架介绍 5
    3 系统分析 6
    3.1系统可行性分析 6
    3.1.1经济可行性 6
    3.1.2技术可行性 6
    3.1.3运行可行性 6
    3.2系统现状分析 6
    3.3功能需求分析 7
    3.4系统设计规则与运行环境 8
    3.5系统流程分析 8
    3.5.1操作流程 8
    3.5.2添加信息流程 9
    3.5.3删除信息流程 10
    4 系统设计 11
    4.1系统设计主要功能 11
    4.2数据库设计 11
    4.2.1数据库设计规范 11
    4.2.2 E/R图 11
    4.2.3数据表 12
    5 系统实现 25
    5.1系统功能模块 25
    5.2后台模块 27
    5.2.1管理员功能模块 27
    5.2.2用户功能模块 30
    6 系统测试 33
    6.1功能测试 33
    6.2可用性测试 33
    6.3性能测试 34
    6.4测试结果分析 34
    7结 论 35
    参考文献 36
    致 谢 37