# 零食商城 Snack Mall > 毕业设计 · 前后端分离的 B2C 电商平台,覆盖用户端、管理端、客服、公告、优惠券、抢购六大模块。 仓库采用单仓多模块结构,包含两个前端项目(用户端 + 管理端)、一个 Spring Boot 后端服务,以及数据库脚本与设计文档。 ## 模块概览 | 目录 | 角色 | 技术栈 | |------|------|--------| | [`server-snack/`](./server-snack/) | 后端 API 服务 | Spring Boot 4.0.6 · Java 21 · MyBatis-Plus 3.5 · Sa-Token 1.45 · Redis · MySQL 8 · Knife4j 4.6 | | [`web-snack/`](./web-snack/) | 用户端 H5/PC 前端 | Vue 3.5 · Vite 8 · TypeScript 6 · Element Plus 2.14 · Pinia 3 | | [`admin-snack/`](./admin-snack/) | 管理后台前端 | Vue 3.5 · Vite 6 · TypeScript 5 · Element Plus 2.9 · Pinia 2 · ECharts 5 | | [`db/`](./db/) | 数据库脚本与设计文档 | `schema.sql` 建库 + 21 张表 DDL,`seed.sql` 演示数据 | | [`功能设计文档.md`](./功能设计文档.md) | 完整功能与接口设计(v1.2) | 6 大模块业务与接口说明 | | [`db/BUSINESS_DESIGN.md`](./db/BUSINESS_DESIGN.md) | 核心业务设计 | WebSocket 客服 + Redis 防超卖方案 | | [`admin-snack/design-system/`](./design-system/) | 设计系统资源 | 视觉令牌与组件规范 | ## 业务功能 - **用户端**:注册登录、收货地址、购物车、收藏、订单、支付、抢购、客服聊天 - **管理端**:仪表盘、商品 / 分类 / SKU 管理、订单处理、用户管理、优惠券、抢购活动、公告、客服会话 - **跨端共享**:系统公告、用户优惠券、限时抢购(Redis 原子扣减防超卖) ## 快速开始 ### 环境要求 | 工具 | 版本 | |------|------| | JDK | 21 | | Maven | 3.8+ | | Node.js | ≥ 20.19 | | MySQL | 8.0+ | | Redis | 6.0+ | ### 1. 初始化数据库 ```bash mysql -u root -p < db/schema.sql # 建库 + 21 张表 mysql -u root -p < db/seed.sql # 演示数据(可选) ``` ### 2. 启动后端 ```bash cd server-snack mvn spring-boot:run # 监听 http://localhost:8080 # 接口文档 http://localhost:8080/doc.html ``` 修改 `server-snack/src/main/resources/application.yml` 中的 MySQL / Redis 配置以匹配本地环境。 ### 3. 启动管理端 ```bash cd admin-snack npm install npm run dev # 访问 http://localhost:5173 ``` ### 4. 启动用户端 ```bash cd web-snack npm install npm run dev ``` > Vite 已将 `/api` 与 `/uploads` 代理到 `http://localhost:8080`,联调时确认后端已启动。 ## 默认账号 | 角色 | 用户名 | 密码 | |------|--------|------| | 管理员 | `admin` | `123456` | | 管理员 | `manager` | `123456` | | 管理员 | `operator` | `123456` | | 普通用户 | `user001` ~ `user005` | `123456` | ## 架构与约定 ### 后端分层 每个业务模块位于 `server-snack/src/main/java/com/snack/server/module//`: ``` module// ├── controller/ # @RestController,用户端 / 管理端分文件 ├── service/ # 业务接口 │ └── impl/ # 业务实现 ├── mapper/ # MyBatis-Plus BaseMapper ├── entity/ # 数据库表实体 ├── dto/req # 入参(带 jakarta.validation 注解) ├── vo/ # 出参(视图对象) ├── enums/ # 模块内枚举 └── constant/ # 模块内常量 ``` 跨模块共享:`com.snack.server.{common,config,constant,exception,handler,utils,enums,websocket}`。 ### 关键技术点 1. **认证** — Sa-Token(非 JWT),用户端与管理端走两套登录体系(`LoginType.USER` / `LoginType.ADMIN`),通过 `SaRouter.match` 按 URL 区分 2. **统一响应** — `Result` 封装 `{ code, message, data }`,前端 axios 拦截器在 `code === 200` 时直接返回 `data`(已解包约定) 3. **MyBatis-Plus** — 逻辑删除字段 `deleted`(0/1)、主键自增、`createTime`/`updateTime` 自动填充、复杂 SQL 走 XML 4. **防超卖** — Redis `DECR` 原子扣减库存 → 失败返回"已抢完" → 写入异步队列 → 消费端落 MySQL 5. **WebSocket 客服** — Spring WebSocket + STOMP,握手时验证 Token,消息全量落库 `chat_message` ### 前端约定 - **路径别名**:`@` → `src/` - **自动导入**:`unplugin-auto-import` + `unplugin-vue-components` 处理 Vue / Vue Router / Pinia / Element Plus - **状态管理**:Pinia + 持久化(管理端 key 为 `snack-admin-user`) - **请求层**:`utils/request.ts` 已解包响应,401 自动清空登录态并跳登录页 - **设计系统**:主色 `#1E40AF` / `#3B82F6`,圆角 6/10px,背景 `#F8FAFC` 更多细节参见 [`CLAUDE.md`](./CLAUDE.md)。 ## 目录结构 ``` snack-mall/ ├── server-snack/ # 后端服务 ├── web-snack/ # 用户端 ├── admin-snack/ # 管理端 ├── db/ # 数据库脚本与业务设计 │ ├── schema.sql # 建库 + 21 张表 │ ├── seed.sql # 演示数据 │ ├── README.md │ └── BUSINESS_DESIGN.md # WebSocket + 防超卖设计 ├── 功能设计文档.md # 完整功能与接口设计 ├── design-system/ # 设计系统资源 ├── CLAUDE.md # Claude Code 项目指引 └── README.md # 本文件 ``` ## 常用命令速查 ### 后端 ```bash mvn clean package # 构建(首次较慢) mvn spring-boot:run # 启动 mvn test # 跑测试 mvn test -Dtest=类名#方法名 # 单个测试方法 ``` ### 前端 ```bash npm install npm run dev # 开发服务器 npm run build # 类型检查 + 生产构建 npm run type-check # vue-tsc 类型检查 npm run lint # ESLint --fix npm run format # Prettier 格式化 ``` ## 文档索引 | 文档 | 路径 | 何时读 | |------|------|--------| | Claude Code 项目指引 | [`CLAUDE.md`](./CLAUDE.md) | 使用 Claude Code 协助开发前 | | 功能设计总览 | [`功能设计文档.md`](./功能设计文档.md) | 任何新模块开发前 | | 业务核心设计 | [`db/BUSINESS_DESIGN.md`](./db/BUSINESS_DESIGN.md) | 客服 / 抢购相关开发前 | | 数据库表结构 | [`db/schema.sql`](./db/schema.sql) + [`db/README.md`](./db/README.md) | 新增 / 修改实体前 | | 管理端技术栈 | [`admin-snack/README.md`](./admin-snack/README.md) | 前端环境问题排查 | | 用户端说明 | [`web-snack/README.md`](./web-snack/README.md) | 用户端环境问题排查 | ## 调试与排错 - **后端启动失败** — 检查 MySQL / Redis 是否启动、端口是否被占用、Knife4j 文档能否打开 - **前端 401 风暴** — 检查 `VITE_API_BASE_URL`、浏览器是否带了 `Authorization` 头、Sa-Token 拦截器路径配置 - **抢购超卖** — 查看 Redis 中 `seckill:stock:*` 键值,对照 [`db/BUSINESS_DESIGN.md`](./db/BUSINESS_DESIGN.md) 流程 - **类型错误** — 运行 `npm run type-check`,不要绕过 `vue-tsc` 直接 build - **本地上传文件访问不到** — 确认 `WebMvcConfig.addResourceHandlers` 中 `/uploads/**` 映射正确 ## 浏览器支持 现代浏览器 + ES2020(Chrome 90+、Edge 90+、Firefox 90+、Safari 14+) ## License 仅用于学习与毕业设计用途。