当前位置:   article > 正文

Java项目:餐厅点餐系统(java+SpringBoot+HTML+layui+Echarts+mysql)_java餐厅点餐系统

java餐厅点餐系统

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

项目介绍

Springboot餐厅点餐系统分为前后台,前台顾客可以进行点餐,后台可以由经理、收银员、厨师、服务员等角色登录;
前台主要功能如下:
桌位选择、菜品选择、提交菜单等功能;

后台主要功能如下:
主页控制台
员工列表:员工查询、新增、编辑、删除;
会员管理:会员列表、会员类型列表;
菜谱管理:菜品列表、种类列表;
订单管理:订单列表;
销售管理:销售统计、销量统计、交易记录;
制菜上菜管理:制菜任务列表、上菜任务列表、桌位上菜情况列表;
桌位管理:桌位列表;


环境需要

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


技术栈

后端:SpringBoot+Mybaits

前端:HTML+css+js+layui+Echarts


使用说明

项目运行:
1. 使用Navicat或者其它工具,在mysql中创建对应sql文件名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中application.yml配置文件中的数据库配置改为自己的配置;
4. 控制台提示运行成功后再运行前端项目;
5. 运行项目,在浏览器中输入地址
后台登录地址:http://localhost:8181/restaurant/sysuser/login.html 
前台点餐登录地址:http://localhost:8181/restaurant/guest/desklist.html 
经理测试号  账号 18384623911 密码123456 
收银员测试号 账号 18384623912 密码 123456 
厨师测试号  账号 18384623913 密码 123456 
服务员   账号 18384623914 密码 123456 


注意事项:

为防止项目运行后图片找不到,请将“images”文件夹中的“restaurant”文件夹放到D盘根目录。如果想放到其他盘,请修改application.yml配置文件中对应路径  

角色介绍:

功能介绍:

 前后台展示图例:

 

 订桌页面:

 

 菜品管理:

 

点餐管理: 

 

提交菜单列表:

 

 后台统计展示:

 

后台销售展示:

 

后台登陆管理控制层:

  1. /**
  2. * 后台登陆
  3. */
  4. @Controller
  5. @RequestMapping("")
  6. public class LoginController {
  7. @Autowired
  8. UserService userService;
  9. @RequestMapping(value="/login",method=RequestMethod.POST)
  10. public String login(Model model, String name, String password){//throws ParseException
  11. Subject subject = SecurityUtils.getSubject();
  12. UsernamePasswordToken token = new UsernamePasswordToken(name,password);
  13. try {
  14. subject.login(token);
  15. User us = userService.getByName(name);
  16. String lastLoginTime = "";
  17. if(us!=null){
  18. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  19. //上次时间
  20. Date time = us.getLasttime();
  21. lastLoginTime = sdf.format(time);
  22. //新时间
  23. String format = sdf.format(new Date());
  24. //string转date 不处理时间格式会不理想
  25. ParsePosition pos = new ParsePosition(0);
  26. Date strtodate = sdf.parse(format, pos);
  27. us.setLasttime(strtodate);
  28. userService.update(us);
  29. }
  30. if (us.getStatus()==1){
  31. Session session=subject.getSession();
  32. session.setAttribute("subject", subject);
  33. session.setAttribute("lastLoginTime",lastLoginTime);
  34. return "redirect:index";
  35. }else {
  36. model.addAttribute("error", "账号已被停用!");
  37. return "/login";
  38. }
  39. } catch (AuthenticationException e) {
  40. model.addAttribute("error", "验证失败!");
  41. return "/login";
  42. }
  43. }
  44. }

订单管理控制层:

  1. /**
  2. * 订单模块controller
  3. */
  4. @Controller
  5. @RequestMapping("/order")
  6. public class OrderController {
  7. @Autowired
  8. OrderService orderService;
  9. @Autowired
  10. OrderItemService orderItemService;
  11. /**
  12. * 所有订单
  13. * @param model
  14. * @param page
  15. * @return
  16. */
  17. @RequestMapping("/list")
  18. public String list(Model model, Page page){
  19. PageHelper.offsetPage(page.getStart(),page.getCount());
  20. List<Order> os= orderService.list();
  21. int total = (int) new PageInfo<>(os).getTotal();
  22. page.setTotal(total);
  23. //为订单添加订单项数据
  24. orderItemService.fill(os);
  25. model.addAttribute("os", os);
  26. model.addAttribute("page", page);
  27. model.addAttribute("totals", total);
  28. return "ordermodule/order-list";
  29. }
  30. /**
  31. * 订单发货
  32. * @param o
  33. * @return
  34. */
  35. @RequestMapping("/orderDelivery")
  36. public String delivery(Order o){
  37. o.setStatus(2);
  38. orderService.update(o);
  39. return "redirect:list";
  40. }
  41. /**
  42. * 查看当前订单的订单项
  43. * @param oid
  44. * @param model
  45. * @return
  46. */
  47. @RequestMapping("/seeOrderItem")
  48. public String seeOrderItem(int oid,Model model){
  49. Order o = orderService.get(oid);
  50. orderItemService.fill(o);
  51. model.addAttribute("orderItems",o.getOrderItems());
  52. model.addAttribute("total",o.getOrderItems().size());
  53. model.addAttribute("totalPrice",o.getTotal());
  54. return "ordermodule/orderItem-list";
  55. }
  56. }

