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 内容前戏: 一个项目是如何从无到有的. 一 需求分析 ...
随机推荐
- Centos7下安装apache2.4 php5.6 pdo_oci oci8
一.下载必须的安装源码包 http://httpd.apache.org/download.cgi#apache24 httpd-2.4.23.tar.gz http://apr.apache.org ...
- linux配置网络
1.配置网络信息 linux系统的第一块网卡信息 /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE 设备名 ONBOOT 系统启动后是否自动启动网卡设备 ...
- python使用ip代理抓取网页
在抓取一个网站的信息时,如果我们进行频繁的访问,就很有可能被网站检测到而被屏蔽,解决这个问题的方法就是使用ip代理 .在我们接入因特网进行上网时,我们的电脑都会被分配一个全球唯一地ip地址供我们使用, ...
- OpenGLES.gpus_ReturnNotPermittedKillClient
在iOS中,使用OpenGLES不当引起的crash:“gpus_ReturnNotPermittedKillClient” https://developer.apple.com/library/i ...
- POJ 1122.FDNY to the Rescue! Dijkstra
FDNY to the Rescue! Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 2808 Accepted: 86 ...
- HDOJ1242 Rescue(营救) 搜索
Rescue Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- 淘宝、天猫又开源了一个动态化、高性能的UI框架
前言 淘宝.天猫一直致力于解决 页面动态化的问题 在2017年的4月发布了v1.0解决方案:Tangram模型 及其对应的 Android库 vlayout,该解决方案在手机淘宝.天猫 Android ...
- Laravel - Opening Multiple Projects
On this page: Basics Opening multiple projects Deleting a project from view Important notes Basics P ...
- [BAT] 执行xcopy命令后出现Invalid num of parameters错误的解决办法
如果是Windows下的命令行,对于有空格的文件路径要加引号,对于xcopy命令就是源路径和目标路径都要加引号 xcopy "C:\ppt" "D:\Program do ...
- jps 命令详解
jps 命令详解 jps 是 jdk 提供的一个查看当前 java 进程的小工具, 可以看做是 JavaVirtual Machine Process Status Tool 的缩写.非常简单实用. ...