s11 day100路飞项目逻辑购物车一
Luffy项目
先看练习,如下:
一. 添加购物车和查看
1. url
url(r'^shoppingcar/$', shoppingcar.ShoppingCarView.as_view({"post":"create","get":"list"})),
2. 视图
class ShoppingCarView(ViewSetMixin,APIView):
def list(self,request,*args,**kwargs):
return Response("h")
def create(self, request, *args, **kwargs):
print("request.body===>",request.body)
print("request.post===>",request.POST)
return Response({"code": })
① 通过postman发送 JSON格式请求(application/json)request.body

输出结果:

POST里面没有值


② request.data
print("request.body===>",request.body)
print("request.data===>",request.data)
print("request.post===>",request.POST)
打印结果:
request.body===> b'{\t\n\t"courseid":1,"policyid":2\n\t\n}'
request.data===> {'courseid': , 'policyid': }
request.post===> <QueryDict: {}>
以上是application/json格式发送请求
下面为 urlencoded格式
print("request.body===>",request.body)
print("request.data===>",request.data)
print("request.post===>",request.POST)
发送请求:

输出结果:
request.body===> b'k1=123&k2=456'
request.data===> <QueryDict: {'k1': [''], 'k2': ['']}>
request.post===> <QueryDict: {'k1': [''], 'k2': ['']}>
这些request 不是Django的request , 而是 restframework的request.
request._request为 Django的request
print("request.body===>",request.body)
print("request.data===>",request.data)
print("request.post===>",request.POST)
print("***"*)
print("django's request",request._request.body)
print("django's request",request._request.POST)
发送urlencode数据格式
request.body===> b'k1=123&k2=456'
request.data===> <QueryDict: {'k1': [''], 'k2': ['']}> restframework的request
request.post===> <QueryDict: {'k1': [''], 'k2': ['']}>
******************************
django's request b'k1=&k2='
django's request <QueryDict: {'k1': [''], 'k2': ['']}>
发送Application/json数据格式
request.body===> b'{\t\n\t"courseid":1,"policyid":2\n\t\n}'
request.data===> {'courseid': , 'policyid': }
request.post===> <QueryDict: {}>
******************************
django's request b'{\t\n\t"courseid":,"policyid":\n\t\n}'
django's request <QueryDict: {}>
一、路飞项目的逻辑:
1. 接收用户选中的课程id和价格策略
course_id = request.data.get("courseid")
policy_id = request.data.get("policyid")
2. 判断数据的合法性
a.课程是否合法
b.价格策略是否合法
def create(self, request, *args, **kwargs):
# . 接收用户选中的课程ID和价格策略ID
course_id = request.data.get("courseid")
policy_id = request.data.get("policyid")
# .判断数据是否合法
# -课程是否合法
# - 价格策略是否合法
#2.1 课程是否合法
course= models.Course.objects.filter(id =course_id).first()
print(course)
if not course:
return Response({"code":,"error":"课程不存在"})
price_policy_query_set =course.price_policy.all()
price_policy_dict={}
for item in price_policy_query_set:
temp ={
"id" :item.id,
"price" :item.price,
"valid_period" :item.valid_period,
"valid_period_display":item.get_valid_period_display()
}
price_policy_dict[item.id]=temp
#2.2 价格策略是否合法
if policy_id not in price_policy_dict:
return Response({"code":,"error":"价格策略你别瞎改"})
return Response({"code": })
构建数据类型
1. 列表
2. 字典 (以id作为key,)
price_policy_query_set =course.price_policy.all()
price_policy_list =[]
price_policy_dict={} for item in price_policy_query_set: temp ={
"id" :item.id,
"price" :item.price,
"valid_period" :item.valid_period,
"valid_period_display":item.get_valid_period_display()
}
price_policy_list.append(temp)
price_policy_dict[item.id] =temp
print(price_policy_list)
print("**"*)
print(price_policy_dict)
print(("**"*))
print(item.id ,item.price,item.valid_period,item.get_valid_period_display)
结果:
[{'id': , 'price': 100.0, 'valid_period': , 'valid_period_display': '1周'}]
****************************************
{: {'id': , 'price': 100.0, 'valid_period': , 'valid_period_display': '1周'}}
****************************************
100.0 <bound method curry.<locals>._curried of <PricePolicy: MySQL入门(付费)(1周)100.0>>
[{'id': , 'price': 100.0, 'valid_period': , 'valid_period_display': '1周'}, {'id': , 'price': 20000000.0, 'valid_period': , 'valid_period_display': '2个月'}]
****************************************
{: {'id': , 'price': 100.0, 'valid_period': , 'valid_period_display': '1周'}, : {'id': , 'price': 20000000.0, 'valid_period': , 'valid_period_display': '2个月'}}
****************************************
20000000.0 <bound method curry.<locals>._curried of <PricePolicy: MySQL入门(付费)(2个月)20000000.0>>
[/Aug/ ::] "POST /api/v1/shoppingcar/ HTTP/1.1"

