教室预约系统-后台系统
项目简介:
这是一个前后端分离的教室预约和查看系统项目,能够实现以教室为单位活动的预约和取消,能够以视图形式显示,附带图书馆和公告管理器功能。
主要采用Vue.js
+SpringBoot
技术栈开发
使用技术点
- 前端:
Vue
、ElementUI
、axios
、Echart
、jQurey
- 后端:
SpringBoot
、Spring Data + JPA
、hibernate
、MySQL
、Shiro
、Redis
使用说明:
-
在mysql数据库中创建数据库
testmeeting
行项目,将自动注入数据。如需关闭此功能,请将application.properties
中的
spring.datasource.initialization-mode=always
代码注释。同样,可以通过使用项目sql
目录下testmeeting
直接导入数
据库数据结构与内容,可根据需要自行使用。Redis 端口为 6379(默认端口),密码为空。
-
数据库配置在后端项目的 src\main\resources 目录下的application.properties 文件中,mysql 版本为 8.0以上版本 。
-
在IntelliJ IDEA中运行后端项目,为了保证项目成功运行,可以右键点击 pom.xml 选择 maven -> reimport ,并重启项目。
至此,服务端就启动成功了,同时,运行前端项目,访问 http://localhost:8080 ,即可进入登录页面,默认账号是 admin,密码是 123 -
项目使用了虹软公司的人脸识别SDK与百度的人体分析SDk:
-
虹软的SDK请自行前往官网获取,获取后建议将SDK导入到
src/main/resources/lib-sdk
目录下,然后在src/main/java/utils
目录下新建SdkParameter.java
文件,填入appId和key以及引擎和算法等文件位置。 -
百度人体分析SDk已在
maven
中引用,但是app_id
等请前往百度云AI开发者平台自行获取,该项目中表示位置为SdkParameter.java
文件。 -
以上内容不必要,可以删除并注释对应接口与服务即可。
二次开发请注意:
- 进入前端项目根目录中,在命令行依次输入如下命令:
# 安装依赖
npm install
# 在 localhost:8080 启动项目
npm run dev
-
由于在前端项目中已经配置了端口转发,将数据转发到SpringBoot上,因此项目启动之后,在浏览器中输入
http://localhost:8080
就可以访问我们的前端项目了,所有的请求通过端口转发将数据传到 SpringBoot 中(注意此时不要关闭 SpringBoot 项目)。 -
最后可以用 IDEA / WebStorm 等工具打开前端项目,继续开发,开发完成后,当项目要上线时,依然进入到 wj-vue 目录,然后执行如下命令:
npm run build
- 该命令执行成功之后,前端项目目录下生成一个
dist
文件夹,可以将该文件夹中的两个文件static
和index.html
拷贝到前端项目中resources/static/
目录下,然后直接运行前端项目,访问http://localhost:8443
,
实际上是把前端打包后作为静态文件,但不推荐使用这种方式。
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
/**
* 角色修改表单提交处理
* @param role
* @return
*/
@RequestMapping(value="/edit",method=RequestMethod.POST)
@ResponseBody
public Result<Boolean> edit(Role role){
//用统一验证实体方法验证是否合法
CodeMsg validate = ValidateEntityUtil.validate(role);
if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
return Result.error(validate);
}
model.addAttribute("role", role);
model.addAttribute("authorities",JSONArray.toJSON(role.getAuthorities()).toString());
return "admin/role/edit";
}
/**
* 角色修改表单提交处理
* @param role
* @return
*/
@RequestMapping(value="/edit",method=RequestMethod.POST)
@ResponseBody
public Result<Boolean> edit(Role role){
//用统一验证实体方法验证是否合法
CodeMsg validate = ValidateEntityUtil.validate(role);
if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
return Result.error(validate);
}
Role existRole = roleService.find(role.getId());
if(existRole == null){
return Result.error(CodeMsg.ADMIN_ROLE_NO_EXIST);
}
existRole.setName(role.getName());
existRole.setRemark(role.getRemark());
existRole.setStatus(role.getStatus());
existRole.setAuthorities(role.getAuthorities());
existRole.setType(role.getType());
return Result.error(CodeMsg.HOME_LOGIN_NO_EXIST);
}
if (!formerPassword.equals(homePeople.getPassword())){
return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_EQ1_ERROR);
}
if (!password.equals(passwordNew)){
return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_EQ_ERROR);
}
homePeople.setPassword(passwordNew);
if (peopleService.save(homePeople) == null){
return Result.error(CodeMsg.HOME_UPDATE_PASSOWRD11_NO_EXIST);
}
return Result.success(true);
}
/**
* 退出
* @return
*/
@RequestMapping(value = "/logout")
public String logout() {
People homePeople = SessionUtil.getHomePeople();
if(homePeople != null){
SessionUtil.set(SessionConstant.SESSION_HOME_USER_LOGIN_KEY, null);
if (StringUtils.isEmpty(formerPassword)){
return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_ERROR);
}
//验证格式是否正确
if (StringUtils.isEmpty(password)){
return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_ERROR);
}
//验证格式是否正确
if (StringUtils.isEmpty(passwordNew)){
return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_ERROR);
}
People homePeople = SessionUtil.getHomePeople();
if (homePeople == null) {
return Result.error(CodeMsg.HOME_LOGIN_NO_EXIST);
}
if (!formerPassword.equals(homePeople.getPassword())){
return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_EQ1_ERROR);
}
if (!password.equals(passwordNew)){
return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_EQ_ERROR);
}
homePeople.setPassword(passwordNew);
if (peopleService.save(homePeople) == null){
public String list(Model model,Role role,PageBean<Role> pageBean){
model.addAttribute("title", "角色列表");
model.addAttribute("name", role.getName());
model.addAttribute("pageBean", roleService.findByName(role, pageBean));
return "admin/role/list";
}
/**
* 角色添加页面
* @param model
* @return
*/
@RequestMapping(value="/add",method=RequestMethod.GET)
public String add(Model model){
List<Menu> findAll = menuService.findAll();
model.addAttribute("topMenus",MenuUtil.getTopMenus(findAll));
model.addAttribute("secondMenus",MenuUtil.getSecondMenus(findAll));
model.addAttribute("thirdMenus",MenuUtil.getThirdMenus(findAll));
return "admin/role/add";
}
*/
@RequestMapping(value = "/logout")
public String logout() {
People homePeople = SessionUtil.getHomePeople();
if(homePeople != null){
SessionUtil.set(SessionConstant.SESSION_HOME_USER_LOGIN_KEY, null);
SessionUtil.set(SessionConstant.SESSION_VIP_KEY,null);
SessionUtil.set(SessionConstant.SESSION_HOME_ITEM_RESERVE_KEY,null);
SessionUtil.set(SessionConstant.SESSION_HOME_STAFF_RESERVE_KEY,null);
}
return "redirect:/home/index/index";
}
}
后台用户管理控制器:
/**
* 角色添加页面
* @param model
* @return
*/
@RequestMapping(value="/add",method=RequestMethod.GET)
public String add(Model model){
List<Menu> findAll = menuService.findAll();
model.addAttribute("topMenus",MenuUtil.getTopMenus(findAll));
model.addAttribute("secondMenus",MenuUtil.getSecondMenus(findAll));
model.addAttribute("thirdMenus",MenuUtil.getThirdMenus(findAll));
return "admin/role/add";
}
}
return Result.success(true);
}
/**
* 退出
* @return
*/
@RequestMapping(value = "/logout")
public String logout() {
People homePeople = SessionUtil.getHomePeople();
if(homePeople != null){
SessionUtil.set(SessionConstant.SESSION_HOME_USER_LOGIN_KEY, null);
SessionUtil.set(SessionConstant.SESSION_VIP_KEY,null);
SessionUtil.set(SessionConstant.SESSION_HOME_ITEM_RESERVE_KEY,null);
SessionUtil.set(SessionConstant.SESSION_HOME_STAFF_RESERVE_KEY,null);
}
return "redirect:/home/index/index";
}
}
} catch (Exception e) {
// TODO: handle exception
return Result.error(CodeMsg.ADMIN_ROLE_DELETE_ERROR);
}
log.info("编辑角色ID【"+id+"】");
operaterLogService.add("删除角色ID【"+id+"】");
return Result.success(true);
}
}
前台登录管理系统:
@Controller
@RequestMapping("/home/login")
public class HomeLoginController {
@Autowired
private PeopleService peopleService;
@Autowired
private ItemReserveService itemReserveService;
@Autowired
private StaffReserveService staffReserveService;
@Autowired
private VipService vipService;
@Autowired
private PayOrderLogService payOrderLogService;
/**
* 登录
* @param mobile
model.addAttribute("roles", roleService.findByType(Role.ADMIN_ROLE_TYPE_ADMIN));
return "admin/user/add";
}
/**
* 用户添加表单提交处理
* @param user
* @return
*/
@RequestMapping(value="/add",method=RequestMethod.POST)
@ResponseBody
public Result<Boolean> add(User user){
//用统一验证实体方法验证是否合法
CodeMsg validate = ValidateEntityUtil.validate(user);
if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
return Result.error(validate);
}
if(user.getRole() == null || user.getRole().getId() == null){
return Result.error(CodeMsg.ADMIN_USER_ROLE_EMPTY);
}
//判断用户名是否存在