0


Java项目:电影院会员管理系统(java+SpringBoot+Vue+element-ui+maven+mysql)

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

项目介绍

本项目代码架构设计简单,注释齐全,结构清晰,适合同为java初学者参考。
项目是一套电影院会员管理系统,使用前后端分离架构开发,前端基于Vue.js+Element UI技术,后端使用springboot+mybatis实现,包含管理员、会员管理、会员卡管理、电影票、消费记录、数据统计等模块

环境需要

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.是否Maven项目: 是;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven项目
6.数据库:MySql 5.7版本;

技术栈

  1. 后端:springboot+mybatis

  2. 前端:vue.js+element-ui

使用说明

  • 数据库文件cinema.sql已整合到项目中,使用mysql导入即可生成数据库

  • 本项目已经整合了前后端,前端文件经过webpack构建后,生成了static文件夹和index.html放入了webapp下。

  • 要对前端页面进行修改,修改完成后同样将生成的文件放到本项目的webapp下。

  • 程序设计文档可参考目录下:电影院会员管理系统说明文档.docx

运行项目

  • 方法一: cinema项目中已经整合了vue打包的静态资源,直接启动项目,并在浏览器上输入http://localhost:8081/cinema 即可运行。
  1. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,下载所需jar包;
  2. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
  3. 将项目中db.properties配置文件中的数据库配置改为自己的配置
  4. 配置tomcat,然后运行项目,输入http://localhost:8081/cinema 登录
  5. 账户:admin 密码:123123
  • 方法二: cinema-web项目是cinema项目的vue单页面前端项目,可以在文件夹目录下命令行输入:
    npm run install
    npm run dev

后,修改utils/request.js下baseURL=”/api”,开启node反向代理服务器,解决跨域问题,然后启动cinema后端项目,在浏览器上输入 http://localhost:8080 即可以前后端分离方式运行(也可以npm run build后将dist文件夹放到nginx下运行)

后台用户管理控制器:

  1. /**
  2. * 后台用户管理控制器
  3. * @author yy
  4. *
  5. */
  6. @RequestMapping("/admin/user")
  7. @Controller
  8. public class UserController {
  9. @Autowired
  10. private UserService userService;
  11. @Autowired
  12. private RoleService roleService;
  13. @Autowired
  14. private OperaterLogService operaterLogService;
  15. /**
  16. * 用户列表页面
  17. * @param model
  18. * @param user
  19. * @param pageBean
  20. * @return
  21. */
  22. @RequestMapping(value="/list")
  23. public String list(Model model, User user, PageBean<User> pageBean){
  24. model.addAttribute("title", "用户列表");
  25. model.addAttribute("username", user.getUsername());
  26. model.addAttribute("pageBean", userService.findList(user, pageBean));
  27. return "admin/user/list";
  28. }
  29. /**
  30. * 新增用户页面
  31. * @param model
  32. * @return
  33. */
  34. @RequestMapping(value="/add",method=RequestMethod.GET)
  35. public String add(Model model){
  36. model.addAttribute("roles", roleService.findAll());
  37. return "admin/user/add";
  38. }
  39. /**
  40. * 用户添加表单提交处理
  41. * @param user
  42. * @return
  43. */
  44. @RequestMapping(value="/add",method=RequestMethod.POST)
  45. @ResponseBody
  46. public Result<Boolean> add(User user){
  47. //用统一验证实体方法验证是否合法
  48. CodeMsg validate = ValidateEntityUtil.validate(user);
  49. if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
  50. return Result.error(validate);
  51. }
  52. if(user.getRole() == null || user.getRole().getId() == null){
  53. return Result.error(CodeMsg.ADMIN_USER_ROLE_EMPTY);
  54. }
  55. //判断用户名是否存在
  56. if(userService.isExistUsername(user.getUsername(), 0l)){
  57. return Result.error(CodeMsg.ADMIN_USERNAME_EXIST);
  58. }
  59. //到这说明一切符合条件,进行数据库新增
  60. if(userService.save(user) == null){
  61. return Result.error(CodeMsg.ADMIN_USE_ADD_ERROR);
  62. }
  63. operaterLogService.add("添加用户,用户名:" + user.getUsername());
  64. return Result.success(true);
  65. }
  66. /**
  67. * 用户编辑页面
  68. * @param model
  69. * @return
  70. */
  71. @RequestMapping(value="/edit",method=RequestMethod.GET)
  72. public String edit(Model model,@RequestParam(name="id",required=true)Long id){
  73. model.addAttribute("roles", roleService.findAll());
  74. model.addAttribute("user", userService.find(id));
  75. return "admin/user/edit";
  76. }
  77. /**
  78. * 编辑用户信息表单提交处理
  79. * @param user
  80. * @return
  81. */
  82. @RequestMapping(value="/edit",method=RequestMethod.POST)
  83. @ResponseBody
  84. public Result<Boolean> edit(User user){
  85. //用统一验证实体方法验证是否合法
  86. CodeMsg validate = ValidateEntityUtil.validate(user);
  87. if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
  88. return Result.error(validate);
  89. }
  90. if(user.getRole() == null || user.getRole().getId() == null){
  91. return Result.error(CodeMsg.ADMIN_USER_ROLE_EMPTY);
  92. }
  93. if(user.getId() == null || user.getId().longValue() <= 0){
  94. return Result.error(CodeMsg.ADMIN_USE_NO_EXIST);
  95. }
  96. if(userService.isExistUsername(user.getUsername(), user.getId())){
  97. return Result.error(CodeMsg.ADMIN_USERNAME_EXIST);
  98. }
  99. //到这说明一切符合条件,进行数据库保存
  100. User findById = userService.find(user.getId());
  101. //讲提交的用户信息指定字段复制到已存在的user对象中,该方法会覆盖新字段内容
  102. BeanUtils.copyProperties(user, findById, "id","createTime","updateTime");
  103. if(userService.save(findById) == null){
  104. return Result.error(CodeMsg.ADMIN_USE_EDIT_ERROR);
  105. }
  106. operaterLogService.add("编辑用户,用户名:" + user.getUsername());
  107. return Result.success(true);
  108. }
  109. /**
  110. * 删除用户
  111. * @param id
  112. * @return
  113. */
  114. @RequestMapping(value="/delete",method=RequestMethod.POST)
  115. @ResponseBody
  116. public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
  117. try {
  118. userService.delete(id);
  119. } catch (Exception e) {
  120. return Result.error(CodeMsg.ADMIN_USE_DELETE_ERROR);
  121. }
  122. operaterLogService.add("添加用户,用户ID:" + id);
  123. return Result.success(true);
  124. }
  125. }

