基于javaweb+mysql的springboot在线服装销售商城系统(java+springboot+maven+vue+mysql)
运行环境
Java≥8、MySQL≥5.7、Node.js≥10
开发工具
后端:eclipse/idea/myeclipse/sts等均可配置运行
前端:WebStorm/VSCode/HBuilderX等均可
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
基于javaweb+mysql的SpringBoot在线服装销售商城系统(java+springboot+maven+vue+mysql)
一、项目运行 环境配置:
Jdk1.8 + Tomcat8.5 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。
项目技术:
Spring + SpringBoot+ mybatis + Maven + Vue 等等组成,B/S模式 + Maven管理等等。
}
}
/**
*/
@Api(tags = "用户端-购物车服务接口列表")
@RestController
@RequestMapping("cart")
public class CartController {
private static final Logger logger = LoggerFactory.getLogger(CartController.class);
@Autowired
private CartService cartService;
@Autowired
private UserService userService;
/**
* @Param:
* @return: Result<>
*/
@ApiOperation(value = "商品加入购物车", notes = "用户端-商品添加购物车")
@PostMapping("/cart_insert")
String jwtToken = jwtUtils.refreshToken(loginVo.getUsername());
// return Result.success(token.toString());
// } catch (UnknownAccountException e) {
// throw new GlobleException(CodeMsg.USERNAME_NOT_EXIST);
// } catch (IncorrectCredentialsException e){
// throw new GlobleException(CodeMsg.PASSWORD_ERROR);
// }
JwtUtils jwtUtils = new JwtUtils();
String token = jwtUtils.sign(loginVo);
return Result.success(token);
}
}
/**
*/
@Api(tags = "用户端-主页服务接口列表")
@RestController
@RequestMapping("/home")
public class HomeController {
private static final Logger logger = LoggerFactory.getLogger(HomeController.class);
@Autowired
private HomeService homeService;
/**
* @Param: keyWord
* @Date
*/
@ApiOperation(value = "搜索商品", notes = "用户端-查询商品")
@GetMapping("/search/{keyWord}")
public Result<List<Goods>> search(@PathVariable String keyWord){
return Result.success(homeService.search(keyWord));
}
/**
* @methodDesc: 查询所有订单
* @Param: userId
* @return: Result<>
*/
@ApiOperation(value = "查询所有订单", notes = "用户端-用户id查询所有订单")
@GetMapping("/orders_show/{userId}")
public Result<List<Orders>> ordersShow(@PathVariable int userId){
return Result.success(ordersService.ordersShow(userId));
}
/**
* @methodDesc: 查询某订单状态的订单
* @Param: state,userId
* @return: Result<List<Orders>>
*/
@ApiOperation(value = "查询某状态订单", notes = "用户端-查询某订单状态的订单")
@GetMapping("/orders_state")
public Result<List<OrdersAndListGoodsDto>> ordersState(int state, int userId){
return Result.success(ordersService.ordersState(state,userId));
}
/**
* @methodDesc: 用户对某商品的评价
* @Param: appraise,orderListId,userId
* @return: Result<>
*/
@ApiOperation(value = "添加评论", notes = "用户端-当订单查询到为待评论状态,点击待评论跳转到评论页面(携带该商品的订单列表信息),在评论页面提交评论,把评论和订单列表id传到后端,添加评论")
@PutMapping("/orders_appraise/{orderListId}")
public Result<Object> ordersAppraise(@PathVariable int orderListId, @RequestBody AppraiseVo appraiseVo){
ordersService.goodsAppraise(orderListId,appraiseVo.getAppraise());
return Result.success(null);
}
/**
* @methodDesc: 管理员查询所有订单
* @Param:
* @return: Result<List<Orders>>
*/
@ApiOperation(value = "查询所有订单", notes = "管理员端-获取用户下的所有订单")
@GetMapping("/orders_show_all")
public Result<List<Orders>> ordersShowAll(){
String cheToken = username+ "." +md5;
return cheToken;
}
/**
* @methodDesc 提取username
* @param request
* @return String
*/
public static String drawUsername(HttpServletRequest request){
String token = request.getHeader("Authorization");
System.out.println("token:"+token);
if (token == null){
throw new GlobleException(CodeMsg.NOT_YET_LOGIN);
}
try {
String username = token.substring(0,token.indexOf("."));
System.out.println("username:"+username);
return username;
} catch (Exception e){
throw new GlobleException(CodeMsg.NOT_YET_LOGIN);
}
}
public static void main(String[] args){
LoginVo loginVo1 = new LoginVo("966966","966966");
LoginVo loginVo2 = new LoginVo("efg","456");
String token1 = MyShiro.createToken(loginVo1);
String token2 = MyShiro.createToken(loginVo2);
System.out.println(token1);
System.out.println(token1.substring(0,token1.indexOf(".")));
// System.out.println("D:\\work\\workspace\\clothing\\static\\1.jpg".substring("D:\\work\\workspace\\clothing\\static\\1.jpg".indexOf("g")+1));
}
}
* @methodDesc: 获取评论
* @Param: goodsId
* @return: Result<String>
*/
@ApiOperation(value = "显示某商品所有评价", notes = "用户端-查询某商品的累计评价")
@GetMapping("/goods_appraise/{goodsId}")
public Result<List<String>> ordersAppraise(@PathVariable int goodsId){
System.out.println(goodsId);
return Result.success(ordersService.ordersAppraise(goodsId));
}
/**
* @methodDesc: 获取所有订单(AllOrderDto)
* @Param: userId
* @return: Result<AllOrderDto>
*/
@ApiOperation(value = "用户查询所有订单", notes = "用户端-用户查询所有订单")
@GetMapping("/get_orders/{userId}")
public Result<List<AllOrdersDto>> getOrders(@PathVariable int userId){
System.out.println(userId);
return Result.success(ordersService.getOrders(userId));
}
/**
* @methodDesc: 查询某订单状态的订单
* @Param: state,userId
* @return: Result<List<AllOrdersDto>>
*/
@ApiOperation(value = "查询某状态订单", notes = "用户端-查询某订单状态的订单")
@GetMapping("/get_state")
public Result<List<AllOrdersDto>> getStateOrder(int state,int userId){
return Result.success(ordersService.getStateOrder(state,userId));
}
/**
* @methodDesc: 确认收货
* @Param: orderId
* @return: Result<>
*/
@ApiOperation(value = "修改订单状态2-->3", notes = "用户端-用户确认订单")
@PutMapping("/confirm_goods/{orderId}")
public Result<Object> confirmGoods(@PathVariable int orderId){
ordersService.confirmGoods(orderId);
return Result.success(null);
}
}
/**
* @Param: cartId
* @return: Result
*/
@ApiOperation(value = "删除购物车", notes = "用户端-删除购物车")
@DeleteMapping("/cart_delete/{cartId}")
public Result<Object> cartDelete(@PathVariable int cartId){
cartService.cartDelete(cartId);
return Result.success(null);
}
/**
* @methodDesc: 通过购物车下单
* @Param: shoppingCart
* @return: Result<>
*/
@ApiOperation(value = "购物车下单", notes = "用户端-通过购物车下单")
@PostMapping("/cart_order")
public Result<Orders> cartOrder(@RequestBody List<ShoppingCart> shoppingCartList){
System.out.println("check:"+shoppingCartList);
return Result.success(cartService.cartOrder(shoppingCartList));
}
}
/**
*/
@Api(tags = "用户端-用户服务接口列表")
@RestController
@RequestMapping("/user")
public class UserController {
private static final Logger logger = LoggerFactory.getLogger(UserController.class);
@Autowired
private UserService userService;
// @Autowired
// private RedisService redisService;
/**
* @methodDesc: 用户信息管理
* @Param: userVo
* @return: Result<UserVo>
*/
@ApiOperation(value = "修改用户信息管理", notes = "用户端-添加用户信息")
@PutMapping("/user_info/{userId}")
public Result<UserVo> insertUserInfo(@PathVariable int userId,@RequestBody UserVo userVo){
logger.info(userId+userVo.toString());
return Result.success(userService.insertUserInfo(userId,userVo));
homeService.rotationUpload(rotationVo);
return Result.success(null);
}
/**
* @Param:
* @Date
*/
@ApiOperation(value = "轮播图展示", notes = "用户端-查询所有轮播图")
@GetMapping("/rotation_chart")
public Result<List<Rotation>> rotationChart(){
List<Rotation> rotationList = homeService.rotationChart();
return Result.success(rotationList);
}
/**
* @Param: rotationId
* @Date
*/
@ApiOperation(value = "删除轮播图", notes = "管理员端-删除轮播图")
@DeleteMapping("/rotation_delete/{rotationId}")
public Result<Object> rotationDelete(@PathVariable int rotationId){
homeService.rotationDelete(rotationId);
return Result.success(null);
}
}
public class MyShiro {
//盐,用于混交md5
private static final String slat = "@gnihtolc#namoaix$";
/**
* @methodDesc 密码加密
//盐,用于混交md5
private static final String slat = "@gnihtolc#namoaix$";
/**
* @methodDesc 密码加密
* @param password
* @return String
*/
public static String securityPassword(String password){
String secPassword = "clot" + password + "hing";
return secPassword;
}
/**
* @methodDesc 生成token
* @param loginVo
* @return String
*/
public static String createToken(LoginVo loginVo){
String base = loginVo.getPassword() +"/"+slat;
String md5 = DigestUtils.md5DigestAsHex(base.getBytes());
String token = loginVo.getUsername()+"."+ md5 ;
return token;
}
/**
* @methodDesc token校验
* @param token,password
* @return String
*/
public static Integer checkToken(String token,String username,String password){
if (!token.equals(priToken(username,password))){
return null;
}
return 1;
}
/**
* @methodDesc 私有creatToken
* @param password
* @return String
*/
private static String priToken(String username,String password) {
String base = password+"/"+slat;
String md5 = DigestUtils.md5DigestAsHex(base.getBytes());
String cheToken = username+ "." +md5;
return cheToken;
}
/**
* @methodDesc 提取username
* @param request
* @return String
*/
if (user == null){
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
Integer result = MyShiro.checkToken(request.getHeader("Authorization"),user.getUsername(),user.getPassword());
if (result == null) {
//为null返回错误信息
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
// //result不为null继续操作
return Result.success(cartService.cartShow(user.getUserId()));
}
/**
* @Param: cartId
* @return: Result
*/
@ApiOperation(value = "删除购物车", notes = "用户端-删除购物车")
@DeleteMapping("/cart_delete/{cartId}")
public Result<Object> cartDelete(@PathVariable int cartId){
cartService.cartDelete(cartId);
return Result.success(null);
}
/**
* @methodDesc: 通过购物车下单
* @Param: shoppingCart
* @return: Result<>
*/
@ApiOperation(value = "购物车下单", notes = "用户端-通过购物车下单")
@PostMapping("/cart_order")
public Result<Orders> cartOrder(@RequestBody List<ShoppingCart> shoppingCartList){
System.out.println("check:"+shoppingCartList);
return Result.success(cartService.cartOrder(shoppingCartList));
}
}
* @Param:
* @return: Result<>
*/
@ApiOperation(value = "商品加入购物车", notes = "用户端-商品添加购物车")
@PostMapping("/cart_insert")
public Result<Object> cartInsert(HttpServletRequest request, @RequestBody CartVo cartVo){
//提取token的username
String username = MyShiro.drawUsername(request);
User user = userService.getUserByUname(username);
if (user == null){
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
Integer result = MyShiro.checkToken(request.getHeader("Authorization"),user.getUsername(),user.getPassword());
//判断result是否为null
if (result == null) {
//为null返回错误信息
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
//result不为null继续操作
cartService.cartInsert(cartVo);
return Result.success(null);
}
/**
* @Param: userId
* @return: List<ShoppingCart>
*/
@ApiOperation(value = "购物车列表", notes = "用户端-显示购物车")
@GetMapping("/cart_show")
public Result<List<CartAndGoodsDto>> cartShow(HttpServletRequest request){
String username = MyShiro.drawUsername(request);
User user = userService.getUserByUname(username);
if (user == null){
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
Integer result = MyShiro.checkToken(request.getHeader("Authorization"),user.getUsername(),user.getPassword());
if (result == null) {
//为null返回错误信息
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
// //result不为null继续操作
return Result.success(cartService.cartShow(user.getUserId()));
/**
*/
@Api(tags = "用户端-用户服务接口列表")
@RestController
@RequestMapping("/user")
public class UserController {
private static final Logger logger = LoggerFactory.getLogger(UserController.class);
@Autowired
private UserService userService;
// @Autowired
// private RedisService redisService;
/**
* @methodDesc: 用户信息管理
* @Param: userVo
* @return: Result<UserVo>
*/
@ApiOperation(value = "修改用户信息管理", notes = "用户端-添加用户信息")
@PutMapping("/user_info/{userId}")
public Result<UserVo> insertUserInfo(@PathVariable int userId,@RequestBody UserVo userVo){
logger.info(userId+userVo.toString());
return Result.success(userService.insertUserInfo(userId,userVo));
}
*/
public static String securityPassword(String password){
String secPassword = "clot" + password + "hing";
return secPassword;
}
/**
* @methodDesc 生成token
* @param loginVo
* @return String
*/
public static String createToken(LoginVo loginVo){
String base = loginVo.getPassword() +"/"+slat;
String md5 = DigestUtils.md5DigestAsHex(base.getBytes());
String token = loginVo.getUsername()+"."+ md5 ;
return token;
}
/**
* @methodDesc token校验
* @param token,password
* @return String
*/
public static Integer checkToken(String token,String username,String password){
if (!token.equals(priToken(username,password))){
return null;
}
return 1;
}
/**
* @methodDesc 私有creatToken
* @param password
* @return String
*/
private static String priToken(String username,String password) {
String base = password+"/"+slat;
String md5 = DigestUtils.md5DigestAsHex(base.getBytes());
String cheToken = username+ "." +md5;
return cheToken;
}
/**
* @methodDesc 提取username
@PutMapping("/user_info/{userId}")
public Result<UserVo> insertUserInfo(@PathVariable int userId,@RequestBody UserVo userVo){
logger.info(userId+userVo.toString());
return Result.success(userService.insertUserInfo(userId,userVo));
}
/**
* @methodDesc: 用户信息管理
* @Param: userVo
* @return: Result<UserVo>
*/
@ApiOperation(value = "修改用户信息管理", notes = "用户端-添加用户信息")
@PutMapping("/update_info")
public Result<UserVo> updateUserInfo(HttpServletRequest request,@RequestBody UserVo userVo){
logger.info(userVo.toString());
String token = request.getHeader("Authorization");
logger.info("token:"+token);
if (token == null || "".equals(token)){
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
String username = token.substring(0,token.indexOf("."));
logger.info("username:"+username);
User user = userService.getUserByUname(username);
logger.info(user.toString());
if (user == null){
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
Integer result = MyShiro.checkToken(token,user.getUsername(),user.getPassword());
//判断result是否为null
if (result == null) {
//为null返回错误信息和登录url
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
return Result.success(userService.insertUserInfo(user.getUserId(),userVo));
}
/**
* @methodDesc: 用户信息管理(查询)
* @Param: userId
* @return: Result<User>
*/
//为null返回错误信息和登录url
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
return Result.success(userService.insertUserInfo(user.getUserId(),userVo));
}
/**
* @methodDesc: 用户信息管理(查询)
* @Param: userId
* @return: Result<User>
*/
@ApiOperation(value = "查询用户信息", notes = "用户端-查询用户信息")
@GetMapping("/user_info")
public Result<UserVo> getUserInfo(HttpServletRequest request){
String token = request.getHeader("Authorization");
logger.info("token:"+token);
if (token == null || "".equals(token)){
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
String username = token.substring(0,token.indexOf("."));
logger.info("username:"+username);
// User user = redisService.get(UserKey.usrByUname, ""+username, User.class);
User user = userService.getUserByUname(username);
logger.info(user.toString());
if (user == null){
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
Integer result = MyShiro.checkToken(token,user.getUsername(),user.getPassword());
//判断result是否为null
if (result == null) {
//为null返回错误信息和登录url
return Result.error(CodeMsg.NOT_YET_LOGIN);
}
UserVo userVo = userService.getUserInfo(user.getUserId());
return Result.success(userVo);
}
/**
/**
* @methodDesc token校验
* @param token,password
* @return String
*/
public static Integer checkToken(String token,String username,String password){
if (!token.equals(priToken(username,password))){
return null;
}
return 1;
}
/**
* @methodDesc 私有creatToken
* @param password
* @return String
*/
private static String priToken(String username,String password) {
String base = password+"/"+slat;
String md5 = DigestUtils.md5DigestAsHex(base.getBytes());
String cheToken = username+ "." +md5;
return cheToken;
}
/**
* @methodDesc 提取username
* @param request
* @return String
*/
public static String drawUsername(HttpServletRequest request){
String token = request.getHeader("Authorization");
System.out.println("token:"+token);
if (token == null){
throw new GlobleException(CodeMsg.NOT_YET_LOGIN);
}
try {
String username = token.substring(0,token.indexOf("."));
System.out.println("username:"+username);
return username;
} catch (Exception e){
throw new GlobleException(CodeMsg.NOT_YET_LOGIN);
}
}
public static void main(String[] args){
LoginVo loginVo1 = new LoginVo("966966","966966");
LoginVo loginVo2 = new LoginVo("efg","456");
String token1 = MyShiro.createToken(loginVo1);
String token2 = MyShiro.createToken(loginVo2);
System.out.println(token1);
System.out.println(token1.substring(0,token1.indexOf(".")));
// System.out.println("D:\\work\\workspace\\clothing\\static\\1.jpg".substring("D:\\work\\workspace\\clothing\\static\\1.jpg".indexOf("g")+1));
/**
*/
@Api(tags = "用户端-商品服务接口列表")
@RestController
@RequestMapping("goods")
@CrossOrigin
public class GoodsController {
private static final Logger logger = LoggerFactory.getLogger(GoodsController.class);
@Autowired
private GoodsService goodsService;
/**
* @Param:
* @return: Result<>
*/
@ApiOperation(value = "显示所有商品", notes = "用户端-查询所有商品")
public class GoodsController {
private static final Logger logger = LoggerFactory.getLogger(GoodsController.class);
@Autowired
private GoodsService goodsService;
/**
* @Param:
* @return: Result<>
*/
@ApiOperation(value = "显示所有商品", notes = "用户端-查询所有商品")
@GetMapping("/goods_show_all")
public Result<List<Goods>> goodsShowAll(){
return Result.success(goodsService.goodsShowAll());
}
/**
* @Param:goodsId
* @return: Result<>
*/
@ApiOperation(value = "某个商品的页面", notes = "用户端-查询某个商品")
@GetMapping("/goods_show/{goodsId}")
public Result<Goods> goodsShow(@PathVariable int goodsId){
return Result.success(goodsService.goodsShow(goodsId));
}
/**
* @Param:
* @return: Result<>
*/
@ApiOperation(value = "显示所有分类", notes = "用户端-查询所有分类")
@GetMapping("/goods_type")
public Result<List<GoodsType>> goodsType(){
return Result.success(goodsService.goodsType());
}
/**
* @Param:
* @return: Result<>
*/
@ApiOperation(value = "分类信息页面展示", notes = "用户端-查询某个分类的商品")
@GetMapping("/type_show/{typeId}")
public Result<List<Goods>> typeShow(@PathVariable int typeId){