图书馆是当下很多大学生和有志青年学习和借阅图书的场所,图书馆每天都有大量的人员需要接待,如何能够更好的对用户的这些借阅信息进行信息化的管理是当下大多数图书馆管理人员所关心的问题
本系统是通过JAVA和MYSQL来进行开发的,通过本系统可以对图书馆内的图书信息,用户信息以及用户对图书的解决信息进行更加合理的管理和查询
用户在打开图书馆借阅系统之后首先打开的是登录页面,在登录时候分为管理员和用户两种角色,其中管理员可以管理所有的图书馆内的信息,用户只能查看和管理自己的个人信息
图书馆借阅系统登录界面
图书馆内的管理人员通过自己的账号和密码登录到系统之后,可以对系统内的图书分类信息,图书信息,读者信息,图书借阅,图书归还,以及对借阅信息进行查询统计,管理员功能界面如下图所示
图书馆借阅系统管理员功能界面
图书馆借阅系统的用户在登录系统之后可以查看自己的个人信息,查询和查看图书信息,查看自己的借阅和归还记录,同时可以进行留言反馈
图书馆管理系统用户部分界面
/**
* 登录相关
*/
@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("/page")
public R page(@RequestParam Map<String, Object> params,UserEntity user){
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@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));
}
/**
* 信息
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") String id){
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 获取用户的session用户信息
*/
@RequestMapping("/session")
public R getCurrUser(HttpServletRequest request){
Long id = (Long)request.getSession().getAttribute("userId");
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 保存
*/
@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();
}
}
第1章 概述1
1.1 开发背景1
1.2 开发目的1
1.3 研究目标2
第2章 相关技术简介3
2.1 开发工具3
2.2 JSP技术3
2.3 HTML简介4
2.4 SQL数据库5
2.5 B/S结构5
第3章 系统需求7
3.1 可行性分析7
3.1.1 技术可行性7
3.1.2 操作可行性7
3.1.3 经济可行性8
3.2需求分析8
3.2.1 性能需求分析8
3.2.2 用户需求分析8
3.2.3 功能需求分析9
3.2.4 非功能需求分析9
3.3 系统流程设计10
3.4 系统用例分析12
3.4.1管理员用例12
3.4.2读者用例12
3.5 界面需求13
第4章 数据库设计15
4. 1 数据库设计原则15
4. 2 数据库实体15
4.3 数据库表设计17
第5章 系统的实现19
5.1系统登录模块的实现19
5.2密码信息管理模块的实现19
5.3图书分类管理界面19
5.4图书信息管理界面20
5.5读者信息管理界面21
5.6图书借阅管理主界面21
第6章 系统测试22
6.1系统测试目的22
6.2 测试过程22
6.3性能测试23
6.4测试结果23
总 结24
致 谢25
参考文献26