作者主页:Java毕设网
简介:Java领域优质创作者、Java项目、学习资料、技术互助
文末获取源码
一、项目介绍
这个项目是一个基于SpringBoot+Vue的校园宿舍管理系统,前后端分离。
主要有超级管理员和宿舍管理员两种角色;
超级管理员权限包括:
首页;
学生宿舍管理:宿舍管理、学生管理、班级管理、宿舍楼管理;
记录:维修记录、晚归记录、请假记录;
系统管理:用户管理、角色管理、菜单管理、日志管理等。
宿舍管理员权限包括:
首页;
学生宿舍管理:宿舍管理、学生管理、班级管理;
记录:维修记录、晚归记录、请假记录;
二、环境需要
1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
4.数据库:MySql 5.7/8.0版本均可;
5.是否Maven项目:是;
三、技术栈
1.后端:SpringBoot+Mysql+redis
2.前端:Vue
四、使用说明
后端项目运行:
1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中application-dev.yaml配置文件中的数据库配置改为自己的配置;
4. 运行项目,控制台提示运行成功后再去运行前端项目;
前端项目运行:
1. 安装好node环境
2. 在dms目录下运行 npm install 安装所需要的包
3. 在dms目录下运行 npm run dev
4. 运行成功后,在浏览器中访问http://localhost:8087,登录账号即可
五、运行截图
六、相关代码
登陆管理控制器
/**
* @author 熊新欣
* @date 2020-12-08
*/
@RestController
@RequestMapping("/login")
public class LoginController {
private final RedisUtil redisUtil;
private final SystemUserService systemUserService;
public LoginController(RedisUtil redisUtil, SystemUserService systemUserService) {
this.redisUtil = redisUtil;
this.systemUserService = systemUserService;
}
@PostMapping("/login")
public Result<String> login(SystemUser user, @RequestParam(value = "redirectUrl") String redirectUrl) {
List<SystemUser> userList = systemUserService.listUserByLoginName(user.getLoginName());
if (userList.size() == 0) {
throw new HttpException(HttpCode.LOGIN_FAILED, "没有此用户");
} else if (userList.size() > 1) {
throw new HttpException(HttpCode.LOGIN_FAILED, "存在多个登录名,请联系管理员");
} else {
SystemUser systemUser = userList.get(0);
if (systemUser.getPassword().equals(MD5Util.md5(user.getPassword()))) {
String token = UUID.randomUUID().toString();
redisUtil.put(token, systemUser.getId());
return Result.<String>ok().add(redirectUrl + "#/token=" + token);
} else {
throw new HttpException(HttpCode.LOGIN_FAILED, "登陆失败,密码错误");
}
}
}
@GetMapping("/logout")
public Result<?> logout(@RequestHeader(HEADER_TOKEN) String token) {
if (redisUtil.hasToken(token)) {
redisUtil.deleteToken(token);
}
return Result.ok();
}
}
宿舍管理控制器
@RestController
@RequestMapping("/room")
public class RoomController {
@Autowired
private RoomService roomService;
@Autowired
private StudentService studentService;
@Autowired
private RedisUtil redisUtil;
@RequirePermission(permissions = {"room:list"})
@PostMapping("/list")
public Result<PageInfo<Room>> list(@RequestBody ListQuery<Room> listQuery, @RequestHeader(Constant.HEADER_TOKEN) String token) {
SystemUser systemUser = redisUtil.exchange(token).orElseThrow(() -> new HttpException(HttpCode.FAILED, "登录用户不存在"));
PageInfo<Room> pageInfo = roomService.list(listQuery, systemUser.getBuildingId());
return Result.<PageInfo<Room>>ok().add(pageInfo);
}
@RequirePermission(permissions = {"room:list"})
@GetMapping("/listAll")
public Result<List<Room>> list(@RequestHeader(Constant.HEADER_TOKEN) String token) {
SystemUser systemUser = redisUtil.exchange(token).orElseThrow(() -> new HttpException(HttpCode.FAILED, "登录用户不存在"));
List<Room> list = roomService.list(systemUser.getBuildingId());
return Result.<List<Room>>ok().add(list);
}
@GetMapping("/query/{id}")
@RequirePermission(permissions = {"room:query"})
public Result<Room> query(@PathVariable("id") Long id) {
Room room = roomService.query(id).orElseThrow(() -> new HttpException(HttpCode.FAILED, "没有该宿舍信息"));
return Result.<Room>ok().add(room);
}
@PostMapping("/saveOrUpdate")
@RequirePermission(permissions = {"room:save", "room:update"})
@Log
public Result<?> saveOrUpdate(@RequestBody @Validated Room room) {
roomService.saveOrUpdate(room);
return Result.ok();
}
@GetMapping("/delete/{id}")
@RequirePermission(permissions = {"room:delete"})
@Log
public Result<?> delete(@PathVariable("id") Long id) {
int count = studentService.countByRoomId(id);
if (count > 0) {
throw new HttpException(HttpCode.FAILED, "该宿舍还有学生, 无法删除");
}
roomService.delete(id);
return Result.ok("删除成功");
}
}