博主介绍:✌全网粉丝30W+,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌
🍅文末获取源码联系🍅
👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟
2022-2024年最全的计算机软件毕业设计选题大全:1000个热门选题推荐✅
Java项目精品实战案例《100套》
Java微信小程序项目实战《100套》
系统介绍:
如今社会上各行各业,都在用属于自己专用的软件来进行工作,互联网发展到这个时候,人们已经发现离不开了互联网。互联网的发展,离不开一些新的技术,而新技术的产生往往是为了解决现有问题而产生的。针对于夕阳红公寓信息管理方面的不规范,容错率低,管理人员处理数据费工费时,采用新开发的夕阳红公寓管理系统可以从根源上规范整个数据处理流程的正规性和合法性。
夕阳红公寓管理系统能够实现访客管理,租客管理,维修管理,缴费管理,行程轨迹管理,留言管理等功能。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。
夕阳红公寓管理系统可以提高夕阳红公寓信息管理问题的解决效率,优化夕阳红公寓信息处理流程,并且能够保证存储数据的安全,它是一个非常可靠,非常安全的应用程序。
4.1 功能结构设计
图4.1即为设计的管理员功能结构,管理员权限操作的功能包括对租客,访客,缴费,维修,留言,公告,租客的行程轨迹等进行管理。
图4.1 管理员功能结构
图4.2即为设计的租客功能结构,租客权限操作的功能包括管理行程轨迹,在线缴费,在线留言,申请报修,查看公告等功能。
图4.2 租客功能结构
程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
程序操作流程图
功能截图:
编程人员在搭建的开发环境中,运用编程技术实现本系统设计的各个操作权限的功能。在本节中,就展示部分操作权限的功能与界面。
5.1 管理员功能实现
5.1.1 访客管理
图5.1 即为编码实现的访客管理界面,管理员在该界面中对访客的信息进行新增,根据访客姓名,访客手机号,访客身份证号等条件查询访客信息,可以对访客的信息进行修改与删除。
图5.1 访客管理界面
5.1.2 缴费管理
图5.2 即为编码实现的缴费管理界面,管理员在该界面中新增缴费信息,缴费的费用包括物业费,房租费等,可以修改,查询,删除缴费信息,租户已经缴纳费用,则对应的缴费信息栏就会显示已缴。未缴纳费用的租户则会在对应的缴费信息栏中显示未缴。
图5.2 缴费管理界面
5.1.3 留言管理
图5.3 即为编码实现的留言管理界面,管理员在该界面中查询租客的留言内容,对每个租客的留言进行回复,可以删除租客留言的信息。
图5.3 留言管理界面
5.1.4 维修管理
图5.4 即为编码实现的维修管理界面,管理员在该界面中对租客申请维修的信息进行查询,可以删除已维修状态的维修信息,可以对未维修状态的维修信息进行已维修状态的切换。
图5.4 维修管理界面
5.1.5 租客管理
图5.5 即为编码实现的租客管理界面,管理员在该界面中可以查询,修改,删除租客的资料,可以禁用租客的账号,让租客不能登录系统,同时可以对租客的密码进行重置。
图5.5 租客管理界面
5.2 租客功能实现
5.2.1 公告信息
图5.6 即为编码实现的公告信息界面,租客在该界面中查看公告信息。租客在公告搜索栏中登记公告标题可以获取指定的公告信息。
图5.6 公告信息界面
5.2.2 在线留言
图5.7 即为编码实现的在线留言界面,租客在该界面中发布留言时,需要对留言的内容以及留言的标题进行编辑,然后提交。同时,租客可以查看本页面显示的所有留言以及管理员的回复信息。
图5.7 在线留言界面
5.2.3 缴费管理
图5.8 即为编码实现的缴费管理界面,租客在该界面中完成缴费信息查询,对需要缴纳的费用进行缴费。
图5.8 缴费管理界面
5.2.4 维修管理
图5.9 即为编码实现的维修管理界面,租客在该界面中新增维修信息,查看管理员对维修信息的查看情况以及处置情况。
图5.9 维修管理界面
5.2.5 行程轨迹管理
图5.10 即为编码实现的行程轨迹管理界面,租客在该界面中对自己的行程轨迹信息进行登记,可以编辑,查询,删除个人行程轨迹信息。
图5.10 行程轨迹管理界面
代码实现:
/**
* 登录相关
*/
@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 role, HttpServletRequest request) {
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user != null){
if(!user.getRole().equals(role)){
return R.error("权限不正常");
}
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);
}else{
return R.error("账号或密码或权限不对");
}
}
/**
* 注册
*/
@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("/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){
Integer id = (Integer)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 Integer[] ids){
userService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
}
论文参考:
源码获取:
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻
精彩专栏推荐订阅:在下方专栏👇🏻
2022-2024年最全的计算机软件毕业设计选题大全:1000个热门选题推荐✅
Java项目精品实战案例《100套》
Java微信小程序项目实战《100套》