后台角色管理控制器:

  1. /**
  2. * 后台角色管理控制器
  3. * @author yy
  4. *
  5. */
  6. @RequestMapping("/admin/role")
  7. @Controller
  8. public class RoleController {
  9. private Logger log = LoggerFactory.getLogger(RoleController.class);
  10. @Autowired
  11. private MenuService menuService;
  12. @Autowired
  13. private OperaterLogService operaterLogService;
  14. @Autowired
  15. private RoleService roleService;
  16. /**
  17. * 分页搜索角色列表
  18. * @param model
  19. * @param role
  20. * @param pageBean
  21. * @return
  22. */
  23. @RequestMapping(value="/list")
  24. public String list(Model model, Role role, PageBean<Role> pageBean){
  25. model.addAttribute("title", "角色列表");
  26. model.addAttribute("name", role.getName());
  27. model.addAttribute("pageBean", roleService.findByName(role, pageBean));
  28. return "admin/role/list";
  29. }
  30. /**
  31. * 角色添加页面
  32. * @param model
  33. * @return
  34. */
  35. @RequestMapping(value="/add",method=RequestMethod.GET)
  36. public String add(Model model){
  37. List<Menu> findAll = menuService.findAll();
  38. model.addAttribute("topMenus", MenuUtil.getTopMenus(findAll));
  39. model.addAttribute("secondMenus",MenuUtil.getSecondMenus(findAll));
  40. model.addAttribute("thirdMenus",MenuUtil.getThirdMenus(findAll));
  41. return "admin/role/add";
  42. }
  43. /**
  44. * 角色添加表单提交处理
  45. * @param role
  46. * @return
  47. */
  48. @RequestMapping(value="/add",method=RequestMethod.POST)
  49. @ResponseBody
  50. public Result<Boolean> add(Role role){
  51. //用统一验证实体方法验证是否合法
  52. CodeMsg validate = ValidateEntityUtil.validate(role);
  53. if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
  54. return Result.error(validate);
  55. }
  56. if(roleService.save(role) == null){
  57. return Result.error(CodeMsg.ADMIN_ROLE_ADD_ERROR);
  58. }
  59. log.info("添加角色【"+role+"】");
  60. operaterLogService.add("添加角色【"+role.getName()+"】");
  61. return Result.success(true);
  62. }
  63. /**
  64. * 角色编辑页面
  65. * @param id
  66. * @param model
  67. * @return
  68. */
  69. @RequestMapping(value="/edit",method=RequestMethod.GET)
  70. public String edit(@RequestParam(name="id",required=true)Long id,Model model){
  71. List<Menu> findAll = menuService.findAll();
  72. model.addAttribute("topMenus",MenuUtil.getTopMenus(findAll));
  73. model.addAttribute("secondMenus",MenuUtil.getSecondMenus(findAll));
  74. model.addAttribute("thirdMenus",MenuUtil.getThirdMenus(findAll));
  75. Role role = roleService.find(id);
  76. model.addAttribute("role", role);
  77. model.addAttribute("authorities",JSONArray.toJSON(role.getAuthorities()).toString());
  78. return "admin/role/edit";
  79. }
  80. /**
  81. * 角色修改表单提交处理
  82. * @param request
  83. * @param role
  84. * @return
  85. */
  86. @RequestMapping(value="/edit",method=RequestMethod.POST)
  87. @ResponseBody
  88. public Result<Boolean> edit(Role role){
  89. //用统一验证实体方法验证是否合法
  90. CodeMsg validate = ValidateEntityUtil.validate(role);
  91. if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
  92. return Result.error(validate);
  93. }
  94. Role existRole = roleService.find(role.getId());
  95. if(existRole == null){
  96. return Result.error(CodeMsg.ADMIN_ROLE_NO_EXIST);
  97. }
  98. existRole.setName(role.getName());
  99. existRole.setRemark(role.getRemark());
  100. existRole.setStatus(role.getStatus());
  101. existRole.setAuthorities(role.getAuthorities());
  102. if(roleService.save(existRole) == null){
  103. return Result.error(CodeMsg.ADMIN_ROLE_EDIT_ERROR);
  104. }
  105. log.info("编辑角色【"+role+"】");
  106. operaterLogService.add("编辑角色【"+role.getName()+"】");
  107. return Result.success(true);
  108. }
  109. /**
  110. * 删除角色
  111. * @param request
  112. * @param id
  113. * @return
  114. */
  115. @RequestMapping(value="delete",method=RequestMethod.POST)
  116. @ResponseBody
  117. public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
  118. try {
  119. roleService.delete(id);
  120. } catch (Exception e) {
  121. // TODO: handle exception
  122. return Result.error(CodeMsg.ADMIN_ROLE_DELETE_ERROR);
  123. }
  124. log.info("编辑角色ID【"+id+"】");
  125. operaterLogService.add("删除角色ID【"+id+"】");
  126. return Result.success(true);
  127. }
  128. }

