修改购物车数据

1. 后端接口设计

请求方式 : PUT /cart/

请求参数: JSON 或 表单

参数 类型 是否必须 说明
sku_id int 商品sku id
count int 数量
selected bool 是否勾选,默认勾选

返回数据: JSON

参数 类型 是否必须 说明
sku_id int 商品sku id
count int 数量
selected bool 是否勾选,默认勾选

2. 后端实现

在carts/views.py中修改视图,添加put方法

 class CartView(APIView):
    ...

    def put(self, request):
        """
        修改购物车数据
        """
        serializer = CartSerializer(data=request.data)
        serializer.is_valid(raise_exception=True)
        sku_id = serializer.validated_data.get(‘sku_id‘)
        count = serializer.validated_data.get(‘count‘)
        selected = serializer.validated_data.get(‘selected‘)

        # 尝试对请求的用户进行验证
        try:
            user = request.user
        except Exception:
            # 验证失败,用户未登录
            user = None

        if user is not None and user.is_authenticated:
            # 用户已登录,在redis中保存
            redis_conn = get_redis_connection(‘cart‘)
            pl = redis_conn.pipeline()
            pl.hset(‘cart_%s‘ % user.id, sku_id, count)
            if selected:
                pl.sadd(‘cart_selected_%s‘ % user.id, sku_id)
            else:
                pl.srem(‘cart_selected_%s‘ % user.id, sku_id)
            pl.execute()
            return Response(serializer.data)
        else:
            # 用户未登录,在cookie中保存
            # 使用pickle序列化购物车数据,pickle操作的是bytes类型
            cart = request.COOKIES.get(‘cart‘)
            if cart is not None:
                cart = pickle.loads(base64.b64decode(cart.encode()))
            else:
                cart = {}

            cart[sku_id] = {
                ‘count‘: count,
                ‘selected‘: selected
            }
            cookie_cart = base64.b64encode(pickle.dumps(cart)).decode()

            response = Response(serializer.data)
            # 设置购物车的cookie
            # 需要设置有效期,否则是临时cookie
            response.set_cookie(‘cart‘, cookie_cart, max_age=constants.CART_COOKIE_EXPIRES)
            return response

原文地址:https://www.cnblogs.com/hzlnice/p/9393125.html

时间: 2024-11-13 09:37:57

修改购物车数据的相关文章

Ajax修改购物车

1.购物车类的设计 ShoppingCartItem:书的封装,包括书名,数量,价格三个属性,以及对应的getter和setter方法. ShoppingCart:购物车封装类,items为 Map<String, ShoppingCartItem> ,以及加入购物车,得到购物车中书的总数量以及总价格三个函数. 2:jsp加入购物车,超链接中带入书名以及价格 <body> <!-- 加入span的目的是为了定位 --> <div id="cartstat

查询购物车数据

1. 后端接口设计 请求方式 : GET /cart/ 请求参数: 无 返回数据: JSON 或 表单 [ { "id": 9, "count": 3, "name": "华为 HUAWEI P10 Plus 6GB+64GB 钻雕金 移动联通电信4G手机 双卡双待", "default_image_url": "http://image.meiduo.site:8888/group1/M00/0

oracle特殊恢复-bbed修改某个数据文件头

数据文件头中的scn要与控制文件中的scn一致,数据库才可以open,在open过程中我们可以通过bbed来修改某个数据文件头的scn,来欺骗oracle,来open库. 1.环境如下 使用Oracle 11gR2进行测试,具体版本为11.2.0.4 [email protected] SQL>select file#,name,checkpoint_change#,checkpoint_time from v$datafile;      FILE# NAME                 

nodejs 通过 get获取数据修改redis数据

如下代码是没有报错的正确代码 我通过https获取到数据 想用redis set一个键值存储 现在我掉入了回调陷阱res.on 里面接收到的数据是data 里面如果放入 client.on('connect',functi ...这个修改函数就会报错. 'use strict'; var redis = require('redis'), RDS_PORT = 6379, //端口号 RDS_HOST = '127.0.0.1', //服务器IP //RDS_PWD = 'porschev',

数据元素文本增强(修改标准数据元素描述)

事务代码:CMOD 1. . 2. 3. 4. 5. 数据元素文本增强(修改标准数据元素描述),布布扣,bubuko.com

修改tcp数据内容

http://blog.sina.com.cn/s/blog_6f0c85fb0100xi1x.html 2.6内核基于NetFilter处理框架修改TCP数据包实现访问控制 参考上面的钩子函数,结合下面的函数修改tcp的数据内容. __nf_nat_mangle_tcp_packet (十五)洞悉linux下的Netfilter&iptables:开发自己的hook函数[实战](上) http://blog.chinaunix.net/uid-23069658-id-3243434.html

用C#实现修改网页数据

背景    由于某宝最近升级,导致朋友买的刷单软件不能用了:在又付过钱之后,那个刷单软件供应商竟然捐款跑路了...于是,朋友委托我做一个功能一样的软件.功能    他给我描述的软件功能,是这个样子的:在网页登陆我的某宝之后,在[已买到的宝贝]页面,有待付款.待发货.待收货.待评价数量,软件可以随意修改这些数据:页面下边还有交易单,软件还可以隐藏指定的单据...然后他把之前买的软件发给我,让我研究研究...分析    按照他的描述,我概括之后,软件的功能就是修改网页数据.我先用Reflector打

SQL语句汇总(二)——数据修改、数据查询

首先创建一张表如下,创建表的方法在上篇介绍过了,这里就不再赘述. 添加新数据: INSERT INTO <表名> (<列名列表>) VALUES (<值列表>)  如: INSERT INTO t_student (student_id,student_name,student_age,student_sex) VALUES (1,'大毛',18,'男'); 其中列名可以省略,省略之后要求插入的值必须与列一一对应: INSERT INTO t_student VALUE

Oracle 修改一行数据内存主要变化

向Oracle 数据库发出请求,修改一行数据,在内存中主要有以下变化: 1. 服务器进程将包含该行数据的块读取到内存中 2. 写redo日志.将内存中该数据块指向undo表空间中数据块的变量向量记录到redo日志中. 3. 将内存中的该数据块复制到undo段中. 4. 写redo日志.将修改的具体操作的变更向量记录到redo日志. 5. 修改该数据块. redo日志记录数据库的一切变化.每次改动至少记录两次redo日志,一次用于指向原来的镜像块,一次用于记录具体的修改内容.