基于javaweb的自习室图书馆座位预约管理系统(java+ssm+jsp+easyui+mysql)

运行环境

Java≥8、MySQL≥5.7、Tomcat≥8

开发工具

eclipse/idea/myeclipse/sts等均可配置运行

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的自习室图书馆座位预约管理系统(java+SSM+JSP+easyUI+mysql)

项目介绍

一款由jsp+ssm+mysql实现的图书馆预约占座管理系统,前端采用的是当下最流行的easyui框架,后台用的ssm(spring、springMVC、mybaits)框架.添加学生和教师时会自动在用户表中注册,定时任务会定时生成座位信息,阅览室分类中可设置信用等级,学生被扣分后信用等级低于相应的值后不能预约相应的阅览室座位.本项目分为管理员、教师、学生三种角色。

管理员角色包含以下功能: 管理员登陆,用户管理,师生信息管理,阅览室管理,信用积分管理,交流管理,信息统计,图书推荐等功能。

教师角色包含以下功能: 教师角色登陆,个人信息管理,管理学生的信用积分等功能。

学生角色包含以下功能: 学生账号登陆,阅览室信息查看,信息积分查看,选座位,选座管理,通知信息管理,信息交流,图书推荐等功能。

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;  5.数据库:MySql 5.7版本; 6.是否Maven项目:否;

技术栈

  1. 后端:Spring+SpringMVC+Mybatis 2. 前端:JSP+easyUI

使用说明

  1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件; 2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行; 3. 将项目中config.properties配置文件中的数据库配置改为自己的配置; 4. 运行项目,输入localhost:8080/ 登录

用户管理控制层:

@Controller

