ToLearn一起来学-用户匹配系统
一起来学(ToLearn),一个前后端分离的用户匹配系统,前端使用 Vite + Vue3 + Vant4,后端使用 SpringBoot 2.7 + Mybatis-plus,使用 WebSocket 实现实时通信,并结合 阿里云SDK + 七牛云SDK 完成短信发送和图片上传。本项目使用 Apache License Version 2.0 开源协议。
BraumAce/ToLearn-frontend (github.com)
BraumAce/ToLearn-backend (github.com)
寻找志同道合的小伙伴一起来学习吧!
- 用户注册和登录:用户可以通过注册账号并登录使用该网站。
- 标签匹配:用户可以选择自己的技能和需求标签,系统会根据标签匹配合适的队友。
- 组队功能:用户可以与其他用户组建队伍,一起组队学习。
- 博文发布、点赞和关注:用户可以发布自己的博文,其他用户可以对其进行点赞和关注,以便更好地了解和交流。
- 实时聊天:队伍中的用户可以进行实时聊天,方便沟通和协作。
- 用户管理:管理员可以对用户进行管理,包括审核用户信息和处理用户投诉等。
- 用户登录:使用 Redis 实现分布式 Session,解决集群间登录态同步问题;使用 token 储存用户信息并实现续签和超时自动退出;使用 Hash 代替 String 存储用户信息,节约了约 78.2% 的内存并便于单字段的修改。
- 对于项目中复杂的集合处理(比如为队伍列表关联已加入队伍的用户),使用 Java 8 Stream API 和 Lambda 表达式来简化编码。
- 使用 Redis 缓存首页高频访问的用户信息列表,将接口响应时长从 13380ms 缩短至 510ms。且通过自定义 Redis 序列化器来解决数据乱码、空间浪费的问题。
- 为解决首次访问系统的用户主页加载过慢的问题,使用 Spring Scheduler 定时任务来实现缓存预热,并通过分布式锁保证多机部署时定时任务不会重复执行。
- 为解决同一用户重复加入队伍、入队人数超限的问题,使用 Redisson 分布式锁来实现操作互斥,保证了接口幂等性。
- 为快速判断用户是否在队伍中,使用布隆过滤器对记录进行去重,并解决缓存穿透的问题。
- 使用编辑距离算法实现了根据标签匹配最相似用户的功能,并通过优先队列来减少 TOP N 运算过程中的内存占用。
- 使用 Knife4j + Swagger 自动生成后端接口文档,并通过编写 ApiOperation 等注解补充接口注释,避免了人工编写维护文档的麻烦。
- 使用本地+阿里云 OSS 储存用户头像,并自定义 CDN 加速域名指向项目专用储存空间。
- 使用 WebSocket 在单个 TCP 连接上进行全双工通信,创建持久性的连接,实现队伍聊天室中的实时聊天。
- 前端使用 Vant UI 组件库,并封装了全局通用的 Layout 组件,使主页、搜索页、组队页布局一致、并减少重复代码。
- 基于 Vue Router 全局路由守卫实现了根据不同页面来动态切换导航栏标题, 并通过在全局路由配置文件扩展 title 字段来减少无意义的 if else 代码。
- 使用 component is 标签自定义少数页面的基本布局,优化用户体验。
- 封装前端卡片组件,对数据做统一处理,减少重复代码。
- 使用 defineEmits 为子组件绑定事件,并使用 emits 将事件发送给父组件,优化用户在操作后的体验。
目前项目仅托管 Github 平台上中,欢迎大家 Star 和 Fork 支持~
前端
- Vue 3
- Vite 脚手架
- Vant UI 移动端组件库
- Axios 请求库
后端
- Java SpringBoot 框架
- MySQL 数据库
- Mybatis-Plus
- Mybatis X
- Redis缓存
- Redisson 分布式锁
- Spring Scheduler 定时任务
- Swagger + Knife4j 接口文档
- Gson JSON序列化库
- 最短编辑距离算法
- WebSocket
-
执行安装后端所需依赖
maven install
-
修改 application.xml ,详细配置信息请见项目文档
-
新建 to_learn数据库,并执行 to_learn.sql
-
运行 ToLearnBackendApplication
开源项目离不开大家的支持,如果您有好的想法,遇到一些 BUG 并修复了,欢迎小伙伴们提交 Pull Request 参与开源贡献!
- fork 本项目到自己的 repo
- 把 fork 过去的项目也就是你仓库中的项目 clone 到你的本地
- 修改代码
- commit 后 push 到自己的库
- 发起PR( pull request) 请求,提交到 dev 分支
- 等待作者合并