Java项目:教室图书馆预约管理系统(java+SpringBoot+JPA+VUE+Maven+Redis+mysql)

 源码获取:博客首页 "资源" 里下载!

教室预约系统-后台系统

项目简介:

这是一个前后端分离的教室预约和查看系统项目,能够实现以教室为单位活动的预约和取消,能够以视图形式显示,附带图书馆和公告管理器功能。

主要采用`Vue.js`+`SpringBoot` 技术栈开发

使用技术点

* 前端:`Vue`、`ElementUI`、`axios`、`Echart`、`jQurey`
* 后端:`SpringBoot`、`Spring Data + JPA`、`hibernate`、`MySQL`、`Shiro`、`Redis`

使用说明:

1. 在mysql数据库中创建数据库`testmeeting`行项目,将自动注入数据。如需关闭此功能,请将 `application.properties `中的
`spring.datasource.initialization-mode=always` 代码注释。同样,可以通过使用项目`sql`目录下`testmeeting`直接导入数
据库数据结构与内容,可根据需要自行使用。`Redis 端口为 6379(默认端口),密码为空。`

2. 数据库配置在后端项目的 src\main\resources 目录下的application.properties 文件中,mysql 版本为 8.0以上版本 。

3. 在IntelliJ IDEA中运行后端项目,为了保证项目成功运行,可以右键点击 pom.xml 选择 maven -> reimport ,并重启项目。
至此,服务端就启动成功了,同时,运行前端项目,访问 http://localhost:8080 ,即可进入登录页面,默认账号是 admin,密码是 123

4. 项目使用了虹软公司的人脸识别SDK与百度的人体分析SDk:
* 虹软的SDK请自行前往官网获取,获取后建议将SDK导入到``src/main/resources/lib-sdk``目录下,然后在``src/main/java/utils``目录下新建``SdkParameter.java``文件,填入appId和key以及引擎和算法等文件位置。

* 百度人体分析SDk已在``maven``中引用,但是``app_id``等请前往百度云AI开发者平台自行获取,该项目中表示位置为``SdkParameter.java``文件。

* 以上内容不必要,可以删除并注释对应接口与服务即可。
----

二次开发请注意:

* 进入前端项目根目录中,在命令行依次输入如下命令:

```text
# 安装依赖
npm install

# 在 localhost:8080 启动项目
npm run dev
```
* 由于在前端项目中已经配置了端口转发,将数据转发到SpringBoot上,因此项目启动之后,在浏览器中输入 `http://localhost:8080`
就可以访问我们的前端项目了,所有的请求通过端口转发将数据传到 SpringBoot 中(注意此时不要关闭 SpringBoot 项目)。

* 最后可以用 IDEA / WebStorm 等工具打开前端项目,继续开发,开发完成后,当项目要上线时,依然进入到 wj-vue 目录,然后执行如下命令:
```text
npm run build
```

* 该命令执行成功之后,前端项目目录下生成一个 `dist` 文件夹,可以将该文件夹中的两个文件` static `和 `index.html`
拷贝到前端项目中 `resources/static/ `目录下,然后直接运行前端项目,访问 `http://localhost:8443` ,

实际上是把前端打包后作为静态文件,但不推荐使用这种方式。

 

 

 

 

 

 

后台用户管理控制器:

/**
 * 后台用户管理控制器
 * @author yy
 *
 */
@RequestMapping("/admin/user")
@Controller
public class UserController {

	@Autowired
	private UserService userService;
	@Autowired
	private RoleService roleService;
	@Autowired
	private OperaterLogService operaterLogService;
	/**
	 * 用户列表页面
	 * @param model
	 * @param user
	 * @param pageBean
	 * @return
	 */
	@RequestMapping(value="/list")
	public String list(Model model,User user,PageBean<User> pageBean){
		model.addAttribute("title", "用户列表");
		model.addAttribute("username", user.getUsername());
		model.addAttribute("pageBean", userService.findList(user, pageBean));
		return "admin/user/list";
	}
	
