尚品汇-购物车列表、临时用户购物车与登录用户购物车合并实现(三十七)

2024-08-24 04:52

本文主要是介绍尚品汇-购物车列表、临时用户购物车与登录用户购物车合并实现(三十七),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录:

(1)功能—展示购物车列表

(2)在web-all添加前端实现

(3)功能--合并购物车

(1)功能—展示购物车列表

购物车列表接口:CartService

/*** 通过用户Id 查询购物车列表* @param userId* @param userTempId* @return*/
List<CartInfo> getCartList(String userId, String userTempId);

 实现类:CartServiceImpl

@Override
public List<CartInfo> getCartList(String userId, String userTempId) {//获取临时用户购物车数据List<CartInfo> cartInfoList = null;if(!StringUtils.isEmpty(userTempId)){BoundHashOperations<String, String, CartInfo> boundHashOps = this.redisTemplate.boundHashOps(this.getCartKey(userTempId));cartInfoList = boundHashOps.values();}//获取用户购物车数据if(!StringUtils.isEmpty(userId)){BoundHashOperations<String, String, CartInfo> boundHashOps = this.redisTemplate.boundHashOps(this.getCartKey(userId));cartInfoList = boundHashOps.values();}if(!CollectionUtils.isEmpty(cartInfoList)){//  展示购物车列表的时候应该有顺序! 京东:按照更新时间! 苏宁:创建时间!cartInfoList.sort((o1,o2)->{//  使用时间进行比较return DateUtil.truncatedCompareTo(o2.getUpdateTime(),o1.getUpdateTime(), Calendar.SECOND);});}return cartInfoList;
}

 

 

控制器:CartApiController

/*** 查询购物车** @param request* @return*/
@GetMapping("cartList")
public Result cartList(HttpServletRequest request) {// 获取用户IdString userId = AuthContextHolder.getUserId(request);// 获取临时用户IdString userTempId = AuthContextHolder.getUserTempId(request);List<CartInfo> cartInfoList = cartService.getCartList(userId, userTempId);return Result.ok(cartInfoList);
}

 在Web-all模块添加一个Controller:

(2)在web-all添加前端实现

添加依赖和配置网关

<dependency>
      <groupId>com.atguigu.gmall</groupId>
      <artifactId>service-cart-client</artifactId>
      <version>1.0</version>
   </dependency>

在nacos的配置网关中添加 

- id: web-cart
 
uri: lb://web-all
 
predicates:
  - Host=cart.gmall.com

- id: service-cart
 
uri: lb://service-cart
 
predicates:
  - Path=/*/cart/**

 controller实现:

添加跳转到购物车详情页面的controller

package com.atguigu.gmall.all.controller;/*** <p>* 购物车页面* </p>**/
@Controller
public class CartController {@Autowiredprivate CartFeignClient cartFeignClient;@Autowiredprivate ProductFeignClient productFeignClient;/*** 查看购物车* @param request* @return*/@RequestMapping("cart.html")public String index(){return "cart/index";}/*** 添加购物车* @param skuId* @param skuNum* @param request* @return*/@RequestMapping("addCart.html")public String addCart(@RequestParam(name = "skuId") Long skuId,@RequestParam(name = "skuNum") Integer skuNum,HttpServletRequest request){SkuInfo skuInfo = productFeignClient.getSkuInfo(skuId);request.setAttribute("skuInfo",skuInfo);request.setAttribute("skuNum",skuNum);return "cart/addCart";}
}

 

(3)功能--合并购物车

功能分析:

  1. 当用户登录以后,先判断未登录的时候,用户是否购买了商品。
    1. 如果用户购买了商品,则找到对应的商品Id,对数量进行合并。
    2. 没有找到的商品,则直接添加到数据。
  2. 合并完成之后,删除未登录数据。

 

更改实现类:CartServiceImpl:cartList的实现

