爱玩科技网
您的当前位置:首页基于SSM+SpringBoot+Vue前后端分离的体育商品商城系统(附论文)

基于SSM+SpringBoot+Vue前后端分离的体育商品商城系统(附论文)

来源:爱玩科技网
基于SSM+SpringBoot+Vue前后端分离的体育商品商城系统

(附论⽂)

⼤家好,很⾼兴和⼤家分享源码。不管是什么样的需求。都希望各位计算机专业的同学们有⼀个提⾼。

⼤家可以通过常⽤的搜索引擎,以百度为例,搜索 源码乐园 code51 ,然后再次搜索 ⾃⼰想要的即可。更多的管理系统等,欢迎⼤家百度搜索源码乐园。

项⽬运⾏截图

1.项⽬简介

1.1背景分析

如今我们⽣活在⼀个互联⽹时代,随着智能⼿机与⽹络技术的⽇益发达,电⼦商务空前发展,许多商品的销售也逐渐从有形的市场转向虚拟的⽹络,为了满⾜⼈们购买体育⽤品的需求,⽹上体育商城应运⽽⽣,⽬的是在体育商城与消费者之间建⽴⼀座⾼速、便捷的⽹上信息桥梁,从⽽可以节省⽤户的时间、⽅便他们购买,使其永远⾛在时代的前沿。

本系统的设计严格遵循软件开发流程,使⽤MVC模式,采⽤开源框架SpringBoot+MybatisPlus+Vue进⾏开发,使⽤java语⾔编写,后端的数据库采⽤MySQL,Jpa⾃动创表,通过Spring配置⽂件与数据库进⾏⽆缝连接,应⽤可以跨平台的Web应⽤技术与Spring boot结合开发的⽹上购物系统—⽹上体育商城,通过使⽤这些框架,使开发过程中的逻辑更加清晰,更有层次,也简化了代码的书写,更好的了解了Web应⽤程序和这些开源的框架技术,熟练了使⽤框架开发的流程。

该体育商城⽹站的前台页⾯⾮常简单明了,当⽤户第⼀次访问该商城时,可以清晰的看到商城中的新款商品与销量排⾏,可以⾮常⽅便的挑选到⾃⼰需要的商品,后台的管理也很⽅便,管理员可以对商品、订单等进⾏管理,所以该⽹上体育商城的创建可以更好地解决⼈们因没有时间到实体店⽽不能买到⾃⼰需要的体育⽤品的问题,商家使⽤该系统,也可以⽅便管理,提⾼⼯作效率。

1.2功能概述

根据对该⽹上体育商城的功能进⾏分析,为了满⾜⽤户的需求,该系统应该满⾜以下功能,接下来从前台的客户端界⾯和后台管理界⾯分别对该系统的功能加以描述。前台页⾯的功能主要包括:

1.体育商品分类:当⽤户第⼀次访问该商城时,可以按照商品分类快速查找到⾃⼰所需商品是属于哪⼀类型。2.所售商品描述:当⽤户看到某⼀商品时,可以很快看到这件商品的详细介绍。

3.商品销量排⾏:在该商城的客户端界⾯,⽤户可以清晰的看到该商城畅销的前五件商品。

4.商品的搜索栏:当⽤户不想逐⼀类别的查找⾃⼰需要的商品时,可以在搜索栏进⾏查找,该搜索栏必须⽀持模糊查询,⽤户只输⼊关键字,就可以快速查找到⾃⼰需要的。

5.会员留⾔:该功能是⽤来专门给⽤户提供反馈意见的机会,⽤户对在该商城买的商品有某些意见,可以进⾏留⾔,或者对该商城有某些建设性的建议,也可以进⾏留⾔,总之,就是为⽤户提供⼀个与商家交流的窗⼝。

6.会员的注册登录:该功能是⼀个购物⽹站不可缺少的主要功能,⽤户只有注册登录成功后,才可以进⾏后续的⼀系列操作,不然就只能浏览商品,不能进⾏购买。