用户管理控制层:

  1. /**
  2. * 管理员controller
  3. */
  4. @Controller
  5. @RequestMapping("/config")
  6. public class UserController {
  7. @Autowired
  8. UserRoleService userRoleService;
  9. @Autowired
  10. UserService userService;
  11. @Autowired
  12. RoleService roleService;
  13. @RequestMapping("/enableStatus")
  14. @ResponseBody
  15. public String enableStatus(@RequestParam(value = "name") String name){
  16. return userService.enableStatus(name);
  17. }
  18. @RequestMapping("/stopStatus")
  19. @ResponseBody
  20. public String stopStatus(@RequestParam(value = "name") String name){
  21. return userService.stopStatus(name);
  22. }
  23. @RequestMapping("/adminAdd")
  24. public String adminadd(Model model){
  25. List<Role> list = roleService.list();
  26. model.addAttribute("rolelist",list);
  27. return "syspage/admin-add";
  28. }
  29. @RequestMapping("/listUser")
  30. public String list(Model model, Page page){
  31. PageHelper.offsetPage(page.getStart(),page.getCount());//分页查询
  32. List<User> us= userService.list();
  33. int total = (int) new PageInfo<>(us).getTotal();//总条数
  34. page.setTotal(total);
  35. model.addAttribute("us", us);//所有用户
  36. model.addAttribute("total",total);
  37. Map<User,List<Role>> user_roles = new HashMap<>();
  38. //每个用户对应的权限
  39. for (User user : us) {
  40. List<Role> roles=roleService.listRoles(user);
  41. user_roles.put(user, roles);
  42. }
  43. model.addAttribute("user_roles", user_roles);
  44. return "syspage/admin-list";
  45. }
  46. /**
  47. * 修改管理员角色
  48. * @param model
  49. * @param id
  50. * @return
  51. */
  52. @RequestMapping("/editUser")
  53. public String edit(Model model,Long id){
  54. List<Role> rs = roleService.list();
  55. model.addAttribute("rs", rs);
  56. User user =userService.get(id);
  57. model.addAttribute("user", user);
  58. //当前拥有的角色
  59. List<Role> roles =roleService.listRoles(user);
  60. model.addAttribute("currentRoles", roles);
  61. return "syspage/admin-edit";
  62. }
  63. @RequestMapping("deleteUser")
  64. public String delete(Model model,long id){
  65. userService.delete(id);
  66. return "redirect:listUser";
  67. }
  68. @RequestMapping("updateUser")
  69. public String update(User user, long[] roleIds){
  70. userRoleService.setRoles(user,roleIds);
  71. String password=user.getPassword();
  72. //如果在修改的时候没有设置密码,就表示不改动密码
  73. if(user.getPassword().length()!=0) {
  74. String salt = new SecureRandomNumberGenerator().nextBytes().toString();
  75. int times = 2;
  76. String algorithmName = "md5";
  77. String encodedPassword = new SimpleHash(algorithmName,password,salt,times).toString();
  78. user.setSalt(salt);
  79. user.setPassword(encodedPassword);
  80. }
  81. else
  82. user.setPassword(null);
  83. userService.update(user);
  84. return "redirect:listUser";
  85. }
  86. @RequestMapping("addUser")
  87. public String add(User user,long[] roleIds){
  88. String salt = new SecureRandomNumberGenerator().nextBytes().toString();//生成随机数
  89. int times = 2;
  90. String algorithmName = "md5";
  91. String encodedPassword = new SimpleHash(algorithmName,user.getPassword(),salt,times).toString();
  92. User u = new User();
  93. u.setName(user.getName());
  94. u.setPassword(encodedPassword);
  95. u.setSalt(salt);
  96. u.setStatus(1);
  97. u.setAddress(user.getAddress());
  98. u.setPhone(user.getPhone());
  99. userService.add(u);
  100. userRoleService.setRoles(u,roleIds);
  101. return "redirect:listUser";
  102. }
  103. }

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/555468
推荐阅读
相关标签
  

闽ICP备14008679号