校园外卖平台系统设计与实现
系统概述
本文档介绍基于Java技术栈和微信小程序开发的校园外卖平台系统。该系统采用经典的三层架构模式,包含前端展示层、业务逻辑层和数据访问层,通过MySQL数据库实现数据持久化存储。
系统架构设计
系统整体采用B/S架构模式,前端使用微信小程序作为用户入口,后端采用Spring Boot框架构建RESTful API服务,数据库选用MySQL进行数据存储。分层架构的设计有助于代码的维护和功能的扩展。
架构层次说明
- 展示层:微信小程序端,负责用户交互和界面展示
- 业务层:Spring Boot后端服务,处理业务逻辑和数据处理
- 数据层:MySQL数据库,负责数据的持久化存储和管理
数据库设计
系统数据库包含用户表、商品表、订单表等核心数据表。以用户表为例,其结构设计如下:
DROP TABLE IF EXISTS `sys_user`;
CREATE TABLE `sys_user` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
`account` varchar(100) NOT NULL COMMENT '账号',
`secret` varchar(100) NOT NULL COMMENT '密码',
`user_role` varchar(100) DEFAULT 'user' COMMENT '用户角色',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='用户信息表';
-- 初始化管理员账号
insert into `sys_user`(`id`,`account`,`secret`,`user_role`,`create_time`)
values (1,'administrator','admin','admin','2022-05-01 00:00:00');
后端核心功能实现
后端采用Spring Boot框架构建,提供用户认证、商品管理、订单处理等核心功能。以下是用户管理模块的核心代码实现:
/**
* 用户管理控制器
*/
@RestController
@RequestMapping("auth")
public class AuthController {
@Autowired
private UserService userService;
@Autowired
private TokenService tokenService;
/**
* 用户登录接口
*/
@IgnoreAuth
@PostMapping(value = "/signin")
public R signin(String account, String password, String role, HttpServletRequest request) {
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>()
.eq("account", account));
if (user == null) {
return R.error("用户不存在");
}
if (!user.getUserRole().equals(role)) {
return R.error("角色权限不匹配");
}
if (!user.getSecret().equals(password)) {
return R.error("账号或密码错误");
}
String token = tokenService.generateToken(user.getId(), account, "auth", user.getUserRole());
return R.ok().put("token", token);
}
/**
* 用户注册接口
*/
@IgnoreAuth
@PostMapping(value = "/signup")
public R signup(@RequestBody UserEntity user) {
if (userService.selectOne(new EntityWrapper<UserEntity>()
.eq("account", user.getAccount())) != null) {
return R.error("账号已被注册");
}
userService.insert(user);
return R.ok();
}
/**
* 用户退出登录
*/
@GetMapping(value = "logout")
public R logout(HttpServletRequest request) {
request.getSession().invalidate();
return R.ok("退出成功");
}
/**
* 密码重置功能
*/
@IgnoreAuth
@RequestMapping(value = "/resetPwd")
public R resetPwd(String account, HttpServletRequest request) {
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>()
.eq("account", account));
if (user == null) {
return R.error("账号不存在");
}
user.setSecret("123456");
userService.update(user, null);
return R.ok("密码已重置为:123456");
}
/**
* 用户列表查询
*/
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params, UserEntity user) {
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
PageUtils page = userService.queryPage(params,
MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
return R.ok().put("data", page);
}
/**
* 获取用户详细信息
*/
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") String id) {
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 获取当前登录用户信息
*/
@RequestMapping("/current")
public R getCurrentUser(HttpServletRequest request) {
Integer id = (Integer)request.getSession().getAttribute("userId");
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 新增用户
*/
@PostMapping("/add")
public R add(@RequestBody UserEntity user) {
if (userService.selectOne(new EntityWrapper<UserEntity>()
.eq("account", user.getAccount())) != null) {
return R.error("账号已存在");
}
userService.insert(user);
return R.ok();
}
/**
* 更新用户信息
*/
@RequestMapping("/modify")
public R modify(@RequestBody UserEntity user) {
userService.updateById(user);
return R.ok();
}
/**
* 批量删除用户
*/
@RequestMapping("/remove")
public R remove(@RequestBody Integer[] ids) {
userService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
}
技术选型说明
后端技术
Java语言具有跨平台特性、面向对象设计和自动垃圾回收等优势。Java EE企业版提供了完整的Web应用开发支持,包括Servlet、JDBC等核心API,能够满足复杂业务场景的开发需求。Spring Boot框架简化了配置过程,提供了快速开发能力。
数据库技术
MySQL是一种广泛使用的关系型数据库,采用客户端/服务器架构模式。它支持标准SQL查询语言,具有高性能、高可靠性的特点。MySQL支持多种存储引擎,其中InnoDB引擎支持事务处理和行级锁定,适合高并发场景。
前端技术
微信小程序是一种不需要下载即可使用的应用,用户可以通过扫码或搜索快速访问。小程序具有原生体验感、开发成本低、传播便捷等优势,非常适合校园外卖这类轻量级应用的开发。
功能模块设计
校园外卖平台主要包含以下核心功能模块:
- 用户管理:包括用户注册、登录、权限验证等功能
- 商品浏览:展示外卖商品列表、分类筛选、商品详情
- 购物车:商品添加到购物车、数量修改、删除操作
- 订单管理:订单创建、订单查询、订单状态跟踪
- 配送管理:骑手分配、配送状态更新
总结
本系统采用现代化的技术栈进行开发,通过前后端分离的架构设计,实现了清晰的职责划分。MySQL数据库提供了稳定的数据存储支持,Spring Boot框架简化了后端开发流程,微信小程序为用户提供了便捷的访问方式。整个系统具有良好的可扩展性和可维护性。