springboot基于微信小程序的智能校园点餐管理系统(源码+vue+uinapp+部署文档等)

207 篇文章 17 订阅
141 篇文章 17 订阅

收藏关注不迷路!!

🌟文末获取源码+数据库🌟

感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人


前言

💗博主介绍:✨全网拥有20W+粉丝、CSDN作者、博客专家、全栈领域优质创作者、平台优质Java创作者、专注于Java、小程序、python、安卓技术领域和毕业项目实战✌💟!✨💗

👇🏻 精彩专栏 推荐订阅👇🏻

计算机毕业设计设计精品实战案例

感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,博主免费解答、希望可以帮助更多人

  

详细视频演示

文章底部名片,获取项目的完整演示视频,免费解答技术疑问

项目介绍

  
人类现已迈入二十一世纪,科学技术日新月异,经济、资讯等各方面都有了非常大的进步,尤其是资讯与网络技术的飞速发展,对政治、经济、军事、文化等各方面都有了极大的影响。
利用安卓操作系统下的应用平台,发展一套智能校园点餐管理系统,将会给餐厅带来更大的效益,而在智能校园点餐管理效能上,也必然会有很大的方便!这样可以节省大量的人力、时间和金钱。该系统主要包括菜品信息、优惠券、订单信息等。方便了管理员随时随地,只要电脑联网,就能对所有信息等进行管理。
本篇论文对智能校园点餐管理系统的需求分析、功能设计、系统设计进行了较为详尽的阐述,并对系统的整体设计进行了阐述,并对各功能的实现和主要功能进行了说明,并附上了相应的操作界面图。

技术介绍

开发语言:Java
框架:springboot
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven

安卓框架:uniapp
安卓开发软件:HBuilder X
开发模式:混合开发

功能介绍

总体上看,智能校园点餐管理系统具有用户管理、用户管理、餐厅管理、美食分类管理、菜品信息管理、优惠券管理、系统管理、订单管理、我的信息等功能模块。
系统总体功能结构图如下所示:
在这里插入图片描述

图4-1系统总体结构图

核心代码


package com.example.controller;

import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.Caiwu;
import com.example.exception.CustomException;
import com.example.service.CaiwuService;
import com.example.utils.MapWrapperUtils;
import com.example.utils.jwt.JwtUtil;
import com.example.vo.CaiwuVo;
import org.springframework.beans.BeanUtils;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@RestController
@RequestMapping(value = "/caiwu")
public class CaiwuController {

    @Resource
    private CaiwuService caiwuService;

    @PostMapping
    public Result<Caiwu> add(@RequestBody CaiwuVo caiwu) {
        caiwuService.add(caiwu);
           return Result.success(caiwu);
    }
	
	

    @PostMapping("/deleteList")
    public Result<Caiwu> deleteList(@RequestBody CaiwuVo caiwu) {
        caiwuService.deleteList(caiwu.getList());
        return Result.success();
    }

    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Long id) {
        caiwuService.delete(id);
        return Result.success();
    }

    @PutMapping
    public Result update(@RequestBody CaiwuVo caiwu) {
        caiwuService.update(caiwu);
        return Result.success();
    }

    @GetMapping("/{id}")
    public Result<Caiwu> detail(@PathVariable Integer id) {
        Caiwu caiwu = caiwuService.findById(id);
        return Result.success(caiwu);
    }

    @GetMapping
    public Result<List<Caiwu>> all() {
        return Result.success(caiwuService.list());
    }

    @PostMapping("/page")
    public Result<CaiwuVo> page(@RequestBody CaiwuVo caiwuVo) {
        return Result.success(caiwuService.findPage(caiwuVo));
    }
	    @PostMapping("/login")
    public Result login(@RequestBody Caiwu caiwu, HttpServletRequest request) {
        if (StrUtil.isBlank(caiwu.getZhanghao()) || StrUtil.isBlank(caiwu.getMima())) {
            throw new CustomException(ResultCode.PARAM_LOST_ERROR);
        }
        Caiwu login = caiwuService.login(caiwu);
//        if(!login.getStatus()){
//            return Result.error("1001","状态限制,无法登录系统");
//        }
        if(login != null) {
            HashMap hashMap = new HashMap();
            hashMap.put("user", login);
            Map<String, Object> map = MapWrapperUtils.builder(MapWrapperUtils.KEY_USER_ID,caiwu.getId());
            String token = JwtUtil.creatToken(map);
            hashMap.put("token", token);
            return Result.success(hashMap);
        }else {
            return Result.error();
        }
    }
    @PutMapping("/updatePassword")
    public Result updatePassword(@RequestBody Caiwu info, HttpServletRequest request) {
        Caiwu caiwu = caiwuService.findById(info.getId());
        String oldPassword = SecureUtil.md5(info.getMima());
        if (!oldPassword.equals(caiwu.getMima())) {
            return Result.error(ResultCode.PARAM_PASSWORD_ERROR.code, ResultCode.PARAM_PASSWORD_ERROR.msg);
        }
        info.setMima(SecureUtil.md5(info.getNewPassword()));
        Caiwu caiwu1 = new Caiwu();
        BeanUtils.copyProperties(info, caiwu1);
        caiwuService.update(caiwu1);
        return Result.success();
    }
}