电影管理控制器:

  1. /**
  2. * 电影管理控制器
  3. * @author yy
  4. *
  5. */
  6. @RequestMapping("/admin/movie")
  7. @Controller
  8. public class MovieController {
  9. @Autowired
  10. private MovieService movieService;
  11. @Autowired
  12. private MovieCommentService movieCommentService;
  13. /**
  14. * 电影列表页面
  15. * @param model
  16. * @return
  17. */
  18. @RequestMapping(value="/list")
  19. public String list(Model model, Movie movie, PageBean<Movie> pageBean){
  20. model.addAttribute("pageBean", movieService.findPage(movie, pageBean));
  21. model.addAttribute("name",movie.getName());
  22. return "admin/movie/list";
  23. }
  24. /**
  25. * 电影添加页面
  26. * @param model
  27. * @return
  28. */
  29. @RequestMapping(value="/add",method=RequestMethod.GET)
  30. public String add(Model model){
  31. model.addAttribute("movieAreaList", MovieArea.values());
  32. model.addAttribute("movieTypeList", MovieType.values());
  33. model.addAttribute("movieLangList", MovieLang.values());
  34. return "admin/movie/add";
  35. }
  36. /**
  37. * 电影编辑页面
  38. * @param model
  39. * @param id
  40. * @return
  41. */
  42. @RequestMapping(value="/edit",method=RequestMethod.GET)
  43. public String edit(Model model,@RequestParam(name="id",required=true)Long id){
  44. model.addAttribute("movie", movieService.findById(id));
  45. model.addAttribute("movieAreaList", MovieArea.values());
  46. model.addAttribute("movieTypeList", MovieType.values());
  47. model.addAttribute("movieLangList", MovieLang.values());
  48. return "admin/movie/edit";
  49. }
  50. /**
  51. * 添加电影表单提交
  52. * @param movie
  53. * @return
  54. */
  55. @RequestMapping(value="/add",method=RequestMethod.POST)
  56. @ResponseBody
  57. public Result<Boolean> add(Movie movie){
  58. if(movie == null){
  59. return Result.error(CodeMsg.DATA_ERROR);
  60. }
  61. CodeMsg validate = ValidateEntityUtil.validate(movie);
  62. if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
  63. return Result.error(validate);
  64. }
  65. //判断是否是编辑
  66. if(movie.getId() != null && movie.getId() > 0){
  67. Movie findById = movieService.findById(movie.getId());
  68. movie.setCreateTime(findById.getCreateTime());
  69. movie.setRate(findById.getRate());
  70. movie.setRateCount(findById.getRateCount());
  71. movie.setTotalMoney(findById.getTotalMoney());
  72. }
  73. //表示数据合法,可以保存到数据库
  74. if(movieService.save(movie) == null){
  75. return Result.error(CodeMsg.ADMIN_AREA_SAVE_ERROR);
  76. }
  77. return Result.success(true);
  78. }
  79. /**
  80. * 删除
  81. * @param id
  82. * @return
  83. */
  84. @RequestMapping(value="/delete",method=RequestMethod.POST)
  85. @ResponseBody
  86. public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
  87. try {
  88. movieService.delete(id);
  89. } catch (Exception e) {
  90. return Result.error(CodeMsg.ADMIN_MOVIE_DELETE_ERROR);
  91. }
  92. return Result.success(true);
  93. }
  94. /**
  95. * ----------电影评价管理-------------
  96. */
  97. /**
  98. * 电影评价列表
  99. * @param model
  100. * @param movieComment
  101. * @param pageBean
  102. * @return
  103. */
  104. @RequestMapping(value="/comment_list")
  105. public String list(Model model,MovieComment movieComment,PageBean<MovieComment> pageBean){
  106. model.addAttribute("pageBean", movieCommentService.findPage(movieComment, pageBean));
  107. model.addAttribute("content",movieComment.getContent());
  108. return "admin/movie/comment_list";
  109. }
  110. /**
  111. * 删除评价
  112. * @param id
  113. * @return
  114. */
  115. @RequestMapping(value="/delete_comment",method=RequestMethod.POST)
  116. @ResponseBody
  117. public Result<Boolean> deleteComment(@RequestParam(name="id",required=true)Long id){
  118. movieCommentService.delete(id);
  119. return Result.success(true);
  120. }
  121. }

