• SpringBoot+Vue实现前后端分离的餐饮点餐系统


    文末获取源码

    开发语言:Java

    使用框架:spring boot

    前端技术:JavaScript、Vue.js 、css3

    开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code

    数据库:MySQL 5.7/8.0

    数据库管理工具:phpstudy/Navicat

    JDK版本:Java jdk8

    Maven:apache-maven 3.8.1-bin

    目录

    一、前言介绍 

    二、系统需求分析

    三、系统前台模块

    3.1系统首页页面

    3.2订餐资讯页面 

    3.3菜单页面 

    3.4菜品详情页面 

    3.5我的页面

    3.6支付页面 

    四、管理员功能模块

    4.1系统首页页面 

    4.2用户管理页面 

    4.3资讯管理页面

    4.4菜品管理页面

    4.5订单列表管理页面

    4.6订单统计管理页面

    五、部分核心代码

    5.1订餐资讯的逻辑代码 

    5.2订餐资讯分类管理逻辑代码

    5.3菜品管理的关键代码

    5.4订单信息管理关键代码

    5.5用户管理关键代码

    5.6用户功能关键代码

    5.7订单信息的关键代码


    一、前言介绍 

    科技进步带来的生产力的发展,其本质上是生产效率的提高。在社会快速发展的今天,效率永远是衡量一款产品的重要标准。在生活中,我们常常遇到这样的问题:上班期间,由于中午休息的时间基本一致,在一座写字楼中就往往会出现这样的问题,即在中午的某个时间段内将会出现人流的高度集中,大家选择在同一时间去食堂或者楼下的餐厅吃饭。这无疑会大大降低人们对于这段时间的利用效率。这时,人们可能会采取一种方式来回避高峰期,那就是叫外卖点餐。传统的外卖方式就是打电话预定,然而,在这种方式中,顾客往往通过餐厅散发的传单来获取餐厅的相关信息,通过电话来传达自己的订单信息,餐厅方面通过电话接受订单后,一般通过手写来记录,最后通过口头确认才算完成一份订单的提交,之后就是订单的完成和食品的递交。显然,在传统外卖流程中,顾客通过传单来接收信息,所能获得的信息太少,而且印发传单成本高昂,无疑那些面对大众的中低档餐厅不会或者很少印发传单;其次通过电话来接收订单,效率很低,耗时至少5到10分钟;最后,口头确认存在出错的风险,无法保证订单的有效性。而点餐系统或称之为餐饮点餐系统,将完美的解决以上的所有问题。

    二、系统需求分析

    餐饮点餐系统需要满足的需求有以下几个:

    1.信息获取方便,用户可在网页上快速浏览到新的信息

    2.查看菜品详情,单独查看某一个菜品信息,获取好评等。

    3.注册登录,餐饮需要吸引客户,即通过注册来提高用户的存留率。

    4.历史记录,用户可以查看自己订餐信息以及其他操作。

    5.修改用户信息,可以修改用户密码或者用户名等一些个性化操作。

    6.管理员功能,管理员可以对用户或者点餐进行管理。

    7.系统安全,操作简便,不过于复杂。

    8.系统可以稳定运行,不存在卡顿等问题造成用户反感。

    三、系统前台模块

    3.1系统首页页面

    3.2订餐资讯页面 

    3.3菜单页面 

    3.4菜品详情页面 

    3.5我的页面

    3.6支付页面 

    四、管理员功能模块

    4.1系统首页页面 

    4.2用户管理页面 

    4.3资讯管理页面

    4.4菜品管理页面

    4.5订单列表管理页面

    4.6订单统计管理页面

    五、部分核心代码

    5.1订餐资讯的逻辑代码 

    1. @RequestMapping("/get_obj")
    2. public Map<String, Object> obj(HttpServletRequest request) {
    3. Query select = service.select(service.readQuery(request), service.readConfig(request));
    4. List resultList = select.getResultList();
    5. if (resultList.size() > 0) {
    6. JSONObject jsonObject = new JSONObject();
    7. jsonObject.put("obj",resultList.get(0));
    8. return success(jsonObject);
    9. } else {
    10. return success(null);
    11. }
    12. }
    13. public Query select(Map<String,String> query,Map<String,String> config){
    14. StringBuffer sql = new StringBuffer("select ");
    15. sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");
    16. sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));
    17. if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){
    18. sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");
    19. }
    20. if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){
    21. sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");
    22. }
    23. if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){
    24. int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;
    25. int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;
    26. sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);
    27. }
    28. log.info("[{}] - 查询操作,sql: {}",table,sql);
    29. return runEntitySql(sql.toString());
    30. }

    5.2订餐资讯分类管理逻辑代码

    1. @RequestMapping("/get_list")
    2. public Map<String, Object> getList(HttpServletRequest request) {
    3. Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
    4. return success(map);
    5. }

    5.3菜品管理的关键代码

    1. @PostMapping("/add")
    2. @Transactional
    3. public Map<String, Object> add(HttpServletRequest request) throws IOException {
    4. service.insert(service.readBody(request.getReader()));
    5. return success(1);
    6. }
    7. @Transactional
    8. public Map<String, Object> addMap(Map<String,Object> map){
    9. service.insert(map);
    10. return success(1);
    11. }
    12. public Map<String,Object> readBody(BufferedReader reader){
    13. BufferedReader br = null;
    14. StringBuilder sb = new StringBuilder("");
    15. try{
    16. br = reader;
    17. String str;
    18. while ((str = br.readLine()) != null){
    19. sb.append(str);
    20. }
    21. br.close();
    22. String json = sb.toString();
    23. return JSONObject.parseObject(json, Map.class);
    24. }catch (IOException e){
    25. e.printStackTrace();
    26. }finally{
    27. if (null != br){
    28. try{
    29. br.close();
    30. }catch (IOException e){
    31. e.printStackTrace();
    32. }
    33. }
    34. }
    35. return null;
    36. }
    37. public void insert(Map<String,Object> body){
    38. StringBuffer sql = new StringBuffer("INSERT INTO ");
    39. sql.append("`").append(table).append("`").append(" (");
    40. for (Map.Entry<String,Object> entry:body.entrySet()){
    41. sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
    42. }
    43. sql.deleteCharAt(sql.length()-1);
    44. sql.append(") VALUES (");
    45. for (Map.Entry<String,Object> entry:body.entrySet()){
    46. Object value = entry.getValue();
    47. if (value instanceof String){
    48. sql.append("'").append(entry.getValue()).append("'").append(",");
    49. }else {
    50. sql.append(entry.getValue()).append(",");
    51. }
    52. }
    53. sql.deleteCharAt(sql.length() - 1);
    54. sql.append(")");
    55. log.info("[{}] - 插入操作:{}",table,sql);
    56. Query query = runCountSql(sql.toString());
    57. query.executeUpdate();
    58. }

    5.4订单信息管理关键代码

    1. @RequestMapping(value = {"/avg_group", "/avg"})
    2. public Map<String, Object> avg(HttpServletRequest request) {
    3. Query count = service.avg(service.readQuery(request), service.readConfig(request));
    4. return success(count.getResultList());
    5. }

    5.5用户管理关键代码

    1. @PostMapping("/add")
    2. @Transactional
    3. public Map<String, Object> add(HttpServletRequest request) throws IOException {
    4. service.insert(service.readBody(request.getReader()));
    5. return success(1);
    6. }
    7. @Transactional
    8. public Map<String, Object> addMap(Map<String,Object> map){
    9. service.insert(map);
    10. return success(1);
    11. }
    12. public Map<String,Object> readBody(BufferedReader reader){
    13. BufferedReader br = null;
    14. StringBuilder sb = new StringBuilder("");
    15. try{
    16. br = reader;
    17. String str;
    18. while ((str = br.readLine()) != null){
    19. sb.append(str);
    20. }
    21. br.close();
    22. String json = sb.toString();
    23. return JSONObject.parseObject(json, Map.class);
    24. }catch (IOException e){
    25. e.printStackTrace();
    26. }finally{
    27. if (null != br){
    28. try{
    29. br.close();
    30. }catch (IOException e){
    31. e.printStackTrace();
    32. }
    33. }
    34. }
    35. return null;
    36. }
    37. public void insert(Map<String,Object> body){
    38. StringBuffer sql = new StringBuffer("INSERT INTO ");
    39. sql.append("`").append(table).append("`").append(" (");
    40. for (Map.Entry<String,Object> entry:body.entrySet()){
    41. sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
    42. }
    43. sql.deleteCharAt(sql.length()-1);
    44. sql.append(") VALUES (");
    45. for (Map.Entry<String,Object> entry:body.entrySet()){
    46. Object value = entry.getValue();
    47. if (value instanceof String){
    48. sql.append("'").append(entry.getValue()).append("'").append(",");
    49. }else {
    50. sql.append(entry.getValue()).append(",");
    51. }
    52. }
    53. sql.deleteCharAt(sql.length() - 1);
    54. sql.append(")");
    55. log.info("[{}] - 插入操作:{}",table,sql);
    56. Query query = runCountSql(sql.toString());
    57. query.executeUpdate();
    58. }

    5.6用户功能关键代码

    1. @RequestMapping("/get_obj")
    2. public Map<String, Object> obj(HttpServletRequest request) {
    3. Query select = service.select(service.readQuery(request), service.readConfig(request));
    4. List resultList = select.getResultList();
    5. if (resultList.size() > 0) {
    6. JSONObject jsonObject = new JSONObject();
    7. jsonObject.put("obj",resultList.get(0));
    8. return success(jsonObject);
    9. } else {
    10. return success(null);
    11. }
    12. }
    13. public Query select(Map<String,String> query,Map<String,String> config){
    14. StringBuffer sql = new StringBuffer("select ");
    15. sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");
    16. sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));
    17. if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){
    18. sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");
    19. }
    20. if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){
    21. sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");
    22. }
    23. if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){
    24. int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;
    25. int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;
    26. sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);
    27. }
    28. log.info("[{}] - 查询操作,sql: {}",table,sql);
    29. return runEntitySql(sql.toString());
    30. }

    5.7订单信息的关键代码

    1. @RestController
    2. @RequestMapping("auth")
    3. public class AuthController extends BaseController, AuthService> {
    4. /**
    5. * 服务对象
    6. */
    7. @Autowired
    8. public AuthController(AuthService service) {
    9. setService(service);
    10. }
    11. }
  • 相关阅读:
    jsp初学
    linux文件夹操作函数
    Spring5入门到实战------10、操作术语解释--Aspectj注解开发实例。AOP切面编程的实际应用
    Linux系统编程(二):文件和目录
    递归思想
    基于sklearn的集成学习实战
    Windows安装Go语言及VScode配置
    掌握软件安装的 9 个要点
    MySQL存储引擎
    上海00后985毕业女生月薪1.2w,想找年薪40万程序员,网友表示很不理解
  • 原文地址:https://blog.csdn.net/m0_49113107/article/details/128104906