7.购物车:该功能也是⼀个购物⽹站必须的功能,⽤户不可能看中⼀件商品就去付⼀次款,这样对商家和⽤户都不是很⽅便,⽤户可以先将看中的商品加⼊购物车中,等挑选结束后,再进⾏统⼀付款。

8.查看订单:该功能主要是⽅便⽤户查看⾃⼰的订单,当⽤户下⼀次单时,商家可以受理此订单并进⾏发货,⽤户收到货后,可以确认收货并评价商品。

9.查看个⼈信息:当⽤户在该商城进⾏注册时,需要填写⾃⼰的个⼈信息,如姓名、性别、地址、邮箱、电话、QQ等信息,注册成功后,该商城会把每⼀位注册成功的⽤户信息保存下来,⽤户登录成功后,可以查看并修改个⼈信息。

10.联系我们:该功能主要是给⽤户提供商家的联系⽅式,当⽤户有某些需求时,可以直接跟商家电话联系。11.⽹站公告:该功能主要是⽅便商家对顾客发布⼀些公告,如商城搞活动或有新商品上架等。

12.后台登录:在前台页⾯的下⽅提供⼀个管理员登录后台的按钮,管理员点击该按钮,可以进⼊后台登录界⾯,⽅便管理员进⾏管理。后台管理页⾯的功能主要包括:

1.系统参数:该功能可以使管理员看到该商城系统的版本号和作者及作者的邮箱,有需要改进的地⽅可以直接和作者联系。2.管理员维护:该功能可以让管理员对⾃⼰的密码进⾏修改。

3.注册会员的管理:管理员可以对前台已经注册的⼀些会员⽤户进⾏管理,当某些会员⽤户有⾮法操作时可以进⾏删除,防⽌对该商城系统造成⼤的损害。

4.商品管理:该功能使管理员对该商品的类别和具体商品进⾏管理,对商城所售商品的类别进⾏增加、修改和删除,对具体某⼀件商品进⾏添加和删除。

5.订单管理:当某⼀⽤户在前台下单后,管理员在后台可以查看订单明细,受理此订单或删除该订单,⽅便管理员对订单的管理。6.销量管理:管理员在后台可以对该商城所售商品的销量进⾏管理,商品的销量按从⾼到低进⾏排列。7.留⾔公告管理:管理员在后台可以查看或删除⽤户的留⾔,发布最新的公告或删除过期的公告。

8.退出后台:该功能主要是⽅便管理员的退出,当管理员想退出后台管理页⾯时,点击此按钮,可以迅速返回到后台的登录页⾯。以上就是该体育商城的前台客户端页⾯和后台管理页⾯所需要实现的所有功能功能模块流程图

2.需求分析

根据对该⽹上体育商城的功能进⾏分析,为了满⾜⽤户的需求,该系统应该满⾜以下功能,接下来从前台的客户端界⾯和后台管理界⾯分别对该系统的功能加以描述。

前台页⾯的功能主要包括:

体育商品分类:当⽤户第⼀次访问该商城时,可以按照商品分类快速查找到⾃⼰所需商品是属于哪⼀类型。

所售商品描述:当⽤户看到某⼀商品时,可以很快看到这件商品的详细介绍。

商品销量排⾏:在该商城的客户端界⾯,⽤户可以清晰的看到该商城畅销的前五件商品。

商品的搜索栏:当⽤户不想逐⼀类别的查找⾃⼰需要的商品时,可以在搜索栏进⾏查找,该搜索栏必须⽀持模糊查询,⽤户只输⼊关键字,就可以快速查找到⾃⼰需要的。

会员留⾔:该功能是⽤来专门给⽤户提供反馈意见的机会,⽤户对在该商城买的商品有某些意见,可以进⾏留⾔,或者对该商城有某些建设性的建议,也可以进⾏留⾔,总之,就是为⽤户提供⼀个与商家交流的窗⼝。

会员的注册登录:该功能是⼀个购物⽹站不可缺少的主要功能,⽤户只有注册登录成功后,才可以进⾏后续的⼀系列操作,不然就只能浏览商品,不能进⾏购买。