订单管理控制器:

  1. /**
  2. * 订单管理控制器
  3. * @author yy
  4. *
  5. */
  6. @RequestMapping("/admin/order")
  7. @Controller
  8. public class OrderController {
  9. @Autowired
  10. private OrderService orderService;
  11. @Autowired
  12. private OrderItemService orderItemService;
  13. /**
  14. * 订单列表
  15. * @param model
  16. * @param order
  17. * @param pageBean
  18. * @return
  19. */
  20. @RequestMapping(value="/list")
  21. public String list(Model model, Order order, PageBean<Order> pageBean){
  22. model.addAttribute("pageBean", orderService.findPage(order, pageBean));
  23. model.addAttribute("sn",order.getSn());
  24. return "admin/order/list";
  25. }
  26. /**
  27. * 查看订单详情
  28. * @param orderId
  29. * @return
  30. */
  31. @RequestMapping(value="/view_detail",method=RequestMethod.POST)
  32. @ResponseBody
  33. public Result<List<OrderItem>> viewDetail(@RequestParam(name="orderId",required=true)Long orderId){
  34. return Result.success(orderItemService.find(orderId));
  35. }
  36. }

排片场次管理控制器:

  1. /**
  2. * 排片场次管理控制器
  3. * @author yy
  4. *
  5. */
  6. @RequestMapping("/admin/cinema_hall_session")
  7. @Controller
  8. public class CinemaHallSessionController {
  9. @Autowired
  10. private CinemaService cinemaService;
  11. @Autowired
  12. private CinemaHallService cinemaHallService;
  13. @Autowired
  14. private MovieService movieService;
  15. @Autowired
  16. private CinemaHallSessionService cinemaHallSessionService;
  17. /**
  18. * 排片场次列表页面
  19. * @param model
  20. * @return
  21. */
  22. @RequestMapping(value="/list")
  23. public String list(Model model, CinemaHallSession cinemaHallSession, PageBean<CinemaHallSession> pageBean){
  24. model.addAttribute("pageBean", cinemaHallSessionService.findPage(cinemaHallSession, pageBean));
  25. model.addAttribute("showDate",cinemaHallSession.getShowDate());
  26. return "admin/cinema_hall_session/list";
  27. }
  28. /**
  29. * 排片场次添加页面
  30. * @param model
  31. * @return
  32. */
  33. @RequestMapping(value="/add",method=RequestMethod.GET)
  34. public String add(Model model){
  35. model.addAttribute("cinemaList", cinemaService.findAll());
  36. model.addAttribute("movieList", movieService.findAll());
  37. model.addAttribute("cinemaSessionTypeList", CinemaSessionType.values());
  38. return "admin/cinema_hall_session/add";
  39. }
  40. /**
  41. * 排片场次编辑页面
  42. * @param model
  43. * @param id
  44. * @return
  45. */
  46. @RequestMapping(value="/edit",method=RequestMethod.GET)
  47. public String edit(Model model,@RequestParam(name="id",required=true)Long id){
  48. model.addAttribute("cinemaHallSession", cinemaHallSessionService.findById(id));
  49. model.addAttribute("movieList", movieService.findAll());
  50. model.addAttribute("cinemaList", cinemaService.findAll());
  51. model.addAttribute("cinemaSessionTypeList", CinemaSessionType.values());
  52. return "admin/cinema_hall_session/edit";
  53. }
  54. /**
  55. * 添加排片场次表单提交
  56. * @param cinemaHallSession
  57. * @return
  58. */
  59. @RequestMapping(value="/add",method=RequestMethod.POST)
  60. @ResponseBody
  61. public Result<Boolean> add(CinemaHallSession cinemaHallSession){
  62. if(cinemaHallSession == null){
  63. return Result.error(CodeMsg.DATA_ERROR);
  64. }
  65. CodeMsg validate = ValidateEntityUtil.validate(cinemaHallSession);
  66. if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
  67. return Result.error(validate);
  68. }
  69. //判断是否是编辑
  70. if(cinemaHallSession.getId() != null && cinemaHallSession.getId() > 0){
  71. CinemaHallSession findById = cinemaHallSessionService.findById(cinemaHallSession.getId());
  72. cinemaHallSession.setCreateTime(findById.getCreateTime());
  73. }
  74. //生成散场时间
  75. String startTime = cinemaHallSession.getShowDate() + " " + cinemaHallSession.getShowTime();
  76. cinemaHallSession.setStartTime(startTime);
  77. cinemaHallSession.setEndTime(StringUtil.getFormatterDate(startTime, "yyyy-MM-dd HH:mm", Integer.valueOf(cinemaHallSession.getMovie().getTime())));
  78. if(cinemaHallSessionService.isExistHall(cinemaHallSession.getId(),cinemaHallSession.getCinemaHall().getId(), cinemaHallSession.getShowDate(), startTime,cinemaHallSession.getEndTime())){
  79. return Result.error(CodeMsg.ADMIN_CINEMA_HALL_SESSION_SAVE_EXIST);
  80. }
  81. //表示数据合法,可以保存到数据库
  82. if(cinemaHallSessionService.save(cinemaHallSession) == null){
  83. return Result.error(CodeMsg.ADMIN_CINEMA_HALL_SESSION_SAVE_ERROR);
  84. }
  85. return Result.success(true);
  86. }
  87. /**
  88. * 删除
  89. * @param id
  90. * @return
  91. */
  92. @RequestMapping(value="/delete",method=RequestMethod.POST)
  93. @ResponseBody
  94. public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
  95. try {
  96. cinemaHallSessionService.delete(id);
  97. } catch (Exception e) {
  98. return Result.error(CodeMsg.ADMIN_CINEMA_HALL_SESSION_DELETE_ERROR);
  99. }
  100. return Result.success(true);
  101. }
  102. }

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

标签: java mysql springboot

本文转载自: https://blog.csdn.net/yuyecsdn/article/details/124218423
版权归原作者 pastclouds 所有, 如有侵权,请联系我们删除。

“Java项目:电影院会员管理系统(java+SpringBoot+Vue+element-ui+maven+mysql)”的评论:

还没有评论