💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发、文档编写、答疑辅导等。
👇🏻 精彩专栏 推荐订阅👇🏻
计算机毕业设计精品项目案例(持续更新)
🌟文末获取源码+数据库+文档🌟
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以和学长沟通,希望帮助更多的人
一.前言
随着校园规模的扩大和学生群体的多元化,传统的餐饮服务模式已难以满足学生日益增长的就餐需求。排队等候时间长、菜单选择有限、就餐时间集中等问题频现,影响了学生的就餐体验和效率。因此,开发一个集在线浏览菜单、预订餐品、支付结算、配送服务于一体的校园点餐服务系统,成为提升校园餐饮服务品质、优化学生就餐体验的重要途径。这一系统旨在通过数字化手段,实现餐饮服务的智能化与个性化,为广大学生提供更加便捷、高效、丰富的餐饮选择。
本基于微信小程序的校园点餐服务系统采用小程序、SpringBoot架构技术,微信端以小程序页面呈现给用户,结合后台java语言使页面更加完善,后台使用MySQL数据库进行数据存储。该系统可以被全面、广泛的运用。它使得传统的管理系统向电子化、智能化、综合化方向发展,实现集中管理、分散操作、共享信息。
二.技术环境
jdk版本:1.8 及以上
ide工具:Eclipse或者 IDEA,微信小程序开发工具
数据库: mysql5.7 (必须5.7)
编程语言: Java
java框架:SpringBoot
maven: 3.6.1
详细技术:HTML+CSS+JAVA+SpringBoot+MYSQL+VUE+MAVEN+微信开发工具
三.功能设计
本系统采用前后端分离的方式进行设计,前台小程序端的主体是用户、后台的主体是管理员和餐厅;其用例分别如下:
管理员用例图如图所示。
餐厅用例图如图所示。
用户用例图如图所示。
程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
四.数据设计
数据库概念模型的设计是为了抽象真实世界的信息,并对信息世界进行建模。它是数据库设计的强大工具。数据库概念模型设计可以通过E-R图描述现实世界的概念模型。而且Mysql数据库是自我保护能力比较强的数据库,在系统中的局部E-R图,如图所示:
五.部分效果展示
5.1用户微信端功能实现效果
第一次使用本小程序的使用者,首先是要进行注册,点击“注册”,然后就会进入到注册的页面里面,将用户信息录入注册表,确认信息正确后,系统才会进入登录界面,用户登录成功后可使用本小程序所提供的所有功能。用户注册界面如图所示。
小程序首页是用户注册登录后进入的第一个界面,用户可通过小程序端首页的最下面的那一行导航栏中的“首页、菜品信息、购物车、我的”进入到相应的网页进行操作;点击“我的”进入我的页面,在我的页面可以对我的订单、我的收藏、用户充值、我的优惠券、购物车等进行详细操作。小程序首页界面如图所示。
用户点击菜品信息,在菜品信息页面的搜索栏输入菜品名称,进行查询,然后可以查看菜品名称、图片、美食分类、口味、餐厅名称、联系电话、餐厅地址、单限、库存、点击次数、评论数、价格、收藏数等信息,如有需要可以加入购物车、立即购买、收藏或者评论等操作。如图所示。
用户点击“我的”进入我的页面,在我的页面可以对我的订单、我的收藏、用户充值、我的优惠券、购物车等进行详细操作。如图所示。
5.2管理员服务端功能实现效果
管理员登录,通过登录页面填写用户名和密码、选择角色等信息,点击登录操作,如图所示。
管理员登录进入系统可以查看系统首页、用户管理、餐厅管理、美食分类管理、菜品信息管理、优惠券管理、系统管理、订单管理、我的信息等功能进行详细操作。
管理员点击餐厅管理;在餐厅管理页面输入餐厅名称、餐厅图片、餐厅地址、联系人、联系电话、资质证明、状态等信息,进行搜索,新增或删除餐厅信息等操作;如图所示。
管理员点击菜品信息管理,在菜品信息页面对菜品名称、图片、美食分类、口味、餐厅名称、联系电话、餐厅地址、单限、库存、点击次数、评论数、价格、收藏数等信息,进行搜索或删除菜品信息等操作;如图所示。
管理员点击优惠券管理,在优惠券页面对名称、券类型、满额、优惠额、生效时间、过期时间、备注、商户名称等信息,进行搜索、新增或删除优惠券等操作;如图所示。
管理员点击系统管理,在系统管理页面对系统简介、轮播图管理、美食资讯、美食资讯分类等模块信息,进行搜索、新增或删除系统信息等操作;如图所示。
管理员点击订单管理,在订单管理页面对订单编号、商品名称、商品图片、购买数量、价格、总价格、支付类型、状态、地址、电话、收货人、备注、商户名称、商品类型、券编号、优惠额、统一订单编号、退货审核、审核回复、下单时间等信息,进行搜索或删除订单信息等操作;如图所示。
5.3餐厅服务端功能实现效果
餐厅注册登录,通过注册登录页面填写详细信息,点击注册登录操作,如图所示。
餐厅登录进入系统可以查看系统首页、菜品信息管理、系统管理、订单管理、我的信息等功能进行详细操作,如图所示。
部分功能代码
/**
* 上传文件
*/
@RequestMapping("/upload")
@IgnoreAuth
public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
if (file.isEmpty()) {
throw new EIException("上传文件不能为空");
}
String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
File path = new File(ResourceUtils.getURL("classpath:static").getPath());
if(!path.exists()) {
path = new File("");
}
File upload = new File(path.getAbsolutePath(),"/upload/");
if(!upload.exists()) {
upload.mkdirs();
}
String fileName = new Date().getTime()+"."+fileExt;
if(StringUtils.isNotBlank(type) && type.contains("_template")) {
fileName = type + "."+fileExt;
new File(upload.getAbsolutePath()+"/"+fileName).deleteOnExit();
}
File dest = new File(upload.getAbsolutePath()+"/"+fileName);
file.transferTo(dest);
if(StringUtils.isNotBlank(type) && type.equals("1")) {
ConfigEntity configEntity = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "faceFile"));
if(configEntity==null) {
configEntity = new ConfigEntity();
configEntity.setName("faceFile");
configEntity.setValue(fileName);
} else {
configEntity.setValue(fileName);
}
configService.insertOrUpdate(configEntity);
}
return R.ok().put("file", fileName);
}
/**
* 登录
*/
@IgnoreAuth
@RequestMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
if(user==null || !user.getPassword().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@PostMapping(value = "/register")
public R register(@RequestBody UsersEntity user){
// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
数据库参考
--
-- 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 */;
--
-- 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 */;
--
-- Table structure for table `coupon`
--
DROP TABLE IF EXISTS `coupon`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `coupon` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`userid` bigint(20) NOT NULL COMMENT '用户id',
`name` varchar(200) NOT NULL COMMENT '名称',
`type` varchar(200) NOT NULL COMMENT '券类型',
`fullamount` double NOT NULL DEFAULT '0' COMMENT '满额',
`discountamount` double NOT NULL DEFAULT '0' COMMENT '优惠额',
`startime` datetime NOT NULL COMMENT '生效时间',
`endtime` datetime NOT NULL COMMENT '过期时间',
`remark` varchar(200) DEFAULT NULL COMMENT '备注',
`cantingmingcheng` varchar(200) DEFAULT NULL COMMENT '商户名称',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='优惠券';
/*!40101 SET character_set_client = @saved_cs_client */;
源码及文档获取
文章下方名片联系我即可~
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻
精彩专栏推荐订阅:在下方专栏👇🏻
最新计算机毕业设计选题篇-选题推荐
小程序毕业设计精品项目案例-200套
Java毕业设计精品项目案例-200套
Python毕业设计精品项目案例-200套
大数据毕业设计精品项目案例-200套
💟💟如果大家有任何疑虑,欢迎在下方位置详细交流。