基于Springboot+Vue实现小米商城
前言
学习了相关技术决定决定做一个项目来将所学知识串联起来,本人对前端了解不多,故借用他人前端项目。
说明
本项目前后端分离,前端项目原型来自于https://github.com/hai-27/vue-store,我在此基础上做了一些修改。
项目简介
本项目前后端分离,mistore为前端部分,mistore-server为后端部分。密码使用双重MD5加密,使用redis来储存商品信息和用户session,同时记录用户登录次数、 商品销量等。实现秒杀功能,启用定时任务定时处理过期秒杀商品、过期未付款订单,并每天同步redis中的登录次数、商品销量到mysql中。同时,使用Redis进行秒 杀库存控制,使用RabbitMQ异步秒杀,能够较好的应对并发场景,客户端完成秒杀请求后每秒请求一次秒杀结果
技术栈
前端:Vue+Vue-router+Vuex+Element-ui+Axios
后端:SpringBoot+Mybatis+Spring+RabbitMQ
数据库:Mysql+Redis
功能模块
登录
页面使用了element-ui的Dialog实现弹出蒙版对话框的效果,登录按钮设置在App.vue根组件,通过vuex中的showLogin状态控制登录框是否显示。
这样设计是为了既可以通过点击页面中的按钮登录,也可以是用户访问需要登录验证的页面或后端返回需要验证登录的提示后自动弹出登录框,减少了页面的跳转,简化用户操作。
用户输入的数据往往是不可靠的,所以本项目前后端都对登录信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。
注册
页面同样使用了element-ui的Dialog实现弹出蒙版对话框的效果,注册按钮设置在App.vue根组件,通过父子组件传值控制注册框是否显示。
用户输入的数据往往是不可靠的,所以本项目前后端同样都对注册信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。
首页
首页主要是对商品的展示,有轮播图展示推荐的商品,分类别对热门商品进行展示。
秒杀
秒杀模块展示秒杀商品,秒杀商品有秒杀开始倒计时、秒杀中、秒杀结束三种状态,只有秒杀中用户才能抢购,并且直接生成订单且处于未付款状态。
全部商品
全部商品页面集成了全部商品展示、商品分类查询,以及根据关键字搜索商品结果展示。
商品详情页
商品详情页主要是对某个商品的详细信息进行展示,用户可以在这里把喜欢的商品加入购物车或收藏列表。
我的购物车
购物车采用vuex实现,页面效果参考了小米商城的购物车。
订单结算
用户在购物车选择了准备购买的商品后,点击“去结算”按钮,会来到该页面。 用户在这里选择收货地址,确认订单的相关信息,然后确认购买。
我的收藏
用户在商品的详情页,可以通过点击加入 喜欢 按钮,把喜欢的商品加入到收藏列表。
我的订单
对用户的所有订单进行展示。
运行项目
运行mistore-server中的MistoreServerApplication.java
在mistore所在目录控制台输入 npm run serve
项目运行需连接redis,否则会报错
部分截图