public class UserController {

@Autowired

UserServiceImpl userService;

/*

  • queryUserlike 通过用户姓名进行模糊查询

  • */

@GetMapping(“/queryUserlike/{username}”)

@ResponseBody

public Msg queryUserlikeId(@RequestParam(value = “pn”,defaultValue = “1”) Integer pn,

@PathVariable(“username”) String username){

PageHelper.startPage(pn,20);

List users = userService.queryByUserName(username);

PageInfo page=new PageInfo(users,5);

return Msg.success().add(“pageInfo”,page);

/*

  • 前端发送请求后端分页数据,

  • */

@GetMapping(“/userTables”)

@ResponseBody

public Msg userTables(@RequestParam(value = “pn”,defaultValue = “1”) Integer pn){

PageHelper.startPage(pn,7);

List users = userService.getAll();

PageInfo page=new PageInfo(users,5);

return Msg.success().add(“pageInfo”,page);

//到tables页面

@RequestMapping(“/usertables”)

public String toUserTables(Map<String,Object> map){

List users = userService.getAll();

map.put(“users”,users);

return “Tables”;

//点击编辑按键传入userid查询用户,返回用户信息

@GetMapping(“/queryUserByID/{userid}”)

@ResponseBody

public Msg queryUserID(@PathVariable(“userid”) Integer userid,Map<String,Object> map){

User users = userService.getUserByID(userid);

return Msg.success().add(“users”,users);

/*

  • 查询全部用户

*/

/*@GetMapping(“/user22”)

public String getAllUser(Map<String,Object> map){

List users = userService.getAll();

map.put(“users”,users);

return “Dashboard”;

}*/

/*

  • 用户删除请求

*/

@DeleteMapping(value = “/user/{ids}”)

@ResponseBody

public Msg delEmp(@PathVariable(“ids”) String ids) {

if(ids.contains(“-”)) {

List delids = new ArrayList();

String[] split = ids.split(“-”);

for (String string : split) {

delids.add(Integer.parseInt(string));

userService.batchUser(delids);

}else {

int id = Integer.parseInt(ids);

userService.deleteUser(id);

return Msg.success();

/*

  • 用户更新

*/

@PutMapping(value = “/user/{userID}”)

@ResponseBody

public Msg saveEmp(User user) {

System.out.println(user);

userService.updateUser(user);

return Msg.success();

/*

  • 根据用户ID查询结果

*/

@GetMapping(value = “user/{id}”)

@ResponseBody

public Msg getEmp(@PathVariable(value = “id”)Integer userID) {

User user = userService.getUserByID(userID);

return Msg.success().add(“user”, user);

/*

  • 检查用户名是否可用

*/

@RequestMapping(value = “/checkAddUser”)

@ResponseBody

public Msg checkAddUser(@RequestParam(“username”)String userName) {

//先判断用户名是否合法的表达式

String regex = “(1{6,16})∣([u2E80−u9FFF]+)|(^[\\u2E80-\\u9FFF]+)∣([u2E80−u9FFF]+)”;

boolean c = userName.matches(regex);

if(!c) {

return Msg.fail().add(“va_msg”, “用户名可以是2-5位中文,或者6-16位英文和数字的组合”);

//数据库用户名重复校验

boolean b = userService.checkUserName(userName);

if(b) {

return Msg.success().add(“va_msg”, “用户名可用”);

}else {

return Msg.fail().add(“va_msg”, “用户名已存在”);

/校验手机号码格式/

@RequestMapping(“/checkAddTel”)

@ResponseBody

public Msg checkAddTel(@RequestParam(value = “usertel”)String userTel1) {

String userTel = userTel1.trim();

String regex = “(^1\d{10}$)”;

boolean matches = userTel.matches(regex);

if(matches == true){

return Msg.success().add(“va_msg”,“”);

}else{

return Msg.fail().add(“va_msg”,“手机号必须以1开头,11位的数字!”);

/校验年龄码格式/

@RequestMapping(“/checkAddAge”)

@ResponseBody

public Msg checkAddAge(@RequestParam(value = “userage”)Integer userAge1) {

String s = userAge1.toString();

String userTel = s.trim();

String regex = “(^\d{1,3}$)”;

boolean matches = userTel.matches(regex);

if(matches == true){

return Msg.success().add(“va_msg”,“”);

}else{

return Msg.fail().add(“va_msg”,“请输入数字”);

/校验密码格式/

@RequestMapping(“/checkAddPwd”)

@ResponseBody

public Msg checkAddPwd(@RequestParam(value = “userpwd”)String userPwd1) {

String userPwd = userPwd1.trim();

String regex = “(2{6,16}$)”;

boolean matches = userPwd.matches(regex);

if(matches == true){

return Msg.success().add(“va_msg”,“”);

}else{

return Msg.fail().add(“va_msg”,“密码格式不正确:必须超过6位,小于16位的英文和数字!”);

/*******************************************插入

  • 点击保存按钮,新增用户

  • */

@PostMapping(“/insertUser”)

@ResponseBody

public Msg insertUser(User user){

user.setUserid(null);

userService.insertUser(user);

return Msg.success().add(“va_msg”,“插入成功!”);

//点击更新按钮,更新修改的数据

@PutMapping(“/updateUser”)

@ResponseBody

public Msg updateUser(User user){

userService.updateUser(user);

return Msg.success().add(“va_msg”,“插入成功!”);

//用户删除

@DeleteMapping(“/deleteUser/{userid}”)

@ResponseBody

public Msg deleteEmployee(@PathVariable(“userid”) Integer userid){

boolean b = userService.deleteUser(userid);

if (b){

return Msg.success().add(“va_msg”,“用户删除成功!”);

}else {

return Msg.fail().add(“va_msg”,“用户删除失败!”);

/*

  • 前端ajax请求,查询userid是否在表中存在

  • */

@GetMapping(“/checkUserID”)

@ResponseBody

public Msg checkUserID(@RequestParam(“userid”) Integer userid){

boolean b = userService.checkUserID(userid);

if(b){

return Msg.success().add(“va_msg”,“用户名存在!”);

}else {

return Msg.fail().add(“va_msg”,“用户名不存在,重新输入!”);

预约作为管理控制层:

@Controller

public class SeatResverController {

@Autowired

SeatResverServiceImpl seatResverService;

/*

  • 点击预约信息的提交按钮,保存该预约信息

  • */

@PostMapping(“/insertSeatResver”)

@ResponseBody

public Msg insertSeatResver(SeatResver seatResver,@RequestParam(“status”) String status){

seatResver.setResverid(null);

seatResverService.insertSeatResver(seatResver,status);

return Msg.success().add(“va_msg”,“预约座位信息插入成功!”);

/*

  • 点击预约信息的提交按钮,校验该用户是否已经预约

  • */

@GetMapping(“/checkSeatResverUserID/{userid}”)

@ResponseBody

public Msg checkSeatResverUserID(@PathVariable(“userid”) Integer userid){

boolean b = seatResverService.checkUserID(userid);

if (b){

return Msg.fail().add(“va_msg”,“该用户已预约或已上座,请重新输入!”);

}else {

return Msg.success().add(“va_msg”,“”);

/*

  • 点击取消按钮,删除预约信息(根据座位号)

  • */

@DeleteMapping(“/deleteSeatResver/{seatid}”)

@ResponseBody

public Msg deleteSeatResver(@PathVariable(“seatid”) Integer seatid){

boolean b = seatResverService.deleteSeatResver(seatid);

if (b){

return Msg.success().add(“va_msg”,“删除预约信息成功!”);

}else {

return Msg.fail().add(“va_msg”,“删除预约信息失败!”);

/*

  • 获取全部预约信息,返回到前端展示再页面中

  • */

@GetMapping(“/getSeatResverInfo”)

@ResponseBody

public Msg getSeatResverInfo(@RequestParam(value = “pn”,defaultValue = “1”)Integer pn){

PageHelper.startPage(pn,6);

List all = seatResverService.getAll();

PageInfo page=new PageInfo(all,5);

return Msg.success().add(“pageInfo”,page);

/*

  • 模糊查询,seatid

  • */

@GetMapping(“/querySeatlike/{seatid}”)

@ResponseBody

public Msg getSeatResver(@PathVariable(“seatid”) Integer seatid

,@RequestParam(value = “pn”,defaultValue = “1”)Integer pn){

PageHelper.startPage(pn,20);

List all = seatResverService.getSeatAll(seatid);

PageInfo page=new PageInfo(all,5);

return Msg.success().add(“pageInfo”,page);

管理员管理控制层:

@Controller

public class ManagerController {

@Autowired

ManagerServiceImpl managerService;

//进入忘记密码页面

@RequestMapping(“/forgotPwd”)

public String toForgotPage(){

return “ForgotPassword”;

@RequestMapping(“/forgotPwd2”)

public String toForgotPage2(){

return “ForgotPassword2”;

@RequestMapping(“/logout”)

public String toLoginPage(HttpSession session){

Enumeration attributeNames = session.getAttributeNames();

while (attributeNames.hasMoreElements()) {

session.removeAttribute(attributeNames.nextElement());

return “Login”;

//进入重置密码页面

@RequestMapping(“/register”)

public String toRegisterPage(){

return “Register”;

//登陆和忘记密码==》检查用户名是否存在

@GetMapping(“/checkLoginManagerName”)

@ResponseBody

public Msg checkLoginManagerName(@RequestParam(“managername”) String managername1){

String managername = managername1.trim();

String regex = “(3{6,16})∣([u2E80−u9FFF]+)|(^[\\u2E80-\\u9FFF]+)∣([u2E80−u9FFF]+)”;

boolean c = managername.matches(regex);

if(!c) {

return Msg.fail().add(“va_msg”, “用户名是2-5位中文,或者6-16位英文和数字的组合”);

boolean b = managerService.checkManagerName(managername);

if (b==true){

return Msg.fail().add(“va_msg”,“用户名不存在!”);

}else {

return Msg.success().add(“va_msg”,“”);

//注册检查用户名是否存在

@GetMapping(“/checkManagerName”)

@ResponseBody

public Msg checkManagerName(@RequestParam(“managername”) String managername1){

String managername = managername1.trim();

String regex = “(4{6,16})∣([u2E80−u9FFF]+)|(^[\\u2E80-\\u9FFF]+)∣([u2E80−u9FFF]+)”;

boolean c = managername.matches(regex);

if(!c) {

return Msg.fail().add(“va_msg”, “用户名可以是2-5位中文,或者6-16位英文和数字的组合”);

boolean b = managerService.checkManagerName(managername);

if (b==true){

return Msg.success().add(“va_msg”,“用户名可用!”);

}else {

return Msg.fail().add(“va_msg”,“用户名已存在!”);

//检查手机号是否是十一位

@GetMapping(“/checkManagerTel”)

@ResponseBody

public Msg checkManagerTel(@RequestParam(“managertel”) String managertel1){

String managertel = managertel1.trim();

String regex = “(^1\d{10}$)”;

boolean matches = managertel.matches(regex);

if(matches == true){

return Msg.success().add(“va_msg”," ");

}else{

return Msg.fail().add(“va_msg”,“手机号必须以1开头,11位的数字!”);

//登陆检查密码

@GetMapping(“/checkLoginManagerPwd”)

@ResponseBody

public Msg checkLoginManagerPwd(@RequestParam(“managerpwd”) String managerpwd1){

String managerpwd = managerpwd1.trim();

String regex = “(5{6,16}$)”;

boolean matches = managerpwd.matches(regex);

if(matches == true){

return Msg.success().add(“va_msg”," ");

}else{

return Msg.fail().add(“va_msg”,“密码格式不正确:必须超过6位,小于16位!”);

//注册检查密码

@GetMapping(“/checkManagerPwd”)

@ResponseBody

public Msg checkManagerPwd(@RequestParam(“managerpwd”) String managerpwd1){

String managerpwd = managerpwd1.trim();

String regex = “(6{6,16}$)”;

boolean matches = managerpwd.matches(regex);

if(matches == true){

return Msg.success().add(“va_msg”," ");

}else{

return Msg.fail().add(“va_msg”,“密码格式不正确:必须超过6位,小于16位!”);

/*新增管理员

**/

@PostMapping(“/registerManager”)

public String registerManger(Manager manager,Map<String,Object> map){

manager.setManagerid(null);

boolean flag = managerService.createManager(manager);

if(flag == true){

map.put(“msg”,“插入成功!”);

return “redirect:share.html”;

}else{

map.put(“msg”,“插入失败!”);

return “Register”;

//点击进入按钮校验用户名和密码是否正确

@PostMapping(“/loginD”)

public String loginDashboard(@RequestParam(“managername”) String managername1,

@RequestParam(“managerpwd”) String managerpwd1,

Map<String,Object> map, HttpSession session){

/*

  • ==true没有该用户

  • ==false 用户存在

  • */

String managername = managername1.trim();

String managerpwd = managerpwd1.trim();

if(managername != “” && managerpwd!=“”){

boolean name = managerService.checkManagerName(managername);

boolean pwd = managerService.checkManagerPwd(managerpwd);

if(name == false && pwd ==false ){

// System.out.println(“用户名或密码正确!”);

session.setAttribute(“username”,managername);

return “redirect:/user22”;

}else{

// System.out.println(“密码错误!”);

map.put(“msg”,“账号密码错误,请重新输入账号和密码!”);

return “Login”;

}else {

map.put(“msg”,“请输入账号or密码!”);

return “Login”;

/*resetpwd

  • 点击确认修改密码并且返回登陆页面*/

@PutMapping(“/resetpwd”)

public String backLogin(@RequestParam(“managername”) String managername1,

@RequestParam(“managerpwd”) String managerpwd1,

Map<String,Object> map){

String managername = managername1.trim();

String managerpwd = managerpwd1.trim();

if (managername != “” && managerpwd != “”){

boolean tel = managerService.checkManagerName(managername);

if(tel == true){

map.put(“msg”,“账号不存在,请重新输入!”);

return “ForgotPassword”;

}else {

int i = managerService.updateUserPwd(managername,managerpwd);

map.put(“msg”,“reset success!”);

if(i>0){

return “redirect:/share.html”;

}else {

return “ForgotPassword”;

}else {

map.put(“msg”,“账号或新密码为空,请输入!”);

return “ForgotPassword”;

@PutMapping(“/resetpwd2”)

public String backLogin2(@RequestParam(“managername”) String managername1,

@RequestParam(“managerpwd”) String managerpwd1,

Map<String,Object> map){

String managername = managername1.trim();

String managerpwd = managerpwd1.trim();

if (managername != “” && managerpwd != “”){

boolean tel = managerService.checkManagerName(managername);

if(tel == true){

map.put(“msg”,“账号不存在,请重新输入!”);

return “ForgotPassword2”;

}else {

int i = managerService.updateUserPwd(managername,managerpwd);

map.put(“msg”,“reset success!”);

if(i>0){

return “redirect:/forgotPwd2”;

}else {

return “ForgotPassword2”;

}else {

map.put(“msg”,“账号或新密码为空,请输入!”);

return “ForgotPassword2”;



  1. a-zA-Z0-9_- ↩︎

  2. a-zA-Z0-9_- ↩︎

  3. a-zA-Z0-9_- ↩︎

  4. a-zA-Z0-9_- ↩︎

  5. a-zA-Z0-9_- ↩︎

  6. a-zA-Z0-9_- ↩︎

基于javaweb的自习室图书馆座位预约管理系统(java+ssm+jsp+easyui+mysql)相关推荐

  1. Java项目:自习室图书馆座位预约管理系统(java+SSM+JSP+easyUI+mysql)

    源码获取:俺的博客首页 "资源" 里下载! 项目介绍 一款由jsp+ssm+mysql实现的图书馆预约占座管理系统,前端采用的是当下最流行的easyui框架,后台用的ssm(spr ...

  2. 基于javaweb的高校教职工差旅报销管理系统(java+ssm+jsp+html+mysql)

    基于javaweb的高校教职工差旅报销管理系统(java+ssm+jsp+html+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclipse/idea/my ...

  3. 基于javaweb的水果生鲜超市商城管理系统(java+ssm+jsp+jquery+mysql)

    基于javaweb的水果生鲜超市商城管理系统(java+ssm+jsp+jquery+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclipse/idea/m ...

  4. 基于javaweb的图书进销存管理系统(java+ssm+jsp+bootstrap+mysql)

    基于javaweb的图书进销存管理系统(java+ssm+jsp+bootstrap+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclipse/idea/m ...

  5. 基于javaweb的业务代办帮跑腿管理系统(java+ssm+jsp+bootstrap+jquery+mysql)

    基于javaweb的业务代办帮跑腿管理系统(java+ssm+jsp+bootstrap+jquery+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclip ...

  6. 基于javaweb的超市进销存管理系统(java+ssm+jsp+bootstrap+jquery+mysql)

    基于javaweb的超市进销存管理系统(java+ssm+jsp+bootstrap+jquery+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclipse ...

  7. 基于javaweb的宠物商城带后台管理系统(java+ssm+jsp+jquery+ajax+mysql)

    基于javaweb的宠物商城带后台管理系统(java+ssm+jsp+jquery+ajax+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclipse/id ...

  8. 基于javaweb的养老院管理系统(java+ssm+jsp+easyui+mysql)

    基于javaweb的养老院管理系统(java+ssm+jsp+easyui+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclipse/idea/myecli ...

  9. 基于javaweb的个人pc电脑商城系统(java+ssm+jsp+jquery+mysql)

    基于javaweb的个人pc电脑商城系统(java+ssm+jsp+jquery+mysql) 运行环境 Java≥8.MySQL≥5.7.Tomcat≥8 开发工具 eclipse/idea/mye ...

最新文章

  1. PMP考试错题记录(2)
  2. 使用模板元编程快速的得到斐波那契数。。
  3. 全面对比 MATLAB、Julia、Python,谁在科学计算中更胜一筹?
  4. ct检查床的移动精度是指_炮塔铣床、数控铣床导轨平行度(扭曲)的检验
  5. [html]history禁用浏览器的后退功能(包括其他操作后退的按钮,操作等)
  6. 实例44:python
  7. oracle日期相减工作日_oracle 日期相减 转载
  8. html中的各种协议,html 中使用 wtai 协议
  9. spring boot的学习(1)杂
  10. attrib批量显示文件夹_CMD中使用attrib命令设置文件只读、隐藏属性详解
  11. resin 配置java_Resin4配置
  12. Android编译环境搭建
  13. 认知升级 - 第一性原理
  14. sql中如何按拼音笔画排序
  15. 阿里云centos7部署l2tp后无法连接
  16. 重装系统后,没有wifi---问题已解决
  17. 中标麒麟——初次体验,感觉流畅
  18. uniapp 调用安卓原生插件 安卓原生又调用了第三方sdk(第三方原生开发的aar怎么转成uni可以使用的aar)
  19. 蓝桥杯_既约分数_java
  20. java分布式事务——seata,tcc解决方案总结!

热门文章

  1. 科技新品 | 索尼最新高级条形音箱;Bose消噪耳塞全新配色;新一代人工智能社交机器人Musio S...
  2. 兼容低版本IE浏览器的一些技巧分享
  3. python爬取pexels网站图片
  4. 一张图看懂阿里云网络产品[七]共享流量包
  5. java8新特性 Stream流的优雅操作
  6. php 百度网盘上传文件大小限制吗,百度云存储,curl_百度云存储如何上传数G超大文件(视频类)和防盗链等一系列问题,百度云存储,curl - phpStudy...
  7. wamp下localhost目录Your Projects下项目无法打开解决方案
  8. 信用卡怎么付款给PayPal?
  9. cisco路由器基本实验之五 配置Loopback接口进行远程登录 (Boson NetSim)
  10. 保研er:9月,我太南了...