博主介绍:✌全网粉丝30W+,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌
🍅文末获取源码联系🍅
👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟
2022-2024年最全的计算机软件毕业设计选题大全:1000个热门选题推荐✅
Java项目精品实战案例《100套》
Java微信小程序项目实战《100套》
系统介绍:
网络技术和计算机技术发展至今,已经拥有了深厚的理论基础,并在现实中进行了充分运用,尤其是基于计算机运行的软件更是受到各界的关注。加上现在人们已经步入信息时代,所以对于信息的宣传和管理就很关键。因此园区停车信息的管理计算机化,系统化是必要的。设计开发园区停车管理系统不仅会节约人力和管理成本,还会安全保存庞大的数据量,对于园区停车信息的维护和检索也不需要花费很多时间,非常的便利。
园区停车管理系统是在MySQL中建立数据表保存信息,运用SSM框架和Java语言编写。并按照软件设计开发流程进行设计实现。系统具备友好性且功能完善。管理员登录进入本人后台之后,管理员工和车主,管理车位,根据车牌号进行泊车或取车,查看停车数据的年份报表或月份报表信息。员工查询车辆记录和车主,管理车位,对车辆进行泊车或取车。
园区停车管理系统在让园区停车信息规范化的同时,也能及时通过数据输入的有效性规则检测出错误数据,让数据的录入达到准确性的目的,进而提升园区停车管理系统提供的数据的可靠性,让系统数据的错误率降至最低。
前面所做的功能分析,只是本系统的一个大概功能,这部分需要在此基础上进行各个模块的详细设计。设计的管理员的详细功能见下图,管理员登录进入本人后台之后,管理员工和车主,管理车位,根据车牌号进行泊车或取车,查看停车数据的年份报表或月份报表信息。
图4.1 管理员功能结构图
设计的员工的详细功能见下图,员工查询车辆记录和车主,管理车位,对车辆进行泊车或取车。
图4.2 员工功能结构图
程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
程序操作流程图
功能截图:
5.1 管理员功能实现
5.1.1 员工管理
管理员权限中的员工管理,其运行效果见下图。管理员维护员工资料,能修改与删除。也能登记本页面没有的员工资料。
图5.1 员管理页面
5.1.2 车主管理
管理员权限中的车主管理,其运行效果见下图。管理员查询车主,可以根据车主姓名,也能根据车主的身份证号,手机号或者车牌号查询车主,同时,管理员能够修改,删除本页面显示的车主资料。
图5.2 车主管理页面
5.1.3 车位管理
管理员权限中的车位管理,其运行效果见下图。管理员增删改查车位,根据车牌号对车辆进行泊车或取车操作。
图5.3 车位管理页面
5.1.4 车辆记录管理
管理员权限中的车辆记录管理,其运行效果见下图。管理员查看车辆停车信息,查看车辆停车的月份报表或年份报表。
图5.4 车辆记录管理页面
5.2 员工功能实现
5.2.1 车位管理
员工权限中的车位管理,其运行效果见下图。员工在本页面可以操作的功能比较多,可以添加车位,修改或查询车位,对车辆进行泊车或取车操作。
图5.5 车位管理页面
5.2.2 车辆记录
员工权限中的车辆记录,其运行效果见下图。员工根据车位名字,车牌号或者停车的时间区间筛选车辆停车记录。
图5.6 车辆记录页面
5.2.3 车主信息
员工权限中的车主信息,其运行效果见下图。员工只能查询或查看车主信息。
图5.7 车主信息页面
代码实现:
/**
* 登录相关
*/
@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();
}
}
论文参考:
1 绪论 1
1.1 选题背景 1
1.2 选题意义 1
1.3 研究内容 2
2 系统开发技术 3
2.1 Java语言 3
2.2 SSM框架 3
2.3 MYSQL数据库 4
3 系统分析 5
3.1可行性研究 5
3.1.1经济可行性 5
3.1.2时间可行性 5
3.1.3操作可行性 5
3.2系统性能分析 6
3.2.1系统易用性 6
3.2.2系统健壮性 6
3.2.3系统安全性 6
3.3 系统流程分析 6
3.4系统功能分析 9
4 系统设计 12
4.1系统目标 12
4.2功能结构设计 13
4.3数据库设计 14
4.3.1数据库E-R图 14
4.3.2 数据库表结构 17
5 系统实现 20
5.1 管理员功能实现 20
5.1.1 员工管理 20
5.1.2 车主管理 20
5.1.3 车位管理 21
5.1.4 车辆记录管理 21
5.2 员工功能实现 22
5.2.1 车位管理 22
5.2.2 车辆记录 22
5.2.3 车主信息 23
6系统测试 24
6.1 系统测试的类型 24
6.2 功能测试 25
6.3 可用性测试 25
6.4 测试结果分析 25
结 论 26
参考文献 28
致 谢 29
源码获取:
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻
精彩专栏推荐订阅:在下方专栏👇🏻
2022-2024年最全的计算机软件毕业设计选题大全:1000个热门选题推荐✅
Java项目精品实战案例《100套》
Java微信小程序项目实战《100套》