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

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

相关文章

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们