功能介绍
用户端功能
注册登录:用户可以注册新账户,并通过账号密码登录系统。
监管页面首页:展示系统的基本信息,包括最新的污染信息、治理进展和新闻咨询。
发帖栏:用户可发布有关环境监督的帖子,包括但不限于污染报告和治理建议。
污染信息:用户可查看不同地区的污染信息,包括污染类型、程度和具体位置。
污染分类:系统根据污染类型(水污染、空气污染等)分类展示污染信息。
治理信息:用户可查看当前的治理措施、治理效果及负责的部门或组织。
治理记录:记录并展示过往的治理案例,包括治理前后的对比。
部门决策:展示环保部门的决策信息,包括决策内容、实施方案等。
新闻咨询:提供环境保护和污染治理相关的最新新闻和资讯。
我的收藏:用户可以收藏感兴趣的帖子、新闻或污染信息等,便于后续查看。
管理员端功能
首页数据可视化:展示重要数据和统计信息,如污染趋势、治理效果等,通过图表形式直观展现。
登录:管理员登录。
用户管理:管理系统用户,包括添加、删除、编辑用户信息等。
系统管理:系统基本设置,如系统维护、更新日志等。
权限管理:分配和管理用户权限,确保系统的安全和有效运行。
污染信息管理:管理污染信息的发布、编辑和删除。
污染分类管理:管理污染信息的分类,包括添加、编辑和删除分类。
意见信息管理:管理用户反馈的意见信息,包括查看、回复和删除。
污染治理管理:管理污染治理的各项措施,包括发布治理方案、监督实施过程等。
新闻资讯管理:管理环保新闻和资讯的发布、编辑和删除。
治理信息管理:管理治理信息的发布、编辑和删除,确保信息的及时性和准确性。
系统实现截图
springboot文件解析
Spring Boot 是 Spring 家族中的一个全新的框架,它用来简化Spring应用程序的创建和开发过程。也可以说 Spring Boot 能简化我们之前采用SSM(Spring MVC + Spring + MyBatis )框架进行开发的过程。config:主要用来存储配置文件,以及其他不怎么动用的信息
controller:项目的主要控制文件
dao: 主要用来操作数据库
entity: 实体,用来放与数据库表里对应的实体类,表中的字段对应类中的属性值,并附有set/get方法
exception:异常处理类
service:主要实现的方法
—impl 实现类
接口:尚未实现的方法,在对应的ipml中实现
util: 工具类
application.properties:项目配置信息
技术介绍
技术范围:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。
jdk版本:jdk1.8+
前端:vue.js+ElementUI
开发工具:IDEA 或者eclipse都支持
编程语言: java
框架支持:springboot/ssm/springcloud分布式微服务
数据库: mysql 版本不限
数据库工具:Navicat/SQLyog都可以
开发步骤编译运行
(1) 创建好数据库并导入,
(2) 创建后台Springboot三层架构(controller,service,mapper层)并启动测试
(3) 导入并编译前端代码vue:网站和后台管理
编译:npm install
试运行:npm run dev
核心代码部分展示
@RequestMapping("users")
@RestController
public class UsersController{
@Autowired
private UsersService userService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@PostMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().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 UsersEntity user){
if(userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
if(user==null) {
return R.error("账号不存在");
}
user.setPassword("123456");
userService.update(user,null);
return R.ok("密码已重置为:123456");
}
/**
* 退出
*/
@GetMapping(value = "logout")
public R logout(HttpServletRequest request) {
request.getSession().invalidate();
return R.ok("退出成功");
}
/**
详细视频演示
请联系我获取更详细的演示视频
源码获取
文章下方名片联系我即可~