数据库参考


--
-- Current Database: `springboot6c54bft3`
--

/*!40000 DROP DATABASE IF EXISTS `springboot6c54bft3`*/;

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `springboot6c54bft3` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;

USE `springboot6c54bft3`;

--
-- Table structure for table `address`
--

DROP TABLE IF EXISTS `address`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `address` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `userid` bigint(20) NOT NULL COMMENT '用户id',
  `address` varchar(200) NOT NULL COMMENT '地址',
  `name` varchar(200) NOT NULL COMMENT '收货人',
  `phone` varchar(200) NOT NULL COMMENT '电话',
  `isdefault` varchar(200) NOT NULL COMMENT '是否默认地址[是/否]',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8 COMMENT='地址';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `address`
--

LOCK TABLES `address` WRITE;
/*!40000 ALTER TABLE `address` DISABLE KEYS */;
INSERT INTO `address` VALUES (1,'2024-01-08 02:41:48',11,'宇宙银河系金星1号','金某','13823888881','是'),(2,'2024-01-08 02:41:48',12,'宇宙银河系木星1号','木某','13823888882','是'),(3,'2024-01-08 02:41:48',13,'宇宙银河系水星1号','水某','13823888883','是'),(4,'2024-01-08 02:41:48',14,'宇宙银河系火星1号','火某','13823888884','是'),(5,'2024-01-08 02:41:48',15,'宇宙银河系土星1号','土某','13823888885','是'),(6,'2024-01-08 02:41:48',16,'宇宙银河系月球1号','月某','13823888886','是'),(7,'2024-01-08 02:41:48',17,'宇宙银河系黑洞1号','黑某','13823888887','是'),(8,'2024-01-08 02:41:48',18,'宇宙银河系地球1号','地某','13823888888','是');
/*!40000 ALTER TABLE `address` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `caipinxinxi`
--

DROP TABLE IF EXISTS `caipinxinxi`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `caipinxinxi` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `caipinmingcheng` varchar(200) NOT NULL COMMENT '菜品名称',
  `tupian` longtext COMMENT '图片',
  `meishifenlei` varchar(200) DEFAULT NULL COMMENT '美食分类',
  `kouwei` varchar(200) DEFAULT NULL COMMENT '口味',
  `caipinxiangqing` longtext COMMENT '菜品详情',
  `cantingmingcheng` varchar(200) DEFAULT NULL COMMENT '餐厅名称',
  `lianxidianhua` varchar(200) DEFAULT NULL COMMENT '联系电话',
  `cantingdizhi` varchar(200) DEFAULT NULL COMMENT '餐厅地址',
  `onelimittimes` int(11) DEFAULT NULL COMMENT '单限',
  `alllimittimes` int(11) DEFAULT NULL COMMENT '库存',
  `thumbsupnum` int(11) DEFAULT '0' COMMENT '赞',
  `crazilynum` int(11) DEFAULT '0' COMMENT '踩',
  `clicktime` datetime DEFAULT NULL COMMENT '最近点击时间',
  `clicknum` int(11) DEFAULT '0' COMMENT '点击次数',
  `discussnum` int(11) DEFAULT '0' COMMENT '评论数',
  `price` double NOT NULL COMMENT '价格',
  `storeupnum` int(11) DEFAULT '0' COMMENT '收藏数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=49 DEFAULT CHARSET=utf8 COMMENT='菜品信息';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `caipinxinxi`
--

LOCK TABLES `caipinxinxi` WRITE;
/*!40000 ALTER TABLE `caipinxinxi` DISABLE KEYS */;
INSERT INTO `caipinxinxi` VALUES (41,'2024-01-08 02:41:48','菜品名称1','upload/caipinxinxi_tupian1.jpg,upload/caipinxinxi_tupian2.jpg,upload/caipinxinxi_tupian3.jpg','美食分类1','口味1','菜品详情1','餐厅名称1','13823888881','餐厅地址1',1,99,1,1,'2024-01-08 10:41:48',1,0,99.9,1),(42,'2024-01-08 02:41:48','菜品名称2','upload/caipinxinxi_tupian2.jpg,upload/caipinxinxi_tupian3.jpg,upload/caipinxinxi_tupian4.jpg','美食分类2','口味2','菜品详情2','餐厅名称2','13823888882','餐厅地址2',2,99,2,2,'2024-01-08 10:41:48',2,0,99.9,2),(43,'2024-01-08 02:41:48','菜品名称3','upload/caipinxinxi_tupian3.jpg,upload/caipinxinxi_tupian4.jpg,upload/caipinxinxi_tupian5.jpg','美食分类3','口味3','菜品详情3','餐厅名称3','13823888883','餐厅地址3',3,99,3,3,'2024-01-08 10:41:48',3,0,99.9,3),(44,'2024-01-08 02:41:48','菜品名称4','upload/caipinxinxi_tupian4.jpg,upload/caipinxinxi_tupian5.jpg,upload/caipinxinxi_tupian6.jpg','美食分类4','口味4','菜品详情4','餐厅名称4','13823888884','餐厅地址4',4,99,4,4,'2024-01-08 10:41:48',4,0,99.9,4),(45,'2024-01-08 02:41:48','菜品名称5','upload/caipinxinxi_tupian5.jpg,upload/caipinxinxi_tupian6.jpg,upload/caipinxinxi_tupian7.jpg','美食分类5','口味5','菜品详情5','餐厅名称5','13823888885','餐厅地址5',5,99,5,5,'2024-01-08 10:48:22',7,0,99.9,5),(46,'2024-01-08 02:41:48','菜品名称6','upload/caipinxinxi_tupian6.jpg,upload/caipinxinxi_tupian7.jpg,upload/caipinxinxi_tupian8.jpg','美食分类6','口味6','菜品详情6','餐厅名称6','13823888886','餐厅地址6',6,99,6,6,'2024-01-08 10:48:52',7,0,99.9,6),(47,'2024-01-08 02:41:48','菜品名称7','upload/caipinxinxi_tupian7.jpg,upload/caipinxinxi_tupian8.jpg,upload/caipinxinxi_tupian9.jpg','美食分类7','口味7','菜品详情7','餐厅名称7','13823888887','餐厅地址7',7,99,7,7,'2024-01-08 10:41:48',7,0,99.9,7),(48,'2024-01-08 02:41:48','菜品名称8','upload/caipinxinxi_tupian8.jpg,upload/caipinxinxi_tupian9.jpg,upload/caipinxinxi_tupian10.jpg','美食分类8','口味8','菜品详情8','餐厅名称8','13823888888','餐厅地址8',8,99,8,8,'2024-01-08 10:54:16',11,0,99.9,8);
/*!40000 ALTER TABLE `caipinxinxi` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `canting`
--

DROP TABLE IF EXISTS `canting`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `canting` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `cantingmingcheng` varchar(200) NOT NULL COMMENT '餐厅名称',
  `mima` varchar(200) NOT NULL COMMENT '密码',
  `cantingtupian` longtext NOT NULL COMMENT '餐厅图片',
  `cantingdizhi` varchar(200) DEFAULT NULL COMMENT '餐厅地址',
  `lianxiren` varchar(200) DEFAULT NULL COMMENT '联系人',
  `lianxidianhua` varchar(200) DEFAULT NULL COMMENT '联系电话',
  `zizhizhengming` longtext COMMENT '资质证明',
  `cantingjieshao` longtext COMMENT '餐厅介绍',
  `sfsh` varchar(200) DEFAULT '待审核' COMMENT '是否审核',
  `shhf` longtext COMMENT '审核回复',
  `money` double DEFAULT '0' COMMENT '余额',
  `status` int(11) DEFAULT '0' COMMENT '状态',
  `passwordwrongnum` int(11) DEFAULT '0' COMMENT '密码错误次数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8 COMMENT='餐厅';
/*!40101 SET character_set_client = @saved_cs_client */;

系统效果图

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

文章目录

目 录
摘 要 I
Pick to II
1绪论 1
1.1项目研究的背景 1
1.2开发意义 1
1.3项目研究现状及内容 2
1.4论文结构 3
2开发技术介绍 3
2.2 java简介 3
2.3 MySQL环境配置 4
2.3微信技术 4
3.1.1微信开发者工具 5
3.1.2 HTML 5
3.1.3 CSS 5
3系统分析 6
3.1 系统可行性分析 6
3.1.1 经济可行性 6
3.1.2 技术可行性 7
3.1.3 运行可行性 7
3.1.4 操作可行性 7
3.2 网站现状分析 7
3.3系统流程的分析 8
3.3.2 添加信息流程 10
3.3.3 删除信息流程 10
4系统设计 11
4.1 软件功能模块设计 11
4.2 数据库设计 11
5系统详细设计 18
5.1管理员功能模块 18
5.2 小程序端 21
6系统测试 26
6.1 功能测试 26
6.2 可用性测试 26
6.3 性能测试 27
6.4 测试结果分析 27
7总结与心得体会 28
7.1 总结 28
7.2 心得体会 28
参考文献 30
致 谢 31

源码获取

下方名片联系我即可!!


大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

QQ1039692211

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值