	/**
	 * 新增用户页面
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/add",method=RequestMethod.GET)
	public String add(Model model){
		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);
		}
		//判断用户名是否存在
		if(userService.isExistUsername(user.getUsername(), 0l)){
			return Result.error(CodeMsg.ADMIN_USERNAME_EXIST);
		}
		//到这说明一切符合条件,进行数据库新增
		if(userService.save(user) == null){
			return Result.error(CodeMsg.ADMIN_USE_ADD_ERROR);
		}
		operaterLogService.add("添加用户,用户名:" + user.getUsername());
		return Result.success(true);
	}
	
	/**
	 * 用户编辑页面
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/edit",method=RequestMethod.GET)
	public String edit(Model model,@RequestParam(name="id",required=true)Long id){
		model.addAttribute("roles", roleService.findByType(Role.ADMIN_ROLE_TYPE_ADMIN));
		model.addAttribute("user", userService.find(id));
		return "admin/user/edit";
	}
	
	/**
	 * 编辑用户信息表单提交处理
	 * @param user
	 * @return
	 */
	@RequestMapping(value="/edit",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> edit(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);
		}
		if(user.getId() == null || user.getId().longValue() <= 0){
			return Result.error(CodeMsg.ADMIN_USE_NO_EXIST);
		}
		if(userService.isExistUsername(user.getUsername(), user.getId())){
			return Result.error(CodeMsg.ADMIN_USERNAME_EXIST);
		}
		//到这说明一切符合条件,进行数据库保存
		User findById = userService.find(user.getId());
		//讲提交的用户信息指定字段复制到已存在的user对象中,该方法会覆盖新字段内容
		BeanUtils.copyProperties(user, findById, "id","createTime","updateTime");
		if(userService.save(findById) == null){
			return Result.error(CodeMsg.ADMIN_USE_EDIT_ERROR);
		}
		operaterLogService.add("编辑用户,用户名:" + user.getUsername());
		return Result.success(true);
	}
	
	/**
	 * 删除用户
	 * @param id
	 * @return
	 */
	@RequestMapping(value="/delete",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
		try {
			userService.delete(id);
		} catch (Exception e) {
			return Result.error(CodeMsg.ADMIN_USE_DELETE_ERROR);
		}
		operaterLogService.add("删除用户,用户ID:" + id);
		return Result.success(true);
	}
}

后台角色管理控制器: 

/**
 * 后台角色管理控制器
 * @author yy
 *
 */
@RequestMapping("/admin/role")
@Controller
public class RoleController {

	
	private Logger log = LoggerFactory.getLogger(RoleController.class);
	
	@Autowired
	private MenuService menuService;
	
	@Autowired
	private OperaterLogService operaterLogService;
	
	@Autowired
	private RoleService roleService;
	
