博客
关于我
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/

你可能感兴趣的文章
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>