电商项目-购物车(合并购物车问题)

1.添加购物车分析

1.商品详情页添加购物车
    2.商品详情页添加购物车时,先判断用户是否登录,若是没有登陆,在判断是否存在临时用户,若是cookie中也没有临时用户,则生成临时用户。
    3.购物车商品与临时用户ID关联,当用户登陆后,将临时用户ID的购物车商品与登陆用户id的商品合并。

2.临时用户处理

1.由于userId咱们是从网关统一传递过来的,那么临时用户ID咱们也能够从网关传递过来,改造网关。
    2.在过滤器中添加一个获取当前用户临时ID的方法
    3.先从header取,若是header没有,再从cookie取
    4.在设置用户ID的方法里,同时设置临时ID到header。
    5.判断若是用户的临时ID或者用户ID不为空。
    6.继续判断:若是用户ID不为空,将用户ID设置到请求头,若是用户临时ID不为空,将用户临时ID设置到请求头,放行请求。

3.添加购物车功能实现

1.建立购物车的mapper接口
    2.建立购物车的服务接口
    3.添加购物车要根据商品的skuId,用户的ID,和商品数量进行添加。
    4.首先根据用户ID获取到购物车的key
    5.由于考虑到可能redis里面的数据过时,因此添加以前须要先去根据key判断一下,缓存若是没有,就去数据库查数据,并放到缓存。
    6.根据用户ID去查询数据库是否存在这个用户的购物车是否已经存在这件商品,若是已经存在,直接修改已经存在的商品数量便可。
    7.若是判断数据库用户的购物车不存在这件商品,咱们须要根据商品的数量和用户的ID,将这件商品保存进数据库。
    8.操做完数据库以后,再根据以前获取的key将商品数据保存到redis,并设置过时时间。

4.商品添加优化

同步数据库,异步redis

5.购物车列表展现

1.购物车的展现分为两种状况:一种是用户为登陆,使用的是临时用户ID,另外一种状况是用户已经登陆,此时须要判断登陆的用户cookie有没有临时用户ID,有的话须要合并这两个购物车,没有的话只须要查出用户登陆后的购物车数据。
    2.定义一个list集合用来接收最终的用户购物车商品数据。
    3.定义一个方法getCartList(String ID),经过用户ID或临时用户ID查询购物车数据并返回list集合。
    4.判断:若是用户ID为空,说明用户未登陆,传入getCartList(TempId);获得临时ID的购物车商品集合,并返回。
    5.判断:若是用户ID不等于空,说明已经登录了,
    根据用户ID查出购物车商品集合。
    6.判断:若是集合不为空,将临时用户ID的购物车数据和登陆后用户的购物车商品数据合并为list,并删除数据库中临时用户的数据。
    7.判断:若是用户临时ID的购物车为空或者登陆用户的购物车为空,list=getCartList(userId);
    8.返回list集合

6.关于购物车的合并

1.根据临时用户ID获取到临时用户ID的购物车集合,使用流转换为map。
    2.遍历登陆用户的购物车,判断:若是没登陆的购物车里包含已经登陆的用户的购物车的商品,将商品数量合并,并判断没登陆的购物车的商品的是已选中,登陆的购物车状态也设置为已选中。
    3.若是已经登陆的购物车不包含临时购物车的商品,降临时购物车的商品异步保存到数据库的登陆购物车。
    4.将合并之后的购物车数据都放入缓存。

7.关于根据用户id获取购物车数据的getCartList

1.判断:若是用户ID为空,返回空。
    2.根据用户ID获取key去redis查出数据。
    3.若是redis查出的数据不为空,将购物车的数据排序,若是redis查出的数据为空,根据用户id去数据库查,并放入缓存。
    4.返回数据。

8.更新商品选中状态

1.异步去数据库更新商品选中状态
    2.根据用户ID获取redis的key
    3.根据key去redis获取数据
    4.先获取到用户修改的商品,修改商品选中状态
    5.更新缓存,设置过时时间。

9.删除购物车的商品

1.根据用户id和商品id异步删除数据库的数据
    2.修改redis里面的数据。

10.关于微服务之间用户信息的传递

由于微服务的调用之间没有传递头文件,因此每次远程调用的请求
    编写一个统一的拦截器继承RequestInterceptor
    拦截每一次请求将用户ID和用户临时ID设置到请求头里面。

11.问题补充:

假如一个电脑登录多个用户,如何确保购物车不会合并出错?

    当用户退出登陆的时候删除cookie里面的临时用户ID和对应的redis里面的token
    一个用户经过多个ip访问?加一个方法判断登陆的ip是不是token里面的,若是不是从新查询数据库并从新存入缓存。