Java项目实战II基于Java+Spring Boot+MySQL的大学城水电管理系统(源码+数据库+文档)

news/2024/9/29 12:30:04 标签: java, 开发语言, 数据库, spring boot, mysql, maven, intellij-idea

目录

一、前言

二、技术介绍

三、系统实现

四、文档参考

五、核心代码

六、源码获取


全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者

一、前言

随着大学城规模的不断扩大和学生数量的急剧增加,大学城内的水电管理面临着前所未有的挑战。传统的人工管理模式不仅效率低下,而且难以准确追踪和统计水电使用情况,导致资源浪费和费用管理混乱。因此,开发一套高效、智能的水电管理系统显得尤为重要。本系统基于Java语言,结合Spring Boot框架的便捷性和MySQL数据库的稳定性,设计并实现了一套大学城水电管理系统。该系统能够实时监控水电使用情况,自动记录并生成详细的报表,极大地提高了管理效率,减少了资源浪费,为大学城提供了更加科学、规范的水电管理解决方案。

二、技术介绍

语言:Java
使用框架:Spring Boot
前端技术:JS、Vue 、css3
开发工具:IDEA/Eclipse
数据库:MySQL 5.7/8.0
数据库管理工具:phpstudy/Navicat
JDK版本:jdk1.8
Maven: apache-maven 3.8.1-bin
前端环境:Node.Js 12\14\16

三、系统实现

领用设备管理
大学城水电管理系统的系统管理员可以管理领用设备,可以对领用设备信息添加修改删除以及查询操作。具体界面的展示如图5.1所示。

消耗设备管理
系统管理员可以查看对消耗设备信息进行添加,修改,删除以及查询操作。具体界面如图5.2所示。

设备申请管理
系统管理员可以对设备申请进行审核操作。界面如下图所示:

状态汇报管理
系统管理员可以对状态汇报进行审核操作。界面如下图所示:

用户模块的实现
设备申请
用户可以进行设备申请操作。界面如下图所示:

状态汇报
用户可以对状态汇报进行添加,修改,删除操作。界面如下图所示:

用户反馈
用户可以对用户反馈进行添加修改删除操作。界面如下图所示:

四、文档参考

五、核心代码

@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<UserEntity>().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<UserEntity>().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<UserEntity>().eq("username", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
    	user.setPassword("123456");
        userService.update(user,null);
        return R.ok("密码已重置为:123456");
    }
 
	/**
     * 列表
     */
    @RequestMapping("/list")
    public R list( UserEntity user){
       	EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
      	ew.allEq(MPUtil.allEQMapPre( user, "user")); 
        return R.ok().put("data", userService.selectListView(ew));
    }
 
    /**
     * 保存
     */
    @PostMapping("/save")
    public R save(@RequestBody UserEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().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();
    }
}

六、源码获取

 感谢大家点赞、收藏、关注、评论啦 


http://www.niftyadmin.cn/n/5683023.html

相关文章

linux中的软件包格式与库文件

在 Ubuntu&#xff08;以及其他基于 Debian 的系统&#xff09;上&#xff0c;软件包通常以 预编译的二进制形式 提供&#xff0c;这样用户无需从源代码编译即可安装和使用软件。然而&#xff0c;即使软件包是预编译的&#xff0c;安装后您仍然会在文件系统中看到与该软件相关的…

使用 Light Chaser 进行大屏数据可视化

引言 在当今数据驱动的世界中&#xff0c;数据可视化变得越来越重要。Light Chaser 是一款基于 React 技术栈的大屏数据可视化设计工具&#xff0c;通过简单的拖拽操作&#xff0c;你可以快速生成漂亮、美观的数据可视化大屏和看板。本文将介绍如何使用 Light Chaser 进行数据…

MySQL实现按分秒统计数据量

在MySQL中&#xff0c;统计每秒、每分钟、每5分钟、每10分钟、每30分钟的交易量可以通过使用 GROUP BY 和 MySQL 的时间处理函数来实现。假设交易记录表名为 transactions&#xff0c;交易时间字段为 transaction_time&#xff0c;并统计每个时间段的交易量。 1. 每秒交易量 …

阿里旗下的AI搜索工具来了~心流小助手

随着人工智能技术的飞速发展&#xff0c;越来越多的AI工具被应用于日常生活之中。阿里巴巴集团紧跟时代潮流&#xff0c;近期推出了一款名为“心流小助手”的AI搜索工具&#xff0c;旨在为科研工作者、大学教师及学生等专业用户提供高效便捷的信息检索服务。 心流小助手简介 …

[论文阅读] ChartInstruct: Instruction Tuning for Chart Comprehension and Reasoning

原文链接&#xff1a;http://arxiv.org/abs/2403.09028 源码链接&#xff1a;https://github.com/vis-nlp/ChartInstruct 启发&#xff1a;本文构建的instruction-tuning数据集以及使用该数据集对模型进行微调的过程都值得学习。 Abstract 研究对象&#xff1a;图表 研究…

代码随想录_刷题记录_第四次

二叉树 — 理论基础 种类&#xff1a; 满二叉树&#xff08;所有层的节点都是满的&#xff0c;k&#xff1a;深度 节点数量&#xff1a;2^k - 1&#xff09;完全二叉树&#xff08;除了最后一层&#xff0c;其余层全满&#xff0c;并且最后一层从左到右连续&#xff09;二叉搜…

以太网交换安全:MAC地址表安全

一、MAC地址表安全 MAC地址表安全是网络安全中的一个重要方面&#xff0c;它涉及到网络设备的MAC地址表的管理和保护。以下是对MAC地址表安全的详细介绍&#xff1a; &#xff08;1&#xff09;基本概念 定义&#xff1a;MAC地址表是网络设备&#xff08;如交换机&#xff0…

Pytorch 学习手册

零 相关资料 官方网址 官方网址下的API搜索网站 一 定义 深度学习框架是用于设计、训练和部署深度学习模型的软件工具包。这些框架提供了一系列预定义的组件&#xff0c;如神经网络层&#xff08;卷积层、全连接层等&#xff09;、损失函数、优化器以及数据处理工具&#xf…