当前位置:   article > 正文

SpringBoot+Vue实现中小学餐饮配送系统_中小学配餐管理小程序的设计和实现

中小学配餐管理小程序的设计和实现

文末获取源码

开发语言:Java

使用框架:spring boot

前端技术:JavaScript、Vue 、css3

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

数据库:MySQL 5.7/8.0

数据库管理工具:phpstudy/Navicat

JDK版本:Java jdk8

Maven:apache-maven 3.8.1-bin

一、前言介绍 

本系统地描绘了整个中小学餐饮配送系统的设计与实现,主要实现的功能有以下几点:首页、站点管理(管理员、普通用户)内容管理(资讯列表、资讯分类)更多管理(餐品信息管理、分类管理、订单管理)系统管理等功能,其具有简单的接口,方便的应用,强大的互动,完全基于互联网的特点。

现代社会的网络和信息技术不断提高,人们的生活水平达到一个新的水平。点餐成为一种人们习以为常的生活方式,一个充分利用碎片化时间,简化点餐配送过程的程序,正是我们所需要的。这篇文章研究了基于springboot的中小学餐饮配送系统的开发和实现,从需求分析、总体设计到具体实现,最终完成了整个中小学餐饮配送系统。

二、系统需求分析

中小学餐饮配送系统需要满足的需求有以下几个:

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

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

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

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

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

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

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

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

三、用户功能模块

3.1用户首页 

中小学餐饮配送系统,在系统首页可以查看首页、餐品信息、订单信息、美食资讯跳转到后台等内容,如图所示。

3.2美食资讯管理

在美食资讯管理可以查看标题、内容等信息,如图所示。

3.3餐品信息管理

3.4餐品详情

3.5个人中心

在用户信息列表中通过填写用户账号、密码、用户姓名、性别、手机、照片等信息进行提交,如图所示。 

四、管理员功能模块

管理员登录进入中小学餐饮配送系统可以查看首页、站点管理(管理员、普通用户)内容管理(资讯列表、资讯分类)更多管理(餐品信息管理、分类管理、订单管理)系统管理等信息,如图所示。

4.1站点管理

4.2用户管理

4.3内容管理

4.3更多管理

五、部分核心代码

5.1用户注册逻辑代码

  1. /**
  2. * 注册
  3. * @param user
  4. * @return
  5. */
  6. @PostMapping("register")
  7. public Map<String, Object> signUp(@RequestBody User user) {
  8. // 查询用户
  9. Map<String, String> query = new HashMap<>();
  10. query.put("username",user.getUsername());
  11. List list = service.select(query, new HashMap<>()).getResultList();
  12. if (list.size()>0){
  13. return error(30000, "用户已存在");
  14. }
  15. user.setUserId(null);
  16. user.setPassword(service.encryption(user.getPassword()));
  17. service.save(user);
  18. return success(1);
  19. }

5.2餐品信息管理的逻辑代码

  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.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. @RestController
  2. @RequestMapping("auth")
  3. public class AuthController extends BaseController<Auth, AuthService> {
  4. /**
  5. * 服务对象
  6. */
  7. @Autowired
  8. public AuthController(AuthService service) {
  9. setService(service);
  10. }
  11. }

 

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

闽ICP备14008679号