@Overridepublic List<CartInfo> cartList(String userId, String userTempId) {/*1.  判断是否登录,根据判断结果查询不同的购物车!2.  查询的结果需要排序!3.  有可能需要合并!在登录的情况下.  未登录 ---> 登录合并!合并完成之后,需要删除未登录购物车数据!case1: 有userId ,没有userTempIdcase2: 没有userId ,有userTempId   return noLoginCartInfoListcase3: 有userId ,有userTempId登录情况下合并购物车:先判断未登录购物车集合有数据!true: 有数据合并false: 没有数据只需要登录购物车数据删除未登录购物车!*///  声明一个集合来存储未登录数据List<CartInfo> noLoginCartInfoList = null;//  完成case2 业务逻辑//  属于未登录if (!StringUtils.isEmpty(userTempId)){String cartKey = this.getCartKey(userTempId);//  获取登录的购物车集合数据!//  noLoginCartInfoList = this.redisTemplate.boundHashOps(cartKey).values();noLoginCartInfoList  = this.redisTemplate.opsForHash().values(cartKey);}//  这个是集合的排序if (StringUtils.isEmpty(userId)){if (!CollectionUtils.isEmpty(noLoginCartInfoList)){noLoginCartInfoList.sort((o1,o2)->{//  按照更新时间:return DateUtil.truncatedCompareTo(o2.getUpdateTime(),o1.getUpdateTime(), Calendar.SECOND);});}//  返回未登录数据!return noLoginCartInfoList;}//  ----------------------case 1 and case3 -----------------/*demo:登录:17  118  1未登录:17  118  119  2合并:17  218  219  2*///  属于登录List<CartInfo> LoginCartInfoList = null;//  先获取到登录购物车的keyString cartKey = this.getCartKey(userId);//  hset key field value;  hget key field;  hvals key ; hmset key field value field value;  hmset key map;//  合并思路二:BoundHashOperations<String, String, CartInfo>  boundHashOperations = this.redisTemplate.boundHashOps(cartKey);//  判断购物车中的field//  boundHashOperations.hasKey(skuId.toString);if (!CollectionUtils.isEmpty(noLoginCartInfoList)){//  循环遍历未登录购物车集合noLoginCartInfoList.stream().forEach(cartInfo -> {//  在未登录购物车中的skuId 与登录的购物车skuId 相对  skuId = 17 18if (boundHashOperations.hasKey(cartInfo.getSkuId().toString())){//  合并业务逻辑 : skuNum + skuNum 更新时间CartInfo loginCartInfo = boundHashOperations.get(cartInfo.getSkuId().toString());//更新数量loginCartInfo.setSkuNum(loginCartInfo.getSkuNum()+cartInfo.getSkuNum());loginCartInfo.setUpdateTime(new Date());//  最新价格loginCartInfo.setSkuPrice(productFeignClient.getSkuPrice(cartInfo.getSkuId()));//  选中状态合并!if (cartInfo.getIsChecked().intValue()==1){
//                        if (loginCartInfo.getIsChecked().intValue()==0){
//                            loginCartInfo.setIsChecked(1);
//                        }loginCartInfo.setIsChecked(1);}//  修改缓存的数据:    hset key field valueboundHashOperations.put(cartInfo.getSkuId().toString(),loginCartInfo);}else {//  直接添加到缓存!    skuId = 19cartInfo.setUserId(userId);cartInfo.setCreateTime(new Date());cartInfo.setUpdateTime(new Date());boundHashOperations.put(cartInfo.getSkuId().toString(),cartInfo);}});//  删除未登录购物车数据!this.redisTemplate.delete(this.getCartKey(userTempId));}//  获取到合并之后的数据:LoginCartInfoList = this.redisTemplate.boundHashOps(cartKey).values();if (CollectionUtils.isEmpty(LoginCartInfoList)){return new ArrayList<>();}//  设置合并之后的排序结果!LoginCartInfoList.sort(((o1, o2) -> {return DateUtil.truncatedCompareTo(o2.getUpdateTime(),o1.getUpdateTime(), Calendar.SECOND);}));return LoginCartInfoList;}

 未登录时:

 

登录的数据:

在购物车页面点击登录:或者结算时会跳转登录

 数据进行了合并,临时id数据页进行了清楚

这篇关于尚品汇-购物车列表、临时用户购物车与登录用户购物车合并实现(三十七)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1101499

相关文章

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Java实现本地缓存的四种方法实现与对比

《Java实现本地缓存的四种方法实现与对比》本地缓存的优点就是速度非常快,没有网络消耗,本地缓存比如caffine,guavacache这些都是比较常用的,下面我们来看看这四种缓存的具体实现吧... 目录1、HashMap2、Guava Cache3、Caffeine4、Encache本地缓存比如 caff

Java高效实现Word转PDF的完整指南

《Java高效实现Word转PDF的完整指南》这篇文章主要为大家详细介绍了如何用Spire.DocforJava库实现Word到PDF文档的快速转换,并解析其转换选项的灵活配置技巧,希望对大家有所帮助... 目录方法一:三步实现核心功能方法二:高级选项配置性能优化建议方法补充ASPose 实现方案Libre

Go中select多路复用的实现示例

《Go中select多路复用的实现示例》Go的select用于多通道通信,实现多路复用,支持随机选择、超时控制及非阻塞操作,建议合理使用以避免协程泄漏和死循环,感兴趣的可以了解一下... 目录一、什么是select基本语法:二、select 使用示例示例1:监听多个通道输入三、select的特性四、使用se

Java 中编码与解码的具体实现方法

《Java中编码与解码的具体实现方法》在Java中,字符编码与解码是处理数据的重要组成部分,正确的编码和解码可以确保字符数据在存储、传输、读取时不会出现乱码,本文将详细介绍Java中字符编码与解码的... 目录Java 中编码与解码的实现详解1. 什么是字符编码与解码?1.1 字符编码(Encoding)1

Python Flask实现定时任务的不同方法详解

《PythonFlask实现定时任务的不同方法详解》在Flask中实现定时任务,最常用的方法是使用APScheduler库,本文将提供一个完整的解决方案,有需要的小伙伴可以跟随小编一起学习一下... 目录完js整实现方案代码解释1. 依赖安装2. 核心组件3. 任务类型4. 任务管理5. 持久化存储生产环境

详解Java中三种状态机实现方式来优雅消灭 if-else 嵌套

《详解Java中三种状态机实现方式来优雅消灭if-else嵌套》这篇文章主要为大家详细介绍了Java中三种状态机实现方式从而优雅消灭if-else嵌套,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录1. 前言2. 复现传统if-else实现的业务场景问题3. 用状态机模式改造3.1 定义状态接口3

MySQL 临时表与复制表操作全流程案例

《MySQL临时表与复制表操作全流程案例》本文介绍MySQL临时表与复制表的区别与使用,涵盖生命周期、存储机制、操作限制、创建方法及常见问题,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小... 目录一、mysql 临时表(一)核心特性拓展(二)操作全流程案例1. 复杂查询中的临时表应用2. 临时

基于Python实现温度单位转换器(新手版)

《基于Python实现温度单位转换器(新手版)》这篇文章主要为大家详细介绍了如何基于Python实现温度单位转换器,主要是将摄氏温度(C)和华氏温度(F)相互转换,下面小编就来和大家简单介绍一下吧... 目录为什么选择温度转换器作为第一个项目项目概述所需基础知识实现步骤详解1. 温度转换公式2. 用户输入处