购物车:该功能也是⼀个购物⽹站必须的功能,⽤户不可能看中⼀件商品就去付⼀次款,这样对商家和⽤户都不是很⽅便,⽤户可以先将看中的商品加⼊购物车中,等挑选结束后,再进⾏统⼀付款。

查看订单:该功能主要是⽅便⽤户查看⾃⼰的订单,当⽤户下⼀次单时,商家可以受理此订单并进⾏发货,⽤户收到货后,可以确认收货并评价商品。

查看个⼈信息:当⽤户在该商城进⾏注册时,需要填写⾃⼰的个⼈信息,如姓名、性别、地址、邮箱、电话、QQ等信息,注册成功后,该商城会把每⼀位注册成功的⽤户信息保存下来,⽤户登录成功后,可以查看并修改个⼈信息。

联系我们:该功能主要是给⽤户提供商家的联系⽅式,当⽤户有某些需求时,可以直接跟商家电话联系。⽹站公告:该功能主要是⽅便商家对顾客发布⼀些公告,如商城搞活动或有新商品上架等。

后台登录:在前台页⾯的下⽅提供⼀个管理员登录后台的按钮,管理员点击该按钮,可以进⼊后台登录界⾯,⽅便管理员进⾏管理。

后台管理页⾯的功能主要包括:

系统参数:该功能可以使管理员看到该商城系统的版本号和作者及作者的邮箱,有需要改进的地⽅可以直接和作者联系。管理员维护:该功能可以让管理员对⾃⼰的密码进⾏修改。

注册会员的管理:管理员可以对前台已经注册的⼀些会员⽤户进⾏管理,当某些会员⽤户有⾮法操作时可以进⾏删除,防⽌对该商城系统造成⼤的损害。

商品管理:该功能使管理员对该商品的类别和具体商品进⾏管理,对商城所售商品的类别进⾏增加、修改和删除,对具体某⼀件商品进⾏添加和删除。

订单管理:当某⼀⽤户在前台下单后,管理员在后台可以查看订单明细,受理此订单或删除该订单,⽅便管理员对订单的管理。销量管理:管理员在后台可以对该商城所售商品的销量进⾏管理,商品的销量按从⾼到低进⾏排列。留⾔公告管理:管理员在后台可以查看或删除⽤户的留⾔,发布最新的公告或删除过期的公告。

退出后台:该功能主要是⽅便管理员的退出,当管理员想退出后台管理页⾯时,点击此按钮,可以迅速返回到后台的登录页⾯。以上就是该体育商城的前台客户端页⾯和后台管理页⾯所需要实现的所有功能。

3.数据库分析与设计

数据库简单的来说,就是⼀个保存数据的⼩仓库,所有需要的数据都可以往⾥⾯存,现在我们⽣活中的各⾏各业都离不开它,最普通的例⼦,我们平时使⽤微信聊天,所有的好友,聊天记录都是存在数据库中的,我们⼿机⾥的联系⼈,短信也都是存在数据库⾥的,这也就是所谓的数据库,它产⽣于⼆⼗世纪六⼗年代,特别是最近⼏年,随着电⼦商务技术的不断发展,市场需求的不断变化,数据库不再仅仅具有存储数据的功能,⽽要满⾜对不同的数据进⾏管理的功能,现在各⾏各业的发展都有⼤量的数据,都离不开对数据的管理,为了科学的和有效的管理,都需要依靠数据库,因此数据库技术得到了⼴泛的应⽤。

3.1 数据库需求分析

该体育商城系统的数据库需求具体体现在对所有的注册会员的⽤户进⾏管理,对各种体育商品的情况进⾏管理,这就要求数据库能及时的更新数据,确保每⼀条数据都能够保存,保证对每个会员,每件商品进⾏有效的管理,为最终项⽬的成功运⾏提供保障。

3.2 数据库逻辑结构设计