赋值测试:

三、把商品和价格放入购物车:
1. 添加到购物车 create
#.把商品和价格侧率信息放入购物车shoppingcar """ 购物车中要放: 课程ID 课程名称 课程图片 默认选中的价格侧率 所有价格策略 redis不支持字典套字典需要dumps出来 { :{ 课程ID 课程名称 课程图片 默认选中的价格侧率 所有价格策略 } :{ 课程ID 课程名称 课程图片 默认选中的价格侧率 所有价格策略 } } { shopping_car_用户ID_课程ID:{ id:课程ID name:课程名称 img: 课程图片 default:... price_list:所有价格策略 } } """ key ="shopping_car_%s_%s"%(,course_id)
# 1 可以定义为变量 USER_ID =1 CONN.hset(key,"id",course_id) CONN.hset(key,"name",course.name) CONN.hset(key,"name",course.course_img) CONN.hset(key,"deault_price",policy_id) CONN.hset(key,"price_policy_dict",json.dumps(price_policy_dict)) return Response({"已经成功加入购物车"})
#.把商品和价格侧率信息放入购物车shoppingcar """ 购物车中要放: 课程ID 课程名称 课程图片 默认选中的价格侧率 所有价格策略 redis不支持字典套字典需要dumps出来 { 1:{ 课程ID 课程名称 课程图片 默认选中的价格侧率 所有价格策略 } 2:{ 课程ID 课程名称 课程图片 默认选中的价格侧率 所有价格策略 } } { shopping_car_用户ID_课程ID:{ id:课程ID name:课程名称 img: 课程图片 default:... price_list:所有价格策略 } } """ key ="shopping_car_%s_%s"%(,course_id)
# 可以定义为变量 USER_ID = CONN.hset(key,"id",course_id) CONN.hset(key,"name",course.name) CONN.hset(key,"name",course.course_img) CONN.hset(key,"deault_price",policy_id) CONN.hset(key,"price_policy_dict",json.dumps(price_policy_dict)) return Response({"已经成功加入购物车"})
测试redis
postman发一个请求

