$Django 路飞之显示视频,Redis存购物车数据,优惠卷生成表,优惠卷的一个领取表。(知识小回顾)
知识小回顾之json序列化问题
精髓:支持python的几种数据类型(注意不是对象,不能放对象),其次是tuple变list。
ensure_ascii:默认值True,如果dict内含有non-ASCII的字符,则会类似\uXXXX的显示数据,设置成False后,就能正常显示
一 显示视频
1.用到了cc视频的服务。
2.购买服务,上传视频,上传完成有个视频id。
3.审核通过可以拿到视频的js,html等代码,复制到模板上就可以用了。
最后:视频的一个播放规则,请阅读api。例如输入密码才能观看,付费(试看几分钟)等。
二 Redis存购物车数据
知识回顾:用redis:先安装redis,django项目再安装django_redis、settings配置、导入模块。
1.我们用的str类型存的 key:'shoppingcar_%s'%user.id value:序列化的字典
{
"": {
"title": "django",
"img": "test/django.jpg",
"default_cenue": 1,
"cenue_all": {
"": {
"date": "1\u4e2a\u6708",
"price": "10.00"
},
"": {
"date": "6\u4e2a\u6708",
"price": "60.00"
}
}
},
"": {
"title": "go",
"img": "test/go.jpg",
"default_cenue": 3,
"cenue_all": {
"": {
"date": "3\u4e2a\u6708",
"price": "10.00"
}
}
}
}
value为购物车内商品信息
2.view
from rest_framework.views import APIView
from rest_framework.response import Response
from api import models from api.utils.commonUtils import MyResponse
from rest_framework.viewsets import ViewSetMixin
from django.core.exceptions import ObjectDoesNotExist
from django.conf import settings
from api.utils.MyAuth import LoginAuth
from api.utils.commonUtils import CommonException
from django_redis import get_redis_connection
import json # 需要登录之后才能操作,写一个认证组件
class ShoppingCart(APIView):
authentication_classes = [LoginAuth]
conn = get_redis_connection() def post(self, request, *args, **kwargs):
response = MyResponse()
# 课程id,价格策略id
# {"course_id": "1", "policy_id": "1"}
# 放到redis中key值 shoppingcart_userid_courseid
# 0 取出课程id,价格策略id
course_id = str(request.data.get('course_id'))
policy_id = str(request.data.get('policy_id'))
# 1 校验课程是否合法
try:
course = models.Course.objects.get(pk=course_id)
# 2 获取所有价格策略(通过课程拿出所有价格策略)
policy_price_all = course.price_policy.all()
# 3 从redis中取出当前登录用户的购物车
shopping_byte = self.conn.get('shoppingcart_%s' % request.user.pk)
if shopping_byte:
shopping_cart = json.loads(shopping_byte)
else:
shopping_cart = {}
# 循环构造出价格策略大字典
policy = {}
for policy_price in policy_price_all:
'''
{
"period":3,
"period_display":"3天",
"price":200
},
'''
policy_one = {
'period': policy_price.pk,
'period_display': policy_price.get_valid_period_display(),
'price': policy_price.price
}
policy[str(policy_price.pk)] = policy_one
# 判断价格策略是否合法,不再字典中,就不合法
if policy_id not in policy:
# 不合法
raise CommonException(102, '价格策略不合法,你不是人')
# 判断传入的课程id是否在购物车中
if course_id in shopping_cart:
# 更新一下默认价格策略
shopping_cart[course_id]['default_policy'] = policy_id
response.msg = '更新成功'
else:
shopping_course = {
'title': course.name,
'img': course.course_img,
'default_policy': policy_id,
'policy': policy
} # 添加到购物车
shopping_cart[course_id] = shopping_course
response.msg = '添加成功'
# 写入redis
self.conn.set('shoppingcart_%s' % request.user.pk, json.dumps(shopping_cart)) except ObjectDoesNotExist as e:
response.status = 101
response.msg = '该课程不存在,你可能是爬虫'
except CommonException as e:
response.status = e.status
response.msg = e.msg
except Exception as e:
response.status = 400
response.msg = '未知错误'
print(str(e))
return Response(response.get_dic) def put(self,request,*args,**kwargs):
response=MyResponse()
# 0 取出课程id,价格策略id
course_id = str(request.data.get('course_id'))
policy_id = str(request.data.get('policy_id'))
try:
shopping_byte = self.conn.get('shoppingcart_%s' % request.user.pk)
if shopping_byte:
shopping_cart = json.loads(shopping_byte)
else:
shopping_cart = {}
if course_id not in shopping_cart:
raise CommonException(102,'要修改的课程不存在')
course_detail=shopping_cart.get(course_id)
if policy_id not in course_detail['policy']:
raise CommonException(103, '价格策略不合法')
course_detail['default_policy']=policy_id
response.msg='修改成功'
self.conn.set('shoppingcart_%s' % request.user.pk, json.dumps(shopping_cart)) except ObjectDoesNotExist as e:
response.status = 101
response.msg = '该课程不存在,你可能是爬虫'
except CommonException as e:
response.status = e.status
response.msg = e.msg
except Exception as e:
response.status = 400
response.msg = '未知错误'
print(str(e))
return Response(response.get_dic) def get(self,request,*args,**kwargs):
response=MyResponse()
try:
shopping_byte = self.conn.get('shoppingcart_%s' % request.user.pk)
if shopping_byte:
shopping_cart = json.loads(shopping_byte)
else:
shopping_cart = {}
response.data=shopping_cart except Exception as e:
response.status = 400
response.msg = '未知错误'
print(str(e))
return Response(response.get_dic) def delete(self, request, *args, **kwargs):
response=MyResponse()
course_id=request.data.get('course_id')
try:
shopping_byte = self.conn.get('shoppingcart_%s' % request.user.pk)
if shopping_byte:
shopping_cart = json.loads(shopping_byte)
else:
shopping_cart = {}
shopping_cart.pop(course_id,None)
self.conn.set('shoppingcart_%s' % request.user.pk, json.dumps(shopping_cart))
except Exception as e:
response.status = 400
response.msg = '未知错误'
print(str(e))
return Response(response.get_dic)
添加购物车需要course_id,价格策略id
总结:序列化问题:
1.django的序列化组件只能序列化对应的model。
2.像我们这种每个表都拿一点组成的字典只能用json来序列化。
3.其次序列化的是数据类型不是对象(filefelid格式的文件路径 要加str)等。
三 优惠券相关
1.优惠券种类表,用户持券表
#用户持券表(用户领取卷)
class GETCoupon(models.Model):
coupon=models.ForeignKey(to='SETCoupon',on_delete=models.CASCADE)
num=models.CharField(max_length=64,verbose_name='用来计数')
user=models.ForeignKey(to='User',verbose_name='拥有者',on_delete=models.CASCADE)
status_choices=((0,'未使用'),(1,'已使用'),(2,'已过期'))
status=models.IntegerField(choices=status_choices,verbose_name='优惠券状态',default=0)
get_time=models.DateTimeField(verbose_name='领券时间',auto_now_add=True)
use_time=models.DateTimeField(verbose_name='使用时间',blank=True,null=True) class Meta:
verbose_name_plural='用户持券表'
def __str__(self):
return '%s-%s-%s'%(self.user,self.coupon,self.get_status_display()) #优惠券类型表(管理元创建)
class SETCoupon(models.Model):
# 生成优惠券
name=models.CharField(max_length=32,verbose_name='名称')
brief=models.TextField(verbose_name='优惠券介绍')
coupon_type_choices=((0,'立减券'),(1,'打折券'),(2,'满减券'))
coupon=models.IntegerField(choices=coupon_type_choices,verbose_name='卷类型') #各种卷的价值
money_jian=models.IntegerField(verbose_name='直接减',blank=True,null=True)
money_zhe=models.PositiveIntegerField(verbose_name='折扣百分比',help_text='例 7.9折,写79',blank=True,null=True)
money_man=models.IntegerField(verbose_name='满减券',default=0,help_text='仅在满减券填写该字段') #各种券又分种类:网站所有商品通用的,某个商品的,减了又减
content_type=models.ForeignKey(ContentType,blank=True,null=True,on_delete=models.CASCADE)
object_id=models.IntegerField(verbose_name='商品id',blank=True,null=True,help_text='某个商品表下的某个商品id')
content_obj=GenericForeignKey() #生成优惠卷:数量,有效期等
coupon_num=models.IntegerField(verbose_name='张数',default=0)
start_get_time=models.DateTimeField('开始领卷的时间')
end_get_time=models.DateTimeField('领卷的结束时间')
start_valid_time=models.DateTimeField('开始有效时间')
end_valid_time=models.DateTimeField('有效结束时间') data=models.DateTimeField(auto_now_add=True)
class Meta:
verbose_name_plural='优惠券表'
def __str__(self):
return "%s(%s)"%(self.get_coupon_display(),self.name)
管理员创建优惠券,用户领取优惠券
随机推荐
- Educational Codeforces Round 62 (Rated for Div. 2) - C Playlist
当时题意看错了...不过大致思路是对的,唯一没有想到的就是用优先队列搞这个东西,真是不该啊... 题意大概就是,有N首歌,N首歌有两个东西,一个是长度Ti,一个是美丽值Bi,你最多可以选择K首歌, 这 ...
- PS外挂滤镜调出清晰对比照片
最终效果 一.打开原图. 二.我们使用类似第一部分的相同方法,但设置上略有不同,我们将光线放在不同的地方.复制底层,执行滤镜-LUCIS ART水彩滤镜-LUCISART 选择 雕刻 设置参数为25. ...
- [转帖]SAP S4 HANA 1610与ECC的比较
SAP S4 HANA 1610与ECC的比较 https://zhuanlan.zhihu.com/p/27266476 SAP S4 HANA是下一代的ERP套件,是SAP 战略的核心,相关资料也 ...
- Word写博常用博客URL地址
地址 描述 http://imguowei.blog.51cto.com/xmlrpc.php 51cto http://upload.move.blog.sina.com.cn/blog_rebui ...
- vivado place30-378
AR# 60131 Vivado Placer - [Place 30-378] Input pin of input buffer has an illegal connection to a lo ...
- 如何破解加密了的word文档
https://blog.csdn.net/huangbaokang/article/details/79630223 变成xml文件格式之后--查找在documentProtection前面加上un ...
- <数据结构基础学习>(四)链表 Part 2
一.使用链表实现栈 增,删,查只对链表头进行操作,时间复杂度都为O(1) 链表头作为栈顶 LinkedListStack<E> implements Stack<E> publ ...
- 关于JavaScript(脚本语言)
1.typeof运算符:判断一个对象是否是什么类型,返回“” 一.数字类型(Number) 1.javascript不擅长计算,不能用于浮点数的计算.如:var a = 0.2; var b = 0. ...
- pillow的用法
这是原图 from PIL import Image im=Image.open('C:/Users/history/Desktop/微信图片_20190408110611.jpg') r,g,b=i ...
- IrisSkin 单独控件样式设置 不使用皮肤样式
可以设置控件的Tag为this.skinEngine1.DisableTag [DefaultValue()] [Description("If you do not want skin t ...