爱楼表情包网站
爱楼-表情包网站
页面展示
- 主页
- 管理员页面
- 后端文档
需求分析
- 用户根据名字和标签搜索表情包
- 用户上传表情包
- 管理员管理表情包
技术栈
前端
- 框架:Vue 3
- 组件库:Ant Design Vue
- 请求:Axios
- 路由:Vue Router
- 文件下载:FileSaver
后端
- Java 8
- 开发框架:SpringBoot 2.x
- 数据访问:MyBatis + MyBatis Plus
- 缓存:Redis
- 项目管理:Maven
- 接口文档:Swagger + Knife4j
存储
- 数据库:MySQL
- 对象存储:七牛云 COS
部署
- 前端:Nginx + Docker
- 后端:Docker容器
特性
- 使用 Redis 缓存首页高频访问的表情包列表,将接口响应时长从120毫秒缩短至 20毫秒。
- 选用 MyBatis + MyBatis-Plus 进行数据访问层开发,复用大多数通用方法,并且通过继承定制了自己的通用操作模板 ,大幅提升了项目开发效率。
- 为了明确接口的返回,自定义统一的错误码,并封装了全局异常处理器 ,从而规范了异常返回、屏蔽了项目冗余的报错细节。
- 自主编写 Dockerfile,并通过容器部署,提高部署上线效率。
- 使用 Knife4j + Swagger 自动生成后端接口文档,避免了人工编写维护文档的麻烦。
- 前端使用 Vant UI 组件库,并封装了全局通用的 Layout 组件,使主页、搜索页、管理页布局一致、并减少重复代码。
软件设计
数据库设计
数据库名: ilou
表名 | 说明 |
---|---|
emoji | 表情 |
tag | 标签 |
表名: emoji
说明: 表情
数据列:
序号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
---|---|---|---|---|---|---|---|---|
1 | id | int | 10 | 0 | N | Y | ||
2 | url | varchar | 4096 | 0 | Y | N | ||
3 | name | varchar | 512 | 0 | Y | N | ||
4 | userId | int | 10 | 0 | Y | N | 0 | 上传用户id |
5 | tags | varchar | 1024 | 0 | Y | N | 标签数组json | |
6 | reviewStatus | int | 10 | 0 | N | N | 0 | 0-待审核,1-通过,2-拒绝 |
7 | createTime | datetime | 19 | 0 | Y | N | CURRENT_TIMESTAMP | |
8 | isDelete | tinyint | 3 | 0 | N | N | 0 | 是否删除0-未删除1-已删除 |
9 | updateTime | datetime | 19 | 0 | Y | N | CURRENT_TIMESTAMP |
表名: tag
说明: 标签
数据列:
序号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
---|---|---|---|---|---|---|---|---|
1 | id | int | 10 | 0 | N | Y | ||
2 | name | varchar | 512 | 0 | N | N | 标签名 | |
3 | createTime | datetime | 19 | 0 | Y | N | CURRENT_TIMESTAMP | |
4 | isDelete | tinyint | 3 | 0 | N | N | 0 | 是否删除0-未删除1-已删除 |
5 | updateTime | datetime | 19 | 0 | Y | N | CURRENT_TIMESTAMP |
后端接口设计
ilou-api.yinan.fun/api/doc.html
通用返回对象
给对象补充一些信息,告诉前端这个请求在业务层面上是成功还是失败
1 |
|
全局异常处理器
-
定义业务异常类
- 相对于 java 的异常类,支持更多字段
- 自定义构造函数,更灵活 / 快捷的设置字段
-
编写全局异常处理器(利用 Spring AOP,在调用方法前后进行额外的处理)
源码
爱楼表情包网站
https://wangyinan.cn/爱楼表情包网站