另起一个文件
import json
import redis
conn =redis.Redis(host="127.0.0.1",port="")
print(conn.keys()) print(conn.hget('shopping_car_1_1',"id").decode("utf-8"))
print(conn.hget('shopping_car_1_1',"name").decode("utf-8"))
# print(conn.hget('shopping_car_1_1',"img").decode("utf-8"))
# print(conn.hget('shopping_car_1_1',"default_price_id").decode("utf-8"))
print(json.loads(conn.hget('shopping_car_1_1',"price_policy_dict").decode("utf-8")))
打印结果:
[b'shopping_car_1_1']
{'': {'id': , 'price': 100.0, 'valid_period': , 'valid_period_display': '1周'}, '': {'id': , 'price': 20000000.0, 'valid_period': , 'valid_period_display': '2个月'}}
2. 查看购物车 list
def list(self,request,*args,**kwargs):
ret ={"code":,"data":None,"error":None}
try:
shopping_car_course_list =[] pattern ="shopping_car_%s"%(USER_ID,)
user_key_list =CONN.keys(pattern)
for key in user_key_list:
temp ={
"id":CONN.hget(key,"id").decode("utf-8"),
"name":CONN.hget(key,"name").decode("utf-8"),
"img":CONN.hget(key,"img").decode("utf-8"),
"default_price_id":CONN.hget(key,"default_price_id").decode("utf-8"),
"price_policy_dict":json.load(CONN.hget(key,"price_policy_dict").decode("utf-8"))
}
shopping_car_course_list.append(temp) ret["data"]= shopping_car_course_list
except Exception as e:
ret["code"]=
ret["error"]="获取购物车数据失败"
return Response(ret)
3. 购物车删除
url(r'^shoppingcar/$',shoppingcar.ShoppingCarView.as_view({"post":"create","get":"list","delete":"destroy"})),
def destory(self,request,pk,*args,**kwargs):
respone= BaseResponse()
try:
courseid = request.GET.get("couseid")
key ="shopping_car_%s_%s*"%(USER_ID,courseid)
CONN.delete(key)
respone.data ="删除成功"
except Exception as e:
respone.code =
respone.error ="删除失败"
return Response("删除成功")
===================购物车逻辑=========================
s11 day100路飞项目逻辑购物车一的更多相关文章
- s11 day 101 python Linux环境安装 与路飞项目支付功能
from django.conf.urls import urlfrom django.contrib import adminfrom app01 import viewsurlpatterns = ...
- 路飞项目背景,contentType以及django缓存
昨日回顾: 分页器: 普通分页 # 普通分页 from rest_framework.pagination import PageNumberPagination -每页的大小(默认) -查询的时候, ...
- vue第十七单元(电商项目逻辑处理,电商划分)
第十七单元(电商项目逻辑处理,电商划分) #课程目标 1.什么是电商项目 2.什么是B2B,B2C,C2C模式,常见的电商项目 3.移动端电商项目常见的逻辑处理 4.[知识扩展]传统系统架构及分布式系 ...
- git的介绍、git的功能特性、git工作流程、git 过滤文件、git多分支管理、远程仓库、把路飞项目传到远程仓库(非空的)、ssh链接远程仓库,协同开发
Git(读音为/gɪt/)是一个开源的分布式版本控制系统,可以有效.高速地处理从很小到非常大的项目版本管理. [1] 也是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码 ...
- DRF 商城项目 - 购物( 购物车, 订单, 支付 )逻辑梳理
购物车 购物车模型 购物车中的数据不应该重复. 即对相同商品的增加应该是对购买数量的处理而不是增加一条记录 因此对此进行联合唯一索引, 但是也因此存在一些问题 class ShoppingCart(m ...
- s11 day 102 python Linux环境安装 与路飞项目 微信平台接口
1.微信公众号平台沙箱环境地址 https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login 二.结算中心业务 结算中心: -购物车,删 ...
- Android 开发笔记___实战项目:购物车
购物车的应用很广泛,电商app基本上都有它的身影.由于它用到了多种存储方式,通过项目对数据的存储有更高层次的了解. 1.设计思路 首先看看购物车的外观.第一次进入时里面是空的,去购物页面加入购物车以后 ...
- django项目中购物车的实现
对于做项目而言,最重要的是分析清楚自己负责模块的思路,确定思路后,把每一步实现的步骤确定后,根据步骤,去实现代码,测试. 购物车的逻辑: 登录用户可以添加购物车,未登陆用户页可以添加到购物车 ...
- 阶段性项目 ATM+购物车项目
ATM + 购物车https://www.cnblogs.com/kermitjam/articles/10687180.html readme 内容前戏: 一个项目是如何从无到有的. 一 需求分析 ...
随机推荐
- 'WebElement' object is not iterable
checkbox.html源码: <html> <head> <meta http-equiv="content-type" content=&quo ...
- php的高性能日志系统 seaslog 的安装与使用
一.什么是日志系统 一般用于记录系统运行时的信息,一般分为三类:系统日志,应用程序日志,安全日志.日志功能不能影响用户的正常使用. 二.为什么需要日志功能 1.了解系统运行情况 2. ...
- OpenSSL 结构体
X509_STORE 头文件:x509_vfy.h 定义 typedef struct x509_store_st X509_STORE; struct x509_store_st { /* The ...
- Ubuntu部分命令的使用简介
1.查看USB设备 lsusb #查看系统中的usb设备 lsusb –v #查看详细的usb设备信息 2.ubuntu mount u盘 第一步:查看U盘信息 sudo fdisk -l 得到类似 ...
- 解决 cmake_symlink_library: System Error: Operation not supported
在编译uchardet时遇到这个错误: cmake_symlink_library: System Error: Operation not supported 创建链接不成功,要确认当前帐户下是否有 ...
- JVM 系列 ClassLoader
JVM 系列()ClassLoader 在前面一节中,主要介绍了 Class 的装载过程,Class 的装载大体上可以分为加载类.连接类和初始化 3 个阶段.本小节将主要介绍绍 Java 语言中的 C ...
- cocos2d接安卓facebook插件(已测cocos-x 3.7 3.8版本)
1 控制台创建新工程: a 控制台 进入cocos2d文件夹下面,如cocos2d-x-3.7.1,执行setup.py,未设置NDK SDK ANT 路径的设置路径,需要改路径的 explore ...
- 2018.09.14 洛谷P3567 [POI2014]KUR-Couriers(主席树)
传送门 简单主席树啊. 但听说有随机算法可以秒掉%%%(本蒟蒻并不会) 直接维护值域内所有数的出现次数之和. 当这个值不大于区间总长度的一半时显然不存在合法的数. 这样在主席树上二分查值就行了. 代码 ...
- 2018.07.10 NOIP模拟 sort(单调队列)
Sort 题目背景 SOURCE:NOIP2016-RZZ-4 T1 题目描述 给你一个长度为 n 的排列,小W每次可以选择一个数,做以下操作: 不断把这个数与它右边的数交换. 当它右边没有数,或它右 ...
- flask_login
一.配置 对于登录系统,我们将会使用到两个扩展,Flask-Login 和 Flask-OpenID.在microblog.py中配置: Flask-OpenID 扩展需要一个存储文件的临时文件夹的路 ...