该体育商城系统的概念结构设计完成后,该数据库的逻辑结构设计可以参照概念结构设计转化过来。⽹上体育商城数据库中各个表的设计如下所⽰,每个表格表⽰在数据库中的⼀个表。描述管理员各个属性的表为管理员表

权限表

订单表

商品类型表

商品详情表

商品表

评价表

购物车表

轮播图表

3.3 数据库概念结构设计

数据库的概念结构设计在整个开发过程中⾮常的重要,没有⼀个好的概念设计,编码做得再好都是徒劳,⼀般可以利⽤E-R图进⾏数据库的概念设计,E-R图可⽤于描述各个实体之间的关系。

4.项⽬实现

根据对该体育商城系统的需求分析,该商城的界⾯主要分为后台管理页⾯和前台客户端页⾯,⽤户只可以访问前台客户端页⾯,通过浏览⽹页来满⾜⾃⼰的购物需求,商城前端的所有功能都是通过后台的管理来实现的,所显⽰的所有商品信息都需要通过后台管理系统来增加、修改和删除,后台管理页⾯只有管理员可以访问。因为在后台需要对所有商品的信息进⾏处理,所以后台管理部分的开发⽐前台客户端要复杂。

对于该体育商城系统,概括起来,主要实现了以下功能:前台部分

商品分类:⽤户可以查看商品的所有分类,⽅便⽤户快速找到⾃⼰需要的商品。商品描述:⽤户可以查看每件商品的详细描述。

销量排⾏:⽤户可以看到该商城中商品销售排在前五的商品。

商品搜索:⽤户可以搜索⾃⼰感兴趣的体育商品,该搜索栏⽀持模糊查询,只需输⼊关键字就可以查到。会员注册:⽤户填写⾃⼰的基本信息,可以成为该商城的会员⽤户。

⽤户登录:注册成功后,可以登录该商城的⽹站。

购物车:⽤户看中⼀件商品不需要马上付款,可以先加⼊到购物车中,挑选结束后再整体付款。

订单管理:⽤户可以查看⾃⼰已下的订单,看是否被管理员受理,收到商品后,可以点击收货,并对商品进⾏评价。联系我们:提供⽹站的联系⽅式,⽤户有某些需求可以直接联系。后台部分

系统参数:管理员可以查看此刻系统运⾏环境。管理员维护:管理员可以对⾃⼰的密码进⾏修改。会员管理:管理员可以对该体育商城的⽤户进⾏删除。

商品管理:管理员可以对商品的类别进⾏添加、修改和删除,对具体某⼀类别的商品进⾏添加和删除。订单管理:管理员可以查看⽤户订单的详细信息,还可以受理⽤户的订单或删除⽤户的订单。退出系统:当管理员的所有操作都结束后,可以点击退出系统进⾏退出。下⾯分别说明这些功能进⾏具体的说明。

5.项⽬开发

5.1⾸页功能

在该体育商城中,在前台页⾯的下⽅有个管理登录按钮,管理员点击后,可跳转到后台的登录页⾯,管理员按要求输⼊⽤户名、密码,就可成功登录后台管理系统,后台通过frame框架分成三部分,页⾯顶部为⼀部分,下⾯分成左右两部分,以下这段代码主要实现了后台登录时验证的功能

