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

你可能感兴趣的文章
Mac book pro打开docker出现The data couldn’t be read because it is missing
查看>>
MAC M1大数据0-1成神篇-25 hadoop高可用搭建
查看>>
mac mysql 进程_Mac平台下启动MySQL到完全终止MySQL----终端八步走
查看>>
Mac OS 12.0.1 如何安装柯美287打印机驱动,刷卡打印
查看>>
MangoDB4.0版本的安装与配置
查看>>
Manjaro 24.1 “Xahea” 发布!具有 KDE Plasma 6.1.5、GNOME 46 和最新的内核增强功能
查看>>
mapping文件目录生成修改
查看>>
MapReduce程序依赖的jar包
查看>>
mariadb multi-source replication(mariadb多主复制)
查看>>
MariaDB的简单使用
查看>>
MaterialForm对tab页进行隐藏
查看>>
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>
Metasploit CGI网关接口渗透测试实战
查看>>
Metasploit Web服务器渗透测试实战
查看>>
MFC模态对话框和非模态对话框
查看>>