博客
关于我
springboot项目实战---Redis购物车
阅读量:368 次
发布时间:2019-03-04

本文共 7554 字,大约阅读时间需要 25 分钟。

Redis购物车

个人商城系统,后台对购物车数据进行“半持久化”。

因为购物车增删改的操作很频繁,如果使用mysql效率会很低,
所以使用redis进行存储。如果担心redis会挂,可使用redis集群,还是很靠谱的


配置文件 和redis连接池

参考上一篇redis进行缓存

购物车redis缓存设置:
CartPrefix.class

public class CartPrefix extends BasePrefix{       public CartPrefix(int expireSeconds, String prefix) {           super(expireSeconds, prefix);    }    /**     * 设置购物车缓存     */    public static CartPrefix getCartList= new CartPrefix(0,"cart");}

购物车service层代码:

CartService.class

@Service@Slf4jpublic class CartServiceImpl implements CartService {       @Autowired    RedisService redisService;    @Autowired    ProductInfoDao productInfoDao;    @Override    public int addCart(String userId, String productId, int num) {           //key为 userId_cart,校验是否已存在        Boolean exists = redisService.existsValue(CartPrefix.getCartList,userId,productId);        if (exists){               //获取现有的购物车中的数据            String json = redisService.hget(CartPrefix.getCartList,userId,productId);            if (json !=null){                   //转换为java实体类                CartDto cartDto = JSON.toJavaObject(JSONObject.parseObject(json),CartDto.class);                cartDto.setProductNum(cartDto.getProductNum()+num);                redisService.hset(CartPrefix.getCartList,userId,productId,JSON.toJSON(cartDto).toString());            }else {                   return 0;            }            return 1;        }        //根据商品id获取商品        ProductInfo productInfo = productInfoDao.findProductById(productId);        if (productInfo==null){               return 0;        }        //设置购物车值        CartDto cartDto = new CartDto();        cartDto.setProductId(productId);        cartDto.setProductName(productInfo.getProductName());        cartDto.setProductIcon(productInfo.getProductIcon());        cartDto.setProductPrice(productInfo.getProductPrice());        cartDto.setProductStatus(productInfo.getProductStatus());        cartDto.setProductNum(num);        cartDto.setCheck("1");        redisService.hset(CartPrefix.getCartList,userId,productId,JSON.toJSON(cartDto).toString());        return 1;    }    /**     * 展示购物车     * @param userId     * @return     */    @Override    public List
getCartList(String userId) { List
jsonList = redisService.hvals(CartPrefix.getCartList,userId); List
cartDtoList = new LinkedList<>(); for (String json:jsonList){ CartDto cartDto = JSON.toJavaObject(JSONObject.parseObject(json),CartDto.class); cartDtoList.add(cartDto); } return cartDtoList; } /** * 更新数量 * @param userId * @param productId * @param num * @return */ @Override public int updateCartNum(String userId, String productId, int num) { String json = redisService.hget(CartPrefix.getCartList,userId,productId); if (json==null){ return 0; } CartDto cartDto = JSON.toJavaObject(JSONObject.parseObject(json),CartDto.class); cartDto.setProductNum(num); redisService.hset(CartPrefix.getCartList,userId,productId,JSON.toJSON(cartDto).toString()); return 1; } /** * 全选商品 * @param userId * @param checked * @return */ @Override public int checkAll(String userId, String checked) { //获取商品列表 List
jsonList = redisService.hvals(CartPrefix.getCartList,userId); for (String json:jsonList){ CartDto cartDto = JSON.toJavaObject(JSONObject.parseObject(json),CartDto.class); if ("true".equals(checked)){ cartDto.setCheck("1"); }else if ("false".equals(checked)){ cartDto.setCheck("0"); }else { return 0; } redisService.hset(CartPrefix.getCartList,userId,cartDto.getProductId(),JSON.toJSON(cartDto).toString()); } return 1; } /** * 删除商品 * @param userId * @param productId * @return */ @Override public int delCartProduct(String userId, String productId) { redisService.hdel(CartPrefix.getCartList,userId,productId); return 1; } /** * 清空购物车 * @param userId * @return */ @Override public int delCart(String userId) { redisService.delete(CartPrefix.getCartList,userId); return 1; }}

购物车接口实现:

CartController.class

@RestController@RequestMapping("/cart")@Slf4jpublic class CartController {       @Autowired    CartService cartService;    /**     * 加入购物车     * @param reqMap     * @param user     * @return     */    @PostMapping(value = "/add")    @Autorization    public Object addCart(@RequestBody Map
reqMap, @CurrentUser User user){ //获取登陆用户的userId String userId = RequestUtil.getMapString(user.getId()); String productId = RequestUtil.getMapString(reqMap.get("product_id").toString()); String numString = RequestUtil.getMapString(reqMap.get("product_num").toString()); Integer num = Integer.parseInt(numString); //加入购物车 int effectNum = cartService.addCart(userId,productId,num); if (effectNum<=0){ return ResultUtil.fail(ResultEnum.ADD_CART_ERROR); } return ResultUtil.ok(ResultEnum.ADD_CART_SUCCESS.getMessage()); } @GetMapping(value = "/getCartList") @Autorization public Object getCartList(@CurrentUser User user){ String userId = RequestUtil.getMapString(user.getId()); List
cartDtoList = cartService.getCartList(userId); return ResultUtil.ok(cartDtoList); } @PostMapping(value = "/updateCartNum") @Autorization public Object updateCartNum(@RequestBody Map
reqMap,@CurrentUser User user){ String userId = RequestUtil.getMapString(user.getId()); String productId = RequestUtil.getMapString(reqMap.get("product_id").toString()); String numString = RequestUtil.getMapString(reqMap.get("product_num").toString()); Integer num = Integer.parseInt(numString); int effectNum = cartService.updateCartNum(userId,productId,num); if (effectNum <=0){ return ResultUtil.fail(); } return ResultUtil.ok(); } @PostMapping(value = "/checkAll") @Autorization public Object checkAll(@RequestBody Map
reqMap,@CurrentUser User user){ String userId = RequestUtil.getMapString(user.getId()); String check = RequestUtil.getMapString(reqMap.get("check").toString()); int effectNum = cartService.checkAll(userId,check); if (effectNum <=0){ return ResultUtil.fail(); } return ResultUtil.ok(); } @PostMapping("/delCartProduct") @Autorization public Object delCartProduct(@RequestBody Map
reqMap,@CurrentUser User user){ String userId = RequestUtil.getMapString(user.getId()); String productId = RequestUtil.getMapString(reqMap.get("product_id").toString()); int effectNum = cartService.delCartProduct(userId,productId); if (effectNum <=0){ return ResultUtil.fail(); } return ResultUtil.ok(); } @PostMapping("/delCart") @Autorization public Object delCart(@CurrentUser User user){ String userId = RequestUtil.getMapString(user.getId()); int effectNum = cartService.delCart(userId); if (effectNum <=0){ return ResultUtil.fail(); } return ResultUtil.ok(); }}

商城项目地址 https://github.com/627886474/sneaker

欢迎start,如有不足,还请指教。

在这里插入图片描述

转载地址:http://qwve.baihongyu.com/

你可能感兴趣的文章
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>