/** * ⽤户登录 * * @param username ⽤户名 * @param password 密码 * @return ResponseEntity

* @throws JsonProcessingException See {@link UserService#login(String, String)} */@PostMapping(\"/login\")

public ResponseEntity login(@RequestParam String username,

@RequestParam String password) throws JsonProcessingException { return RestModel.ok(userService.login(username, password));}

@Override

public String login(String username, String password) throws JsonProcessingException { if (StringUtils.isAnyBlank(username, password)) { throw new NullFiledException(\"⽤户名/密码不能为空\"); }

User user = userRepository.findById(username).orElseThrow(() -> new IdNotFoundException(\"⽤户名不存在\")); if (!password.equals(user.getPassword())) {

throw new SecurityServerException(\"密码错误\", HttpStatus.BAD_REQUEST); }

LoginUser loginUser = OrikaUtils.a2b(user, LoginUser.class); return JwtUtils.buildJwt(loginUser); }其他功能

/** * 修改⽤户信息(不包括密码) * * @param loginUser 登录⽤户 * @param user 新⽤户信息 * @return ResponseEntity */@PatchMapping(\"/user\")

public ResponseEntity modifyUserInfo(@MustUserLogin LoginUser loginUser, @RequestBody User user) { userService.modifyUser(loginUser, user); return RestModel.noContent();}

/** * ⽤户注册 * * @param username ⽤户名 * @param email 邮箱 * @param phone ⼿机号 * @param password 密码 * @return ResponseEntity */@PostMapping(\"/reg\")

public ResponseEntity regUser(@RequestParam String username, @RequestParam String email, @RequestParam String phone, @RequestParam String password) {

return RestModel.created(userService.reg(username, email, phone, password));}

/** * 更改密码 * * @param loginUser 登录⽤户 * @param oldPwd 旧密码 * @param newPwd 新密码 * @return ResponseEntity */@PostMapping(\"/pwd\")

public ResponseEntity changePwd(@MustUserLogin LoginUser loginUser, @RequestParam String oldPwd, @RequestParam String newPwd) { userService.changePwd(loginUser, oldPwd, newPwd); return RestModel.ok(\"success\");}

5.2JWT⼯具类

package com.sport.sportsmallserver.util;

import com.fasterxml.jackson.core.JsonProcessingException;import com.fasterxml.jackson.databind.ObjectMapper;import com.sport.sportsmallserver.dto.LoginUser;

import com.sport.sportsmallserver.exception.TokenException;import io.jsonwebtoken.*;

import io.jsonwebtoken.*;

import org.springframework.http.HttpStatus;import java.util.Date;

/** * Jwt ⼯具类 * * @author itning */public final class JwtUtils {

private static final String PRIVATE_KEY = \"itning\"; private static final String LOGIN_USER = \"loginUser\"; private static final String DEFAULT_STR = \"null\";

private static final ObjectMapper MAPPER = new ObjectMapper(); private JwtUtils() { }

public static String buildJwt(Object o) throws JsonProcessingException { return Jwts.builder()

//SECRET_KEY是加密算法对应的密钥,这⾥使⽤额是HS256加密算法 .signWith(SignatureAlgorithm.HS256, PRIVATE_KEY) //expTime是过期时间 .setExpiration(new Date(System.currentTimeMillis() + 240 * 60 * 1000)) .claim(LOGIN_USER, MAPPER.writeValueAsString(o)) //令牌的发⾏者 .setIssuer(\"itning\") .compact(); }

public static LoginUser getLoginUser(String jwt) { if (DEFAULT_STR.equals(jwt)) {

throw new TokenException(\"请先登陆\", HttpStatus.UNAUTHORIZED); } try {

//解析JWT字符串中的数据,并进⾏最基础的验证 Claims claims = Jwts.parser()

//SECRET_KEY是加密算法对应的密钥,jjwt可以⾃动判断机密算法 .setSigningKey(PRIVATE_KEY) //jwt是JWT字符串 .parseClaimsJws(jwt) .getBody(); //获取⾃定义字段key String loginUserJson = claims.get(LOGIN_USER, String.class);

LoginUser loginUser = MAPPER.readValue(loginUserJson, LoginUser.class); //判断⾃定义字段是否正确 if (loginUser == null) {

throw new TokenException(\"登陆失败\", HttpStatus.UNAUTHORIZED); } else {

return loginUser; }

//在解析JWT字符串时,如果密钥不正确,将会解析失败,抛出SignatureException异常,说明该JWT字符串是伪造的 //在解析JWT字符串时,如果‘过期时间字段’已经早于当前时间,将会抛出ExpiredJwtException异常,说明本次请求已经失效 } catch (ExpiredJwtException e) {

} catch (ExpiredJwtException e) {

throw new TokenException(\"登陆超时\", HttpStatus.UNAUTHORIZED); } catch (SignatureException e) {

throw new TokenException(\"凭据错误\", HttpStatus.BAD_REQUEST); } catch (Exception e) {

throw new TokenException(\"登陆失败\", HttpStatus.UNAUTHORIZED); } }}

5.3实体映射⼯具类

⾃动⽣成表功能实现

package com.sport.sportsmallserver.util;import ma.glasnost.orika.MapperFactory;

import ma.glasnost.orika.impl.DefaultMapperFactory;import org.springframework.lang.NonNull;import org.springframework.lang.Nullable;

/** * 实体映射⼯具类 * * @author itning */public class OrikaUtils {

private static final MapperFactory MAPPER_FACTORY = new DefaultMapperFactory.Builder().build(); /** * 将两个实体合并为⼀个DTO

* input1,input2 不能全为 {@code null} * * @param input1 第⼀个输⼊实体 * @param input2 第⼆个输⼊实体 * @param result DTO类型 * @param DTO * @param ENTITY * @param ENTITY * @return DTO类型 */ @NonNull

public static R doubleEntity2Dto(@Nullable A input1, @Nullable B input2, @NonNull Class result) { if (input1 != null && input2 != null) {

R r = MAPPER_FACTORY.getMapperFacade().map(input1, result); MAPPER_FACTORY.getMapperFacade().map(input2, r); return r;

} else if (input1 != null) {

return MAPPER_FACTORY.getMapperFacade().map(input1, result); } else {

return MAPPER_FACTORY.getMapperFacade().map(input2, result); } } /** * A 实体 转换 B 实体 * * @param a A实例 * @param bClass B类型 * @param A * @param B * @return B 实例 */ public static B a2b(A a, Class bClass) {

return MAPPER_FACTORY.getMapperFacade().map(a, bClass); }}

5.4后台功能开发

@Override

public Page findByType(String typeId, Pageable pageable) { if (StringUtils.isBlank(typeId)) {

throw new NullFiledException(\"商品类别为空\"); }

CommodityType commodityType = commodityTypeRepository.findById(typeId).orElseThrow(() -> new IdNotFoundException(\"商品类别没有找到\"));

return commodityRepository.findAllByCommodityTypeAndTakeOff(commodityType, false, pageable);}

@Override

public List findByRecommend() {

return commodityRepository.findAllByRecommendedAndTakeOff(true, false);}

@Override

public Commodity findById(String id) {

Commodity commodity = commodityRepository.findById(id).orElseThrow(() -> new IdNotFoundException(\"商品不存在\")); if (commodity.isTakeOff()) {

throw new SecurityServerException(\"商品已下架\", HttpStatus.NOT_FOUND); }

return commodity;}

@Override

public Page search(String keyword, Pageable pageable) { if (StringUtils.isBlank(keyword)) {

throw new NullFiledException(\"关键字不能为空\"); }

return commodityRepository.findAllByTakeOffAndNameLike(false, \"%\" + keyword + \"%\", pageable);}

6.项⽬展⽰

登录

注册

普通⽤户

主页

分类显⽰

商品详情

评价查看

管理员

主页(商品管理)

订单管理

分类管理

轮播图管理

技术描述

开发⼯具: Idea/Eclipse数据库: mysqlJar包仓库: Maven

前段框架: vue/ElementUI/echart

后端框架: Spring+SpringMVC+Mybatis+SpringBoot

资料说明

本系统的设计严格遵循软件开发流程,使⽤MVC模式,采⽤开源框架SpringBoot+MybatisPlus+Vue进⾏开发,使⽤java语⾔编写,后端的数据库采⽤MySQL,Jpa⾃动创表,通过Spring配置⽂件与数据库进⾏⽆缝连接,应⽤可以跨平台的Web应⽤技术与Spring boot结合开发的⽹上购物系统—⽹上体育商城,通过使⽤这些框架,使开发过程中的逻辑更加清晰,更有层次,也简化了代码的书写,更好的了解了Web应⽤程序和这些开源的框架技术,熟练了使⽤框架开发的流程。