	/**
	 * 分页搜索角色列表
	 * @param model
	 * @param role
	 * @param pageBean
	 * @return
	 */
	@RequestMapping(value="/list")
	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";
	}
	
	/**
	 * 角色添加表单提交处理
	 * @param role
	 * @return
	 */
	@RequestMapping(value="/add",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> add(Role role){
		//用统一验证实体方法验证是否合法
		CodeMsg validate = ValidateEntityUtil.validate(role);
		if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
			return Result.error(validate);
		}
		if(roleService.save(role) == null){
			return Result.error(CodeMsg.ADMIN_ROLE_ADD_ERROR);
		}
		log.info("添加角色【"+role+"】");
		operaterLogService.add("添加角色【"+role.getName()+"】");
		return Result.success(true);
	}
	
	/**
	 * 角色编辑页面
	 * @param id
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/edit",method=RequestMethod.GET)
	public String edit(@RequestParam(name="id",required=true)Long id,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));
		Role role = roleService.find(id);
		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());
		if(roleService.save(existRole) == null){
			return Result.error(CodeMsg.ADMIN_ROLE_EDIT_ERROR);
		}
		log.info("编辑角色【"+role+"】");
		operaterLogService.add("编辑角色【"+role.getName()+"】");
		return Result.success(true);
	}
	
	/**
	 * 删除角色
	 * @param request
	 * @param id
	 * @return
	 */
	@RequestMapping(value="delete",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
		try {
			roleService.delete(id);
		} 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
     * @param idNumber
     * @return
     */
    @RequestMapping(value = "/login", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> login(String mobile,String password) {
        //验证格式是否正确
        if (StringUtils.isEmpty(password)){
            return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_ERROR);
        }

        //验证手机号
        People byMobilePeople = peopleService.findByMobile(mobile);
        if (byMobilePeople == null) {
            return Result.error(CodeMsg.HOME_LOGIN_NO_EXIST);
        }

        //比对密码
        if (!byMobilePeople.getPassword().equals(password)) {
            return Result.error(CodeMsg.HOME_LOGIN_PASSOWRD1_NO_EXIST);
        }

        //登录成功将信息放入Session中
        if (null != byMobilePeople.getMemberExpirationTime()){
            String strMemberExpirationTime = StringUtil.dateToStrLong(byMobilePeople.getMemberExpirationTime());
            if (StringUtil.dateCompare(strMemberExpirationTime)){
                byMobilePeople.setMemberExpirationTime(null);
            }
        }
        SessionUtil.set(SessionConstant.SESSION_HOME_USER_LOGIN_KEY, byMobilePeople);
        SessionUtil.set(SessionConstant.SESSION_HOME_ITEM_RESERVE_KEY,itemReserveService.selByPeopleIdAndNow(byMobilePeople.getId()));
        SessionUtil.set(SessionConstant.SESSION_HOME_STAFF_RESERVE_KEY,staffReserveService.selByPeopleAndNow(byMobilePeople.getId()));
        SessionUtil.set(SessionConstant.SESSION_HOME_PAY_LOG_KEY,payOrderLogService.findByPeopleIdAndStatusOrderByCreateTimeDesc(byMobilePeople.getId(),PayOrderLog.PAY_STATUS_PAID));

        List<Vip> allVip = vipService.findAll();
        if (null != allVip && !allVip.isEmpty()){
            SessionUtil.set(SessionConstant.SESSION_VIP_KEY,allVip.get(0));
        }else {
            SessionUtil.set(SessionConstant.SESSION_VIP_KEY,null);
        }
        return Result.success(true);
    }

    /**
     * 忘记密码
     * @param mobile
     * @return
     */
    @RequestMapping(value = "/updatePassword", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> updatePassword(String mobile,String password,String passwordNew,String idNumber) {
        //验证格式是否正确
        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 byMobilePeople = peopleService.findByMobile(mobile);
        if (byMobilePeople == null) {
            return Result.error(CodeMsg.HOME_LOGIN_NO_EXIST);
        }

        if (!byMobilePeople.getIdNumber().equals(idNumber)){
            return Result.error(CodeMsg.HOME_LOGIN_IDNUMBER_NO_EXIST);
        }

        if (!password.equals(passwordNew)){
            return Result.error(CodeMsg.HOME_LOGIN_PASSWORD_EQ_ERROR);
        }

        byMobilePeople.setPassword(passwordNew);

        if (peopleService.save(byMobilePeople) == null){
            return Result.error(CodeMsg.HOME_UPDATE_PASSOWRD1_NO_EXIST);
        }

        return Result.success(true);
    }

    /**
     * 修改密码
     * @return
     */
    @RequestMapping(value = "/updatePasswordUp", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> updatePasswordUp(String formerPassword,String password,String passwordNew) {
        //验证格式是否正确
        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){
            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);
            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";
    }


}

 源码获取:博客首页 "资源" 里下载!

猜你喜欢

转载自blog.csdn.net/yuyecsdn/article/details/124129379
今日推荐