基于javaweb+mysql的springboot在线服装销售商城系统(java+springboot+maven+vue+mysql)

基于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){

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值