久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > python >内容正文

python

python 全栈开发,Day104(DRF用户认证,结算中心,django-redis)

發(fā)布時(shí)間:2024/3/13 python 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 全栈开发,Day104(DRF用户认证,结算中心,django-redis) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

python 全棧開發(fā),Day104(DRF用戶認(rèn)證,結(jié)算中心,django-redis)

考試第二部分:MySQL數(shù)據(jù)庫(kù)

6.? MySQL中char和varchar的區(qū)別(1分)

char是定長(zhǎng),varchar是變長(zhǎng)。 char的查詢速度比varchar要快。 View Code

?

7.? ?MySQL中varchar(50)的50表示什什么意思?(1分)

是字符長(zhǎng)度。一個(gè)中文,也是一個(gè)字符。 View Code

?

8. left join、right join以及inner join的區(qū)別?(2分)

left join,表示左連接,以左表為基準(zhǔn),如果左表有不匹配的,顯示為空 right join,表示右連接,以右表為基準(zhǔn),如果右表有不匹配的,顯示為空 inner join,表示內(nèi)連接,只顯示2個(gè)表?xiàng)l件符合的記錄,不匹配的不顯示 View Code

?

9. MySQL組合索引(2分)
where?子句句中有a、b、c 三個(gè)查詢條件,創(chuàng)建?一個(gè)組合索引 abc(a,b,c),那么如下那中情況會(huì)命 中索引:
a. where (a)
b. where (b)
c. where (c)
d. where (a,b)
e. where (b,c)
f. where (a,c)
g. where (a,b,c)

a,d,f,g 會(huì)命中索引 View Code

解釋:

索引有2個(gè)功能:加快查詢和約束。

這里的約束指的是唯一索引,聯(lián)合唯一索引。

索引遵循的原則: 最左前綴原則

你可以認(rèn)為聯(lián)合索引是闖關(guān)游戲的設(shè)計(jì)例如你這個(gè)聯(lián)合索引是state/city/zipCode那么state就是第一關(guān) city是第二關(guān), zipCode就是第三關(guān)你必須匹配了第一關(guān),才能匹配第二關(guān),匹配了第一關(guān)和第二關(guān),才能匹配第三關(guān)你不能直接到第二關(guān)的索引的格式就是第一層是state,第二層才是city索引是因?yàn)锽+樹結(jié)構(gòu) 所以查找快 如果單看第三列 是非排序的。 多列索引是先按照第一列進(jìn)行排序,然后在第一列排好序的基礎(chǔ)上再對(duì)第二列排序,如果沒有第一列的話,直接訪問第二列,那第二列肯定是無(wú)序的,直接訪問后面的列就用不到索引了。 所以如果不是在前面列的基礎(chǔ)上而是但看后面某一列,索引是失效的。 View Code

簡(jiǎn)而言之,只要where條件包含最左邊的字段,那么它就會(huì)用到組合索引,反之亦然!

如果創(chuàng)建了組合索引,但是卻沒有命中,這是浪費(fèi)磁盤空間。因?yàn)樗饕舱加么疟P!

?

10. 假設(shè)學(xué)?生Student和教師Teacher關(guān)系模型如下:(4分) Student(學(xué)號(hào)、姓名、性別、類型、身份證號(hào)) Teacher(教師號(hào)、姓名、性別、類型、身份證號(hào)、工資)
其中,學(xué)?生表中類別為“本科生”和“研究生”兩類;性別為“男”和“女”兩類。
a. 性別為女的所有學(xué)生。

select * from Student where 性別='' View Code

b. 學(xué)生表中類別分別對(duì)應(yīng)的個(gè)數(shù)。

select 類型,count(1) from Student group by 類型 View Code

c.工資少于10000的女教師的身份證和姓名。

select 身份證,姓名 from Teacher where 性別= '' and 類型='研究生' and 工資 < 10000 View Code

d.? 研究生教師平均工資、最?高和最低工資。

select AVG(工資),MAX(工資),MIN(工資) from Teacher wherer 類型='研究生' View Code

?

11. 根據(jù)如下表結(jié)構(gòu)建表:(2分)

CREATE TABLE `t1` (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(32) NOT NULL,`balance` decimal(10,2) NOT NULL,PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; View Code

?

12.? ? 根據(jù)如下表查詢每個(gè)?用戶第?一次下訂單的時(shí)間。(2分)

# 第一次下單時(shí)間,就是時(shí)間最早的 select name,MIN(order_time) from table group by name View Code

?

13. 有?一個(gè)訂單系統(tǒng)包含訂單信息、商品信息、價(jià)格信息且還要?一些狀態(tài),如何設(shè)計(jì)表結(jié)構(gòu)(2分)

#最簡(jiǎn)單的設(shè)計(jì) 商品表 - id - 名稱 - 價(jià)格 - 描述信息訂單表 - id - 訂單號(hào)(唯一) - 商品id - 用戶id用戶表 - id - username - password View Code

?

14. 有如下表:(3分)
products(商品表) columns為 id、name、price
orders(商城訂單表) columns為 id、reservations_id、product_id、quantity(數(shù)量量)
reservations(酒店訂單表) columns為 id、user_id、price、created_at

ps:這個(gè)一個(gè)真實(shí)面試題!

應(yīng)用場(chǎng)景:比如萬(wàn)達(dá)酒店,需要訂購(gòu)商品,比如紅酒,紅木家具...

?

a. 各個(gè)商品的售賣情況,需要字段:商品名、購(gòu)買總數(shù)、商品收?入(單價(jià)*數(shù)量量)

SELECTproducts. NAME,sum(orders.quantity),products.price * sum(orders.quantity) FROMorders LEFT JOIN products ON products.id = orders.product_id GROUP BYorders.product_id View Code

?

b. 所有用戶在2018-01-01至2018-02-01下單次數(shù)、下單金額、商城下單次數(shù)、商城下單金額

# 注意:最后的期限要加1天。因?yàn)?3:59:59也是屬于當(dāng)天的 SELECTcount(1),sum(reservations.price),sum(orders.quantity),products.price * sum(orders.quantity) FROMreservations LEFT JOIN orders ON orders.reservations_id = reservations.id LEFT JOIN products ON products.id = orders.product_id WHEREreservations.created_at BETWEEN 2018-01-01 AND reservations.created_at '2018-02-02' View Code

?

c. 歷月下單用戶數(shù):下單1次的用戶數(shù)、下單2次的用戶數(shù)、下單3次及以上的用戶數(shù)

# 下單1次的用戶數(shù) select DATE_FORMAT(created_at,'%Y-%m'),user_id,count(1) from reservations group by DATE_FORMAT(created_at,'%Y-%m'),user_id having count(user_id) = 1;# 下單2次的用戶數(shù) select DATE_FORMAT(created_at,'%Y-%m'),user_id,count(1) from reservations group by DATE_FORMAT(created_at,'%Y-%m'),user_id having count(user_id) = 1;# 下單3次及以上的用戶數(shù) select DATE_FORMAT(created_at,'%Y-%m'),user_id,count(1) from reservations group by DATE_FORMAT(created_at,'%Y-%m'),user_id having count(user_id) >= 3; View Code

?

15.? 根據(jù)表寫SQL語(yǔ)句句:(5分)

? 查詢所有同學(xué)的學(xué)號(hào)、姓名、班級(jí)名稱。(1分)

select student.sid,student.sname,class.caption from student left jon class on class.cid = student.class_id View Code

?

? 查詢沒有學(xué)?生的所有班級(jí)。(2分)

select class.caption from student left jon class on class.cid = student.class_id where class.cid is null View Code

?

? 查詢有學(xué)?生的所有班級(jí)的名稱和學(xué)數(shù)量量。(2分)

select class.caption,count(1) from student left jon class on class.cid = student.class_id View Code

?

一、DRF用戶認(rèn)證

流程圖

請(qǐng)求到達(dá)視圖的時(shí)候,需要進(jìn)行認(rèn)證。

認(rèn)證是在中間件之后的。如果一旦認(rèn)證失敗,則返回信息給用戶

?

啟動(dòng)項(xiàng)目luffcity,訪問購(gòu)物車

注意:要啟動(dòng)redis,否則提示獲取購(gòu)物車數(shù)據(jù)失敗

?

添加認(rèn)證?

購(gòu)物車需要登錄才能查看,登錄成功后,返回一個(gè)token

修改views目錄下的auth.py

from rest_framework.response import Response from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from api import models from api.utils.response import BaseResponse import uuidclass AuthView(ViewSetMixin,APIView):def login(self,request,*args,**kwargs):"""用戶登陸認(rèn)證:param request::param args::param kwargs::return:"""response = BaseResponse() # 默認(rèn)狀態(tài)try:user = request.data.get('username')pwd = request.data.get('password')# 驗(yàn)證用戶和密碼obj = models.Account.objects.filter(username=user,password=pwd).first()if not obj:response.code = 10002response.error = '用戶名或密碼錯(cuò)誤'else:uid = str(uuid.uuid4()) # 生成唯一idresponse.code = 99999response.data = uidexcept Exception as e:response.code = 10005response.error = '操作異常'return Response(response.dict) View Code

請(qǐng)確保已經(jīng)生成了表api_account,并添加了一條記錄

如果沒有,請(qǐng)參考昨天的文檔!

?

測(cè)試用戶和密碼

查看返回結(jié)果

?

輸入正確的用戶名和密碼

查看返回結(jié)果,返回一個(gè)隨機(jī)碼。這個(gè)就是token

9999表示登錄成功

?

既然token已經(jīng)生成了,并返回給了客戶端。那么服務(wù)器如何驗(yàn)證客戶端的token是否合法呢?

答案是,服務(wù)器需要保存token。推薦加一個(gè)有效期,比如微信公眾號(hào)的token有效期為8個(gè)小時(shí)!

增加token表

修改models.py,增加token表

它和用戶表是一對(duì)一的關(guān)系!

from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation from django.contrib.contenttypes.models import ContentType from django.db.models import Q from django.utils.safestring import mark_safe from django.db import models import hashlib# ######################## 課程相關(guān) ########################class CourseCategory(models.Model):"""課程大類, e.g 前端 后端..."""name = models.CharField(max_length=64, unique=True)def __str__(self):return "%s" % self.nameclass Meta:verbose_name_plural = "01.課程大類"class CourseSubCategory(models.Model):"""課程子類, e.g python linux """category = models.ForeignKey("CourseCategory")name = models.CharField(max_length=64, unique=True)def __str__(self):return "%s" % self.nameclass Meta:verbose_name_plural = "02.課程子類"class DegreeCourse(models.Model):"""學(xué)位課程"""name = models.CharField(max_length=128, unique=True)course_img = models.CharField(max_length=255, verbose_name="縮略圖")brief = models.TextField(verbose_name="學(xué)位課程簡(jiǎn)介", )total_scholarship = models.PositiveIntegerField(verbose_name="總獎(jiǎng)學(xué)金(貝里)", default=40000) # 2000 2000mentor_compensation_bonus = models.PositiveIntegerField(verbose_name="本課程的導(dǎo)師輔導(dǎo)費(fèi)用(貝里)", default=15000)period = models.PositiveIntegerField(verbose_name="建議學(xué)習(xí)周期(days)", default=150) # 為了計(jì)算學(xué)位獎(jiǎng)學(xué)金prerequisite = models.TextField(verbose_name="課程先修要求", max_length=1024)teachers = models.ManyToManyField("Teacher", verbose_name="課程講師")# 用于GenericForeignKey反向查詢, 不會(huì)生成表字段,切勿刪除# coupon = GenericRelation("Coupon")# 用于GenericForeignKey反向查詢,不會(huì)生成表字段,切勿刪除degreecourse_price_policy = GenericRelation("PricePolicy")def __str__(self):return self.nameclass Meta:verbose_name_plural = "03.學(xué)位課"class Teacher(models.Model):"""講師、導(dǎo)師表"""name = models.CharField(max_length=32)role_choices = ((0, '講師'), (1, '導(dǎo)師'))role = models.SmallIntegerField(choices=role_choices, default=0)title = models.CharField(max_length=64, verbose_name="職位、職稱")signature = models.CharField(max_length=255, help_text="導(dǎo)師簽名", blank=True, null=True)image = models.CharField(max_length=128)brief = models.TextField(max_length=1024)def __str__(self):return self.nameclass Meta:verbose_name_plural = "04.導(dǎo)師或講師"class Scholarship(models.Model):"""學(xué)位課程獎(jiǎng)學(xué)金"""degree_course = models.ForeignKey("DegreeCourse")time_percent = models.PositiveSmallIntegerField(verbose_name="獎(jiǎng)勵(lì)檔位(時(shí)間百分比)", help_text="只填百分值,如80,代表80%")value = models.PositiveIntegerField(verbose_name="獎(jiǎng)學(xué)金數(shù)額")def __str__(self):return "%s:%s" % (self.degree_course, self.value)class Meta:verbose_name_plural = "05.學(xué)位課獎(jiǎng)學(xué)金"class Course(models.Model):"""專題課/學(xué)位課模塊表"""name = models.CharField(max_length=128, unique=True)course_img = models.CharField(max_length=255)sub_category = models.ForeignKey("CourseSubCategory")course_type_choices = ((0, '付費(fèi)'), (1, 'VIP專享'), (2, '學(xué)位課程'))course_type = models.SmallIntegerField(choices=course_type_choices)# 不為空;學(xué)位課的某個(gè)模塊# 為空;專題課degree_course = models.ForeignKey("DegreeCourse", blank=True, null=True, help_text="若是學(xué)位課程,此處關(guān)聯(lián)學(xué)位表")brief = models.TextField(verbose_name="課程概述", max_length=2048)level_choices = ((0, '初級(jí)'), (1, '中級(jí)'), (2, '高級(jí)'))level = models.SmallIntegerField(choices=level_choices, default=1)pub_date = models.DateField(verbose_name="發(fā)布日期", blank=True, null=True)period = models.PositiveIntegerField(verbose_name="建議學(xué)習(xí)周期(days)", default=7) # order = models.IntegerField("課程順序", help_text="從上一個(gè)課程數(shù)字往后排")attachment_path = models.CharField(max_length=128, verbose_name="課件路徑", blank=True, null=True)status_choices = ((0, '上線'), (1, '下線'), (2, '預(yù)上線'))status = models.SmallIntegerField(choices=status_choices, default=0)template_id = models.SmallIntegerField("前端模板id", default=1)coupon = GenericRelation("Coupon")# 用于GenericForeignKey反向查詢,不會(huì)生成表字段,切勿刪除price_policy = GenericRelation("PricePolicy")asked_question = GenericRelation("OftenAskedQuestion")def __str__(self):return "%s(%s)" % (self.name, self.get_course_type_display())def save(self, *args, **kwargs):if self.course_type == 2:if not self.degree_course:raise ValueError("學(xué)位課程必須關(guān)聯(lián)對(duì)應(yīng)的學(xué)位表")super(Course, self).save(*args, **kwargs)class Meta:verbose_name_plural = "06.專題課或?qū)W位課模塊"class CourseDetail(models.Model):"""課程詳情頁(yè)內(nèi)容"""course = models.OneToOneField("Course")hours = models.IntegerField("課時(shí)")course_slogan = models.CharField(max_length=125, blank=True, null=True)video_brief_link = models.CharField(verbose_name='課程介紹', max_length=255, blank=True, null=True)why_study = models.TextField(verbose_name="為什么學(xué)習(xí)這門課程")what_to_study_brief = models.TextField(verbose_name="我將學(xué)到哪些內(nèi)容")career_improvement = models.TextField(verbose_name="此項(xiàng)目如何有助于我的職業(yè)生涯")prerequisite = models.TextField(verbose_name="課程先修要求", max_length=1024)recommend_courses = models.ManyToManyField("Course", related_name="recommend_by", blank=True)teachers = models.ManyToManyField("Teacher", verbose_name="課程講師")def __str__(self):return "%s" % self.courseclass Meta:verbose_name_plural = "07.課程或?qū)W位模塊詳細(xì)"class OftenAskedQuestion(models.Model):"""常見問題"""content_type = models.ForeignKey(ContentType) # 關(guān)聯(lián)course or degree_courseobject_id = models.PositiveIntegerField()content_object = GenericForeignKey('content_type', 'object_id')question = models.CharField(max_length=255)answer = models.TextField(max_length=1024)def __str__(self):return "%s-%s" % (self.content_object, self.question)class Meta:unique_together = ('content_type', 'object_id', 'question')verbose_name_plural = "08. 常見問題"class CourseOutline(models.Model):"""課程大綱"""course_detail = models.ForeignKey("CourseDetail")title = models.CharField(max_length=128)# 前端顯示順序order = models.PositiveSmallIntegerField(default=1)content = models.TextField("內(nèi)容", max_length=2048)def __str__(self):return "%s" % self.titleclass Meta:unique_together = ('course_detail', 'title')verbose_name_plural = "09. 課程大綱"class CourseChapter(models.Model):"""課程章節(jié)"""course = models.ForeignKey("Course")chapter = models.SmallIntegerField(verbose_name="第幾章", default=1)name = models.CharField(max_length=128)summary = models.TextField(verbose_name="章節(jié)介紹", blank=True, null=True)pub_date = models.DateField(verbose_name="發(fā)布日期", auto_now_add=True)class Meta:unique_together = ("course", 'chapter')verbose_name_plural = "10. 課程章節(jié)"def __str__(self):return "%s:(第%s章)%s" % (self.course, self.chapter, self.name)class CourseSection(models.Model):"""課時(shí)目錄"""chapter = models.ForeignKey("CourseChapter")name = models.CharField(max_length=128)order = models.PositiveSmallIntegerField(verbose_name="課時(shí)排序", help_text="建議每個(gè)課時(shí)之間空1至2個(gè)值,以備后續(xù)插入課時(shí)")section_type_choices = ((0, '文檔'), (1, '練習(xí)'), (2, '視頻'))section_type = models.SmallIntegerField(default=2, choices=section_type_choices)section_link = models.CharField(max_length=255, blank=True, null=True, help_text="若是video,填vid,若是文檔,填link")video_time = models.CharField(verbose_name="視頻時(shí)長(zhǎng)", blank=True, null=True, max_length=32) # 僅在前端展示使用pub_date = models.DateTimeField(verbose_name="發(fā)布時(shí)間", auto_now_add=True)free_trail = models.BooleanField("是否可試看", default=False)class Meta:unique_together = ('chapter', 'section_link')verbose_name_plural = "11. 課時(shí)"def __str__(self):return "%s-%s" % (self.chapter, self.name)class Homework(models.Model):chapter = models.ForeignKey("CourseChapter")title = models.CharField(max_length=128, verbose_name="作業(yè)題目")order = models.PositiveSmallIntegerField("作業(yè)順序", help_text="同一課程的每個(gè)作業(yè)之前的order值間隔1-2個(gè)數(shù)")homework_type_choices = ((0, '作業(yè)'), (1, '模塊通關(guān)考核'))homework_type = models.SmallIntegerField(choices=homework_type_choices, default=0)requirement = models.TextField(max_length=1024, verbose_name="作業(yè)需求")threshold = models.TextField(max_length=1024, verbose_name="踩分點(diǎn)")recommend_period = models.PositiveSmallIntegerField("推薦完成周期(天)", default=7)scholarship_value = models.PositiveSmallIntegerField("為該作業(yè)分配的獎(jiǎng)學(xué)金(貝里)")note = models.TextField(blank=True, null=True)enabled = models.BooleanField(default=True, help_text="本作業(yè)如果后期不需要了,不想讓學(xué)員看到,可以設(shè)置為False")class Meta:unique_together = ("chapter", "title")verbose_name_plural = "12. 章節(jié)作業(yè)"def __str__(self):return "%s - %s" % (self.chapter, self.title)# class CourseReview(models.Model): # """課程評(píng)價(jià)""" # enrolled_course = models.OneToOneField("EnrolledCourse") # about_teacher = models.FloatField(default=0, verbose_name="講師講解是否清晰") # about_video = models.FloatField(default=0, verbose_name="內(nèi)容實(shí)用") # about_course = models.FloatField(default=0, verbose_name="課程內(nèi)容通俗易懂") # review = models.TextField(max_length=1024, verbose_name="評(píng)價(jià)") # disagree_number = models.IntegerField(default=0, verbose_name="踩") # agree_number = models.IntegerField(default=0, verbose_name="贊同數(shù)") # tags = models.ManyToManyField("Tags", blank=True, verbose_name="標(biāo)簽") # date = models.DateTimeField(auto_now_add=True, verbose_name="評(píng)價(jià)日期") # is_recommend = models.BooleanField("熱評(píng)推薦", default=False) # hide = models.BooleanField("不在前端頁(yè)面顯示此條評(píng)價(jià)", default=False) # # def __str__(self): # return "%s-%s" % (self.enrolled_course.course, self.review) # # class Meta: # verbose_name_plural = "13. 課程評(píng)價(jià)(購(gòu)買課程后才能評(píng)價(jià))" # # # class DegreeCourseReview(models.Model): # """學(xué)位課程評(píng)價(jià) # 為了以后可以定制單獨(dú)的評(píng)價(jià)內(nèi)容,所以不與普通課程的評(píng)價(jià)混在一起,單獨(dú)建表 # """ # enrolled_course = models.ForeignKey("EnrolledDegreeCourse") # course = models.ForeignKey("Course", verbose_name="評(píng)價(jià)學(xué)位模塊", blank=True, null=True, # help_text="不填寫即代表評(píng)價(jià)整個(gè)學(xué)位課程", limit_choices_to={'course_type': 2}) # about_teacher = models.FloatField(default=0, verbose_name="講師講解是否清晰") # about_video = models.FloatField(default=0, verbose_name="視頻質(zhì)量") # about_course = models.FloatField(default=0, verbose_name="課程") # review = models.TextField(max_length=1024, verbose_name="評(píng)價(jià)") # disagree_number = models.IntegerField(default=0, verbose_name="踩") # agree_number = models.IntegerField(default=0, verbose_name="贊同數(shù)") # tags = models.ManyToManyField("Tags", blank=True, verbose_name="標(biāo)簽") # date = models.DateTimeField(auto_now_add=True, verbose_name="評(píng)價(jià)日期") # is_recommend = models.BooleanField("熱評(píng)推薦", default=False) # hide = models.BooleanField("不在前端頁(yè)面顯示此條評(píng)價(jià)", default=False) # # def __str__(self): # return "%s-%s" % (self.enrolled_course, self.review) # # class Meta: # verbose_name_plural = "14. 學(xué)位課評(píng)價(jià)(購(gòu)買課程后才能評(píng)價(jià))"class PricePolicy(models.Model):"""價(jià)格與有課程效期表"""content_type = models.ForeignKey(ContentType) # 關(guān)聯(lián)course or degree_courseobject_id = models.PositiveIntegerField()content_object = GenericForeignKey('content_type', 'object_id')# course = models.ForeignKey("Course")valid_period_choices = ((1, '1天'), (3, '3天'),(7, '1周'), (14, '2周'),(30, '1個(gè)月'),(60, '2個(gè)月'),(90, '3個(gè)月'),(180, '6個(gè)月'), (210, '12個(gè)月'),(540, '18個(gè)月'), (720, '24個(gè)月'),)valid_period = models.SmallIntegerField(choices=valid_period_choices)price = models.FloatField()class Meta:unique_together = ("content_type", 'object_id', "valid_period")verbose_name_plural = "15. 價(jià)格策略"def __str__(self):return "%s(%s)%s" % (self.content_object, self.get_valid_period_display(), self.price)# ################################### 優(yōu)惠券相關(guān) #################################class Coupon(models.Model):"""優(yōu)惠券生成規(guī)則"""name = models.CharField(max_length=64, verbose_name="活動(dòng)名稱")brief = models.TextField(blank=True, null=True, verbose_name="優(yōu)惠券介紹")coupon_type_choices = ((0, '立減'), (1, '滿減券'), (2, '折扣券'))coupon_type = models.SmallIntegerField(choices=coupon_type_choices, default=0, verbose_name="券類型")money_equivalent_value = models.IntegerField(verbose_name="等值貨幣")off_percent = models.PositiveSmallIntegerField("折扣百分比", help_text="只針對(duì)折扣券,例7.9折,寫79", blank=True, null=True)minimum_consume = models.PositiveIntegerField("最低消費(fèi)", default=0, help_text="僅在滿減券時(shí)填寫此字段")content_type = models.ForeignKey(ContentType, blank=True, null=True)object_id = models.PositiveIntegerField("綁定課程", blank=True, null=True, help_text="可以把優(yōu)惠券跟課程綁定")content_object = GenericForeignKey('content_type', 'object_id')quantity = models.PositiveIntegerField("數(shù)量(張)", default=1)open_date = models.DateField("優(yōu)惠券領(lǐng)取開始時(shí)間")close_date = models.DateField("優(yōu)惠券領(lǐng)取結(jié)束時(shí)間")valid_begin_date = models.DateField(verbose_name="有效期開始時(shí)間", blank=True, null=True)valid_end_date = models.DateField(verbose_name="有效結(jié)束時(shí)間", blank=True, null=True)# coupon_valid_days = models.PositiveIntegerField(verbose_name="優(yōu)惠券有效期(天)", blank=True, null=True,# help_text="自券被領(lǐng)時(shí)開始算起")date = models.DateTimeField(auto_now_add=True)class Meta:verbose_name_plural = "31. 優(yōu)惠券生成記錄"def __str__(self):return "%s(%s)" % (self.get_coupon_type_display(), self.name)class CouponRecord(models.Model):"""優(yōu)惠券發(fā)放、消費(fèi)紀(jì)錄"""coupon = models.ForeignKey("Coupon")account = models.ForeignKey("Account", verbose_name="擁有者")number = models.CharField(max_length=64, unique=True)status_choices = ((0, '未使用'), (1, '已使用'), (2, '已過期'))status = models.SmallIntegerField(choices=status_choices, default=0)get_time = models.DateTimeField(verbose_name="領(lǐng)取時(shí)間", help_text="用戶領(lǐng)取時(shí)間")used_time = models.DateTimeField(blank=True, null=True, verbose_name="使用時(shí)間")# order = models.ForeignKey("Order", blank=True, null=True, verbose_name="關(guān)聯(lián)訂單") # 一個(gè)訂單可以有多個(gè)優(yōu)惠券order_id = models.IntegerField(verbose_name='關(guān)聯(lián)訂單ID')class Meta:verbose_name_plural = "32. 用戶優(yōu)惠券"def __str__(self):return '%s-%s-%s' % (self.account, self.number, self.status)class Account(models.Model):username = models.CharField("用戶名", max_length=64, unique=True)email = models.EmailField(verbose_name='郵箱',max_length=255,unique=True,blank=True,null=True)password = models.CharField('密碼', max_length=128)class Meta:verbose_name_plural = "33. 用戶表"class UserToken(models.Model):user = models.OneToOneField(to='Account')token = models.CharField(max_length=36)class Meta:verbose_name_plural = "34. token表" View Code

使用2個(gè)命令,生成表

python manage.py makemigrations python manage.py migrate

?

修改views目錄下的auth.py,保存token到數(shù)據(jù)庫(kù)中

from rest_framework.response import Response from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from api import models from api.utils.response import BaseResponse import uuidclass AuthView(ViewSetMixin,APIView):def login(self,request,*args,**kwargs):"""用戶登陸認(rèn)證:param request::param args::param kwargs::return:"""response = BaseResponse() # 默認(rèn)狀態(tài)try:user = request.data.get('username')pwd = request.data.get('password')# 驗(yàn)證用戶和密碼obj = models.Account.objects.filter(username=user,password=pwd).first()if not obj:response.code = 10002response.error = '用戶名或密碼錯(cuò)誤'else:uid = str(uuid.uuid4()) # 生成唯一id# 保存到數(shù)據(jù)庫(kù)中,update_or_create表示更新或者創(chuàng)建# user=obj,這個(gè)是判斷條件。當(dāng)條件成立,更新token字段,值為uid# 當(dāng)條件不成立時(shí),增加一條記錄。注意:增加時(shí),有2個(gè)字段,分別是user和tokenmodels.UserToken.objects.update_or_create(user=obj, defaults={'token': uid})response.code = 99999response.data = uidexcept Exception as e:response.code = 10005response.error = '操作異常'return Response(response.dict) View Code

再次發(fā)送POST請(qǐng)求,輸入正確的用戶名和密碼

查看表api_usertoken,發(fā)現(xiàn)和返回結(jié)果是一樣的!

再發(fā)送一次

表的數(shù)據(jù)隨之更新

?

增加認(rèn)證

不光購(gòu)物車會(huì)用到用戶認(rèn)證,結(jié)算中心也需要用到認(rèn)證,還有其他的視圖,也同樣需要登錄才能使用。

所以,這個(gè)認(rèn)證類需要放到utils里面

在utils目錄中新建文件auth.py

from rest_framework.authentication import BaseAuthentication from rest_framework.exceptions import AuthenticationFailedfrom api import modelsclass LuffyAuthentication(BaseAuthentication):def authenticate(self, request):"""用戶認(rèn)證:param request::return:"""# 獲取get參數(shù)中的tokentoken = request.query_params.get('token')# 判斷token是否在數(shù)據(jù)庫(kù)中token_obj = models.UserToken.objects.filter(token=token).first()if not token_obj:# 認(rèn)證失敗raise AuthenticationFailed({'code':1008,'error':'認(rèn)證失敗'})# 認(rèn)證成功# return 必須返回2個(gè)參數(shù),請(qǐng)參考源碼解析# 這里的token_obj.user,表示UserToken表中的user字段# token_obj就是UserToken表的一條記錄,也就是一個(gè)objectreturn (token_obj.user,token_obj) View Code

修改views目錄下的shoppingcart.py,導(dǎo)入utils下的auth模塊

from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from rest_framework.response import Response from api import models from api.utils.response import BaseResponse import json import redis from django.conf import settings from api.utils.auth import LuffyAuthentication# redis連接 CONN = redis.Redis(host=settings.REDIS_SERVER.get('host'),port=settings.REDIS_SERVER.get('port'))# print(settings.REDIS_SERVER.get('host')) SHOPPING_CAR = {}USER_ID = 1 # 用戶id# SHOPPING_CAR = { # 1:{ # 2:{ # 'title':'xxxx', # 'price':1, # 'price_list':[ # {'id':11,}, # {'id':22}, # {'id':33}, # ] # }, # 3:{}, # 5:{} # }, # 2:{}, # 3:{}, # }class ShoppingCartView(ViewSetMixin,APIView):# 開啟認(rèn)證,指定認(rèn)證類authentication_classes = [LuffyAuthentication,]def list(self, request, *args, **kwargs):"""查看購(gòu)物車信息:param request::param args::param kwargs::return:"""ret = {'code':10000,'data':None,'error':None}try:# request.user和request.auth是源碼返回的# 如果自定義認(rèn)證類返回了一個(gè)元組,元組里面有2個(gè)值。# 它會(huì)覆蓋上面2個(gè)值,request.user和request.authprint(request.user) # 認(rèn)證類返回的第一個(gè)值print(request.auth) # 認(rèn)證類返回的第二個(gè)值# 獲取tokenprint('shopping',request.query_params.get('token'))shopping_car_course_list = []# pattern = "shopping_car_%s_*" % (USER_ID,)pattern = "shopping_car_%s_%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.loads(CONN.hget(key, 'price_policy_dict').decode('utf-8'))}shopping_car_course_list.append(temp)ret['data'] = shopping_car_course_listexcept Exception as e:# print(e)ret['code'] = 10005ret['error'] = '獲取購(gòu)物車數(shù)據(jù)失敗'# print(ret)# print(json.dumps(ret))return Response(ret)def create(self, request, *args, **kwargs):"""加入購(gòu)物車:param request::param args::param kwargs::return:""""""1. 接受用戶選中的課程ID和價(jià)格策略ID2. 判斷合法性- 課程是否存在?- 價(jià)格策略是否合法?3. 把商品和價(jià)格策略信息放入購(gòu)物車 SHOPPING_CAR注意:用戶ID=1"""# 1.接受用戶選中的課程ID和價(jià)格策略ID"""相關(guān)問題:a. 如果讓你編寫一個(gè)API程序,你需要先做什么?- 業(yè)務(wù)需求- 統(tǒng)一數(shù)據(jù)傳輸格式- 表結(jié)構(gòu)設(shè)計(jì)- 程序開發(fā)b. django restful framework的解析器的parser_classes的作用?根據(jù)請(qǐng)求中Content-Type請(qǐng)求頭的值,選擇指定解析對(duì)請(qǐng)求體中的數(shù)據(jù)進(jìn)行解析。如:請(qǐng)求頭中含有Content-type: application/json 則內(nèi)部使用的是JSONParser,JSONParser可以自動(dòng)去請(qǐng)求體request.body中獲取請(qǐng)求數(shù)據(jù),然后進(jìn)行 字節(jié)轉(zhuǎn)字符串、json.loads反序列化;c. 支持多個(gè)解析器(一般只是使用JSONParser即可)"""course_id = request.data.get('courseid')policy_id = request.data.get('policyid')# 2. 判斷合法性# - 課程是否存在?# - 價(jià)格策略是否合法?# 2.1 課程是否存在?course = models.Course.objects.filter(id=course_id).first()if not course:return Response({'code': 10001, 'error': '課程不存在'})# 2.2 價(jià)格策略是否合法?price_policy_queryset = course.price_policy.all()price_policy_dict = {}for item in price_policy_queryset: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] = tempprint(price_policy_dict,type(price_policy_dict))print(policy_id,type(policy_id))if policy_id not in price_policy_dict:return Response({'code': 10002, 'error': '傻×,價(jià)格策略別瞎改'})# 3. 把商品和價(jià)格策略信息放入購(gòu)物車 SHOPPING_CAR"""購(gòu)物車中要放:課程ID課程名稱課程圖片默認(rèn)選中的價(jià)格策略所有價(jià)格策略{shopping_car_1_1:{id:課程IDname:課程名稱img:課程圖片defaut:默認(rèn)選中的價(jià)格策略price_list:所有價(jià)格策略},}"""pattern = "shopping_car_%s_%s" % (USER_ID, '*',)keys = CONN.keys(pattern)if keys and len(keys) >= 1000:return Response({'code': 10009, 'error': '購(gòu)物車東西太多,先去結(jié)算再進(jìn)行購(gòu)買..'})# key = "shopping_car_%s_%s" %(USER_ID,course_id,)key = "shopping_car_%s_%s" % (USER_ID, course_id,)print(key,'1111111111')CONN.hset(key, 'id', course_id)CONN.hset(key, 'name', course.name)CONN.hset(key, 'img', course.course_img)CONN.hset(key, 'default_price_id', policy_id)CONN.hset(key, 'price_policy_dict', json.dumps(price_policy_dict))CONN.expire(key, 60 * 60 * 24) # 有效期,單位秒。表示一天return Response({'code': 10000, 'data': '購(gòu)買成功'})def destroy(self,request,*args,**kwargs):"""刪除購(gòu)物車中的某個(gè)課程:param request::param args::param kwargs::return:"""response = BaseResponse()try:# courseid = request.GET.get('courseid')courseid = request.data.get('courseid')print(courseid)# key = "shopping_car_%s_%s" % (USER_ID,courseid)key = "shopping_car_%s_%s" % (USER_ID, courseid,)CONN.delete(key)response.data = '刪除成功'except Exception as e:response.code = 10006response.error = '刪除失敗'return Response(response.dict)def update(self,request,*args,**kwargs):"""修改用戶選中的價(jià)格策略:param request::param args::param kwargs::return:""""""1. 獲取課程ID、要修改的價(jià)格策略ID2. 校驗(yàn)合法性(去redis中)"""response = BaseResponse()try:course_id = request.data.get('courseid')policy_id = str(request.data.get('policyid')) if request.data.get('policyid') else None# key = 'shopping_car_%s_%s' %(USER_ID,course_id,)key = "shopping_car_%s_%s" % (USER_ID, course_id,)if not CONN.exists(key):response.code = 10007response.error = '課程不存在'return Response(response.dict)price_policy_dict = json.loads(CONN.hget(key, 'price_policy_dict').decode('utf-8'))if policy_id not in price_policy_dict:response.code = 10008response.error = '價(jià)格策略不存在'return Response(response.dict)CONN.hset(key,'default_price_id',policy_id)CONN.expire(key, 20 * 60) # 有效期20分鐘response.data = '修改成功'except Exception as e:response.code = 10009response.error = '修改失敗'return Response(response.dict) View Code

參數(shù)說明:

CONN.expire 表示設(shè)置有效期,單位是秒。60 * 60 * 24,表示一天

?

使用postman,發(fā)送get請(qǐng)求

提示認(rèn)證失敗

發(fā)送一個(gè)錯(cuò)誤的token

提示認(rèn)證失敗!注意:這里直接被認(rèn)證組件攔截了,并沒有到達(dá)視圖

發(fā)送一個(gè)正確的token,從數(shù)據(jù)庫(kù)里面copy一下

返回code為10000,表示認(rèn)證成功!

?查看Pycharm控制臺(tái)輸出:

Account object UserToken object shopping c8aa8609-fb14-43ea-a6cf-96b2c2469b01

上面2個(gè)值,就被自定義類覆蓋了!

?

既然得到了用戶對(duì)象,那么常量USER_ID就可以刪除了

修改shoppingcart.py

from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from rest_framework.response import Response from api import models from api.utils.response import BaseResponse import json import redis from django.conf import settings from api.utils.auth import LuffyAuthentication# redis連接 CONN = redis.Redis(host=settings.REDIS_SERVER.get('host'),port=settings.REDIS_SERVER.get('port'))class ShoppingCartView(ViewSetMixin,APIView):# 開啟認(rèn)證,指定認(rèn)證類authentication_classes = [LuffyAuthentication,]def list(self, request, *args, **kwargs):"""查看購(gòu)物車信息:param request::param args::param kwargs::return:"""ret = {'code':10000,'data':None,'error':None}try:# request.user和request.auth是源碼返回的# 如果自定義認(rèn)證類返回了一個(gè)元組,元組里面有2個(gè)值。# 它會(huì)覆蓋上面2個(gè)值,request.user和request.authprint(request.user) # 認(rèn)證類返回的第一個(gè)值print(request.auth) # 認(rèn)證類返回的第二個(gè)值# 獲取tokenprint('shopping',request.query_params.get('token'))shopping_car_course_list = []# pattern = "shopping_car_%s_*" % (request.user.id,)pattern = "shopping_car_%s_%s" % (request.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.loads(CONN.hget(key, 'price_policy_dict').decode('utf-8'))}shopping_car_course_list.append(temp)ret['data'] = shopping_car_course_listexcept Exception as e:# print(e)ret['code'] = 10005ret['error'] = '獲取購(gòu)物車數(shù)據(jù)失敗'# print(ret)# print(json.dumps(ret))return Response(ret)def create(self, request, *args, **kwargs):"""加入購(gòu)物車:param request::param args::param kwargs::return:""""""1. 接受用戶選中的課程ID和價(jià)格策略ID2. 判斷合法性- 課程是否存在?- 價(jià)格策略是否合法?3. 把商品和價(jià)格策略信息放入購(gòu)物車 SHOPPING_CAR注意:用戶ID=1"""# 1.接受用戶選中的課程ID和價(jià)格策略ID"""相關(guān)問題:a. 如果讓你編寫一個(gè)API程序,你需要先做什么?- 業(yè)務(wù)需求- 統(tǒng)一數(shù)據(jù)傳輸格式- 表結(jié)構(gòu)設(shè)計(jì)- 程序開發(fā)b. django restful framework的解析器的parser_classes的作用?根據(jù)請(qǐng)求中Content-Type請(qǐng)求頭的值,選擇指定解析對(duì)請(qǐng)求體中的數(shù)據(jù)進(jìn)行解析。如:請(qǐng)求頭中含有Content-type: application/json 則內(nèi)部使用的是JSONParser,JSONParser可以自動(dòng)去請(qǐng)求體request.body中獲取請(qǐng)求數(shù)據(jù),然后進(jìn)行 字節(jié)轉(zhuǎn)字符串、json.loads反序列化;c. 支持多個(gè)解析器(一般只是使用JSONParser即可)"""course_id = request.data.get('courseid')policy_id = request.data.get('policyid')# 2. 判斷合法性# - 課程是否存在?# - 價(jià)格策略是否合法?# 2.1 課程是否存在?course = models.Course.objects.filter(id=course_id).first()if not course:return Response({'code': 10001, 'error': '課程不存在'})# 2.2 價(jià)格策略是否合法?price_policy_queryset = course.price_policy.all()price_policy_dict = {}for item in price_policy_queryset: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] = tempprint(price_policy_dict,type(price_policy_dict))print(policy_id,type(policy_id))if policy_id not in price_policy_dict:return Response({'code': 10002, 'error': '傻×,價(jià)格策略別瞎改'})# 3. 把商品和價(jià)格策略信息放入購(gòu)物車 SHOPPING_CAR"""購(gòu)物車中要放:課程ID課程名稱課程圖片默認(rèn)選中的價(jià)格策略所有價(jià)格策略{shopping_car_1_1:{id:課程IDname:課程名稱img:課程圖片defaut:默認(rèn)選中的價(jià)格策略price_list:所有價(jià)格策略},}"""pattern = "shopping_car_%s_%s" % (request.user.id, '*',)keys = CONN.keys(pattern)if keys and len(keys) >= 1000:return Response({'code': 10009, 'error': '購(gòu)物車東西太多,先去結(jié)算再進(jìn)行購(gòu)買..'})# key = "shopping_car_%s_%s" %(request.user.id,course_id,)key = "shopping_car_%s_%s" % (request.user.id, course_id,)print(key,'1111111111')CONN.hset(key, 'id', course_id)CONN.hset(key, 'name', course.name)CONN.hset(key, 'img', course.course_img)CONN.hset(key, 'default_price_id', policy_id)CONN.hset(key, 'price_policy_dict', json.dumps(price_policy_dict))CONN.expire(key, 60 * 12 * 24) # 有效期return Response({'code': 10000, 'data': '購(gòu)買成功'})def destroy(self,request,*args,**kwargs):"""刪除購(gòu)物車中的某個(gè)課程:param request::param args::param kwargs::return:"""response = BaseResponse()try:# courseid = request.GET.get('courseid')courseid = request.data.get('courseid')print(courseid)# key = "shopping_car_%s_%s" % (request.user.id,courseid)key = "shopping_car_%s_%s" % (request.user.id, courseid,)CONN.delete(key)response.data = '刪除成功'except Exception as e:response.code = 10006response.error = '刪除失敗'return Response(response.dict)def update(self,request,*args,**kwargs):"""修改用戶選中的價(jià)格策略:param request::param args::param kwargs::return:""""""1. 獲取課程ID、要修改的價(jià)格策略ID2. 校驗(yàn)合法性(去redis中)"""response = BaseResponse()try:course_id = request.data.get('courseid')policy_id = str(request.data.get('policyid')) if request.data.get('policyid') else None# key = 'shopping_car_%s_%s' %(request.user.id,course_id,)key = "shopping_car_%s_%s" % (request.user.id, course_id,)if not CONN.exists(key):response.code = 10007response.error = '課程不存在'return Response(response.dict)price_policy_dict = json.loads(CONN.hget(key, 'price_policy_dict').decode('utf-8'))if policy_id not in price_policy_dict:response.code = 10008response.error = '價(jià)格策略不存在'return Response(response.dict)CONN.hset(key,'default_price_id',policy_id)CONN.expire(key, 20 * 60)response.data = '修改成功'except Exception as e:response.code = 10009response.error = '修改失敗'return Response(response.dict) View Code

測(cè)試get請(qǐng)求

?

全局配置

假設(shè)有100個(gè)類,有98個(gè)視圖要認(rèn)證。可以加到全局里面,修改settings.py

REST_FRAMEWORK = {'DEFAULT_VERSIONING_CLASS':'rest_framework.versioning.URLPathVersioning','VERSION_PARAM':'version','DEFAULT_VERSION':'v1','ALLOWED_VERSIONS':['v1','v2'],'PAGE_SIZE':20,'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination','DEFAULT_AUTHENTICATION_CLASSES':['api.utils.auth.LuffyAuthentication',] } View Code

?

那么登錄和查看課程,是不需要認(rèn)證的。怎么忽略呢?

修改views目錄下的auth.py,定義認(rèn)證類為空列表,表示不認(rèn)證!

from rest_framework.response import Response from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from api import models from api.utils.response import BaseResponse import uuidclass AuthView(ViewSetMixin,APIView):authentication_classes = [] # 空列表表示不認(rèn)證def login(self,request,*args,**kwargs):"""用戶登陸認(rèn)證:param request::param args::param kwargs::return:"""response = BaseResponse() # 默認(rèn)狀態(tài)try:user = request.data.get('username')pwd = request.data.get('password')# 驗(yàn)證用戶和密碼obj = models.Account.objects.filter(username=user,password=pwd).first()if not obj:response.code = 10002response.error = '用戶名或密碼錯(cuò)誤'else:uid = str(uuid.uuid4()) # 生成唯一id# 保存到數(shù)據(jù)庫(kù)中,update_or_create表示更新或者創(chuàng)建# user=obj,這個(gè)是判斷條件。當(dāng)條件成立,更新token字段,值為uid# 當(dāng)條件不成立時(shí),增加一條記錄。注意:增加時(shí),有2個(gè)字段,分別是user和tokenmodels.UserToken.objects.update_or_create(user=obj, defaults={'token': uid})response.code = 99999response.data = uidexcept Exception as e:response.code = 10005response.error = '操作異常'return Response(response.dict) View Code

使用postman測(cè)試登錄

查看返回結(jié)果

?

修改settings.py,注釋掉全局認(rèn)證。因?yàn)檫@里用到的登錄認(rèn)證的視圖不多

REST_FRAMEWORK = {'DEFAULT_VERSIONING_CLASS':'rest_framework.versioning.URLPathVersioning','VERSION_PARAM':'version','DEFAULT_VERSION':'v1','ALLOWED_VERSIONS':['v1','v2'],'PAGE_SIZE':20,'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',# 'DEFAULT_AUTHENTICATION_CLASSES':['api.utils.auth.LuffyAuthentication',] } View Code

?

問題:認(rèn)證類為什么要繼承BaseAuthentication?

查看源碼BaseAuthentication

class BaseAuthentication(object):"""All authentication classes should extend BaseAuthentication."""def authenticate(self, request):"""Authenticate the request and return a two-tuple of (user, token)."""raise NotImplementedError(".authenticate() must be overridden.")def authenticate_header(self, request):"""Return a string to be used as the value of the `WWW-Authenticate`header in a `401 Unauthenticated` response, or `None` if theauthentication scheme should return `403 Permission Denied` responses."""pass View Code

發(fā)現(xiàn),只要執(zhí)行了authenticate方法,它會(huì)執(zhí)行raise。它會(huì)主動(dòng)報(bào)錯(cuò)

為了不讓它報(bào)錯(cuò),子類繼承BaseAuthentication后,必須重寫authenticate方法,才不會(huì)報(bào)錯(cuò)。

這樣做的目的,是為了約束子類,哪些方法,必須要定義!

?

二、結(jié)算中心

?

點(diǎn)擊去結(jié)算,會(huì)發(fā)送一次post請(qǐng)求。那么它該發(fā)送什么數(shù)據(jù)呢?

只需要發(fā)送課程id就可以了?為什么呢?
因?yàn)閞edis中有購(gòu)物車相關(guān)數(shù)據(jù)!后臺(tái)根據(jù)課程id去購(gòu)物車中獲取,要結(jié)算的課程就可以了!

結(jié)算中心和購(gòu)物車一樣,也是一個(gè)臨時(shí)數(shù)據(jù)。它也需要放到redis中!

先來(lái)看購(gòu)物車的數(shù)據(jù)結(jié)構(gòu)

購(gòu)物車 = {'shopping_car_1_3':{name:'',src:'xx'price_id:1,price_dict = {1:....}},'shopping_car_1_1':{...},'shopping_car_1_5':{...},} View Code

再來(lái)看結(jié)算中新的數(shù)據(jù)結(jié)構(gòu)

結(jié)算中心 = {'payment_1_3':{id:3,mame:Django框架學(xué)習(xí),price_id:1,price_priod:30,price:199,defaul_coupon_id:0,coupon_dict: { ----> 綁定了課程3的優(yōu)惠券0: '請(qǐng)選擇課程優(yōu)惠券',1:'xxx',2:'xxx',3:'xxx',4:'xxx',}},'payment_1_1':{id:1,mame:Django框架學(xué)習(xí),price_id:1,price_priod:30,price:199,defaul_coupon_id:0,coupon_dict: { ----> 綁定了課程1的優(yōu)惠券0: '請(qǐng)選擇課程優(yōu)惠券',1:'xxx',2:'xxx',3:'xxx',4:'xxx',}}, } View Code

?

優(yōu)惠券

優(yōu)惠券分為2大類:綁定課程和非綁定課程

?

點(diǎn)擊去結(jié)算

在左下角,展示的是非綁定課程的優(yōu)惠券。

在右邊的下拉菜單中,展示的是綁定課程的優(yōu)惠券

?

在views目錄下,創(chuàng)建文件payment.py

import json import redis from django.conf import settings from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from rest_framework.response import Response from api.utils.auth import LuffyAuthentication from api import models from api.utils.response import BaseResponse# redis連接 CONN = redis.Redis(host=settings.REDIS_SERVER.get('host'),port=settings.REDIS_SERVER.get('port'))class PaymentView(ViewSetMixin, APIView):authentication_classes = [LuffyAuthentication, ]def create(self, request, *args, **kwargs):"""在結(jié)算中添加課程:param request::param args::param kwargs::return:"""# 1.接受用戶選擇的要結(jié)算的課程ID列表# 2.清空當(dāng)前用戶request.user.id結(jié)算中心的數(shù)據(jù)# key = payment_1*# 3.循環(huán)要加入結(jié)算中的所有課程ID列表"""for course_id in 用戶提交課程ID列表:3.1 根據(jù)course_id,request.user.id去購(gòu)物車中獲取商品信息:商品名稱、圖片、價(jià)格(id,周期,顯示周期,價(jià)格)3.2 根據(jù)course_id,request.user.id獲取 - 當(dāng)前用戶- 當(dāng)前課程- 可用的優(yōu)惠券加入結(jié)算中心提示:可以使用contenttypes"""# 4.獲取當(dāng)前用戶所有未綁定課程優(yōu)惠券# - 未使用# - 有效期內(nèi)# - 加入結(jié)算中心:glocal_coupon_用戶IDdef list(self, request, *args, **kwargs):"""查看結(jié)算中心:param request::param args::param kwargs::return:"""# 1. 根據(jù)用戶ID去結(jié)算中心獲取該用戶所有要結(jié)算課程# 2. 根據(jù)用戶ID去結(jié)算中心獲取該用戶所有可用未綁定課程的優(yōu)惠券# 3. 用戶表中獲取貝里余額# 4. 以上數(shù)據(jù)構(gòu)造成一個(gè)字典return Response('...')def update(self, request, *args, **kwargs):"""更新優(yōu)惠券:param request::param args::param kwargs::return:"""# 1. 獲取用戶提交:# course_id=1,coupon_id=3# course_id=0,coupon_id=6# 2. course_id=1 --> 去結(jié)算中心獲取當(dāng)前用戶所擁有的綁定當(dāng)前課程優(yōu)惠,并進(jìn)行校驗(yàn)# - 成功:defaul_coupon_id=3# - 否則:非法請(qǐng)求# 2. course_id=0 --> 去結(jié)算中心獲取當(dāng)前用戶所擁有的未綁定課程優(yōu)惠,并進(jìn)行校驗(yàn)# - 成功:defaul_coupon_id=3# - 否則:非法請(qǐng)求 View Code

course_id為空,表示 未綁定課程,否則為綁定課程

這里面展示的是一些業(yè)務(wù)邏輯,需要自己用代碼來(lái)填充

提示你的代碼編寫能力!

?

三、django-redis

介紹

django-redis 基于 BSD 許可, 是一個(gè)使 Django 支持 Redis cache/session 后端的全功能組件

django-redis 中文文檔,請(qǐng)參考

http://django-redis-chs.readthedocs.io/zh_CN/latest/

為何要用 django-redis ?

因?yàn)?

  • 持續(xù)更新
  • 本地化的 redis-py URL 符號(hào)連接字符串
  • 可擴(kuò)展客戶端
  • 可擴(kuò)展解析器
  • 可擴(kuò)展序列器
  • 默認(rèn)客戶端主/從支持
  • 完善的測(cè)試
  • 已在一些項(xiàng)目的生產(chǎn)環(huán)境中作為 cache 和 session 使用
  • 支持永不超時(shí)設(shè)置
  • 原生進(jìn)入 redis 客戶端/連接池支持
  • 高可配置 ( 例如仿真緩存的異常行為 )
  • 默認(rèn)支持 unix 套接字
  • 支持 Python 2.7, 3.4, 3.5 以及 3.6

?

安裝

安裝 django-redis 最簡(jiǎn)單的方法就是用 pip :

pip install django-redis

作為 cache backend 使用配置

為了使用 django-redis , 你應(yīng)該將你的 django cache setting 改成這樣:

CACHES = {"default": {"BACKEND": "django_redis.cache.RedisCache","LOCATION": "redis://127.0.0.1:6379/1","OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient",}} }

?

舉例:

在上面購(gòu)物車中,使用了緩存。結(jié)算中心也需要使用緩存,那么就可以定義一個(gè)全局配置。當(dāng)需要使用時(shí),導(dǎo)入一下配置即可!

修改settings.py,最后一行添加

# ######django-redis的配置 ################# CACHES = {"default": {"BACKEND": "django_redis.cache.RedisCache","LOCATION": "redis://192.168.218.140:6379","OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient","CONNECTION_POOL_KWARGS": {"max_connections": 100},# "PASSWORD": "密碼", }} }

參數(shù)解釋:

BACKEND 表示后臺(tái)連接

OPTIONS 表示參數(shù)

CONNECTION_POOL_KWARGS 表示連接池。max_connections表示最大連接數(shù)

?

連接池,請(qǐng)參考鏈接:

https://baike.baidu.com/item/%E8%BF%9E%E6%8E%A5%E6%B1%A0%E6%8A%80%E6%9C%AF/523659?fr=aladdin

上面定義了100個(gè)連接池,假設(shè)100進(jìn)程,都在使用連接池。當(dāng)?shù)?01個(gè)訪問時(shí),會(huì)等待。直到有空閑的進(jìn)程時(shí),才處理!

不過redis的處理是很快的,很少會(huì)出現(xiàn)等待的情況!

使用連接池,有很多優(yōu)點(diǎn):

1.減少連接創(chuàng)建時(shí)間
2.簡(jiǎn)化的編程模式
3.受控的資源使用

?

使用連接池,性能會(huì)更高好!

視圖中使用

加上2行代碼,就可以了

from django_redis import get_redis_connection CONN = get_redis_connection("default")

這里的default指的是settings.py中CACHES配置項(xiàng)的default

?

修改views目錄下的shoppingcar.py

from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from rest_framework.response import Response from api import models from api.utils.response import BaseResponse import json from api.utils.auth import LuffyAuthentication from django_redis import get_redis_connectionCONN = get_redis_connection("default") # 使用redis連接池class ShoppingCartView(ViewSetMixin,APIView):# 開啟認(rèn)證,指定認(rèn)證類authentication_classes = [LuffyAuthentication,]def list(self, request, *args, **kwargs):"""查看購(gòu)物車信息:param request::param args::param kwargs::return:"""ret = {'code':10000,'data':None,'error':None}try:# request.user和request.auth是源碼返回的# 如果自定義認(rèn)證類返回了一個(gè)元組,元組里面有2個(gè)值。# 它會(huì)覆蓋上面2個(gè)值,request.user和request.authprint(request.user) # 認(rèn)證類返回的第一個(gè)值print(request.auth) # 認(rèn)證類返回的第二個(gè)值# 獲取tokenprint('shopping',request.query_params.get('token'))shopping_car_course_list = []# pattern = "shopping_car_%s_*" % (request.user.id,)pattern = "shopping_car_%s_%s" % (request.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.loads(CONN.hget(key, 'price_policy_dict').decode('utf-8'))}shopping_car_course_list.append(temp)ret['data'] = shopping_car_course_listexcept Exception as e:# print(e)ret['code'] = 10005ret['error'] = '獲取購(gòu)物車數(shù)據(jù)失敗'# print(ret)# print(json.dumps(ret))return Response(ret)def create(self, request, *args, **kwargs):"""加入購(gòu)物車:param request::param args::param kwargs::return:""""""1. 接受用戶選中的課程ID和價(jià)格策略ID2. 判斷合法性- 課程是否存在?- 價(jià)格策略是否合法?3. 把商品和價(jià)格策略信息放入購(gòu)物車 SHOPPING_CAR注意:用戶ID=1"""# 1.接受用戶選中的課程ID和價(jià)格策略ID"""相關(guān)問題:a. 如果讓你編寫一個(gè)API程序,你需要先做什么?- 業(yè)務(wù)需求- 統(tǒng)一數(shù)據(jù)傳輸格式- 表結(jié)構(gòu)設(shè)計(jì)- 程序開發(fā)b. django restful framework的解析器的parser_classes的作用?根據(jù)請(qǐng)求中Content-Type請(qǐng)求頭的值,選擇指定解析對(duì)請(qǐng)求體中的數(shù)據(jù)進(jìn)行解析。如:請(qǐng)求頭中含有Content-type: application/json 則內(nèi)部使用的是JSONParser,JSONParser可以自動(dòng)去請(qǐng)求體request.body中獲取請(qǐng)求數(shù)據(jù),然后進(jìn)行 字節(jié)轉(zhuǎn)字符串、json.loads反序列化;c. 支持多個(gè)解析器(一般只是使用JSONParser即可)"""course_id = request.data.get('courseid')policy_id = request.data.get('policyid')# 2. 判斷合法性# - 課程是否存在?# - 價(jià)格策略是否合法?# 2.1 課程是否存在?course = models.Course.objects.filter(id=course_id).first()if not course:return Response({'code': 10001, 'error': '課程不存在'})# 2.2 價(jià)格策略是否合法?price_policy_queryset = course.price_policy.all()price_policy_dict = {}for item in price_policy_queryset: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] = tempprint(price_policy_dict,type(price_policy_dict))print(policy_id,type(policy_id))if policy_id not in price_policy_dict:return Response({'code': 10002, 'error': '傻×,價(jià)格策略別瞎改'})# 3. 把商品和價(jià)格策略信息放入購(gòu)物車 SHOPPING_CAR"""購(gòu)物車中要放:課程ID課程名稱課程圖片默認(rèn)選中的價(jià)格策略所有價(jià)格策略{shopping_car_1_1:{id:課程IDname:課程名稱img:課程圖片defaut:默認(rèn)選中的價(jià)格策略price_list:所有價(jià)格策略},}"""pattern = "shopping_car_%s_%s" % (request.user.id, '*',)keys = CONN.keys(pattern)if keys and len(keys) >= 1000:return Response({'code': 10009, 'error': '購(gòu)物車東西太多,先去結(jié)算再進(jìn)行購(gòu)買..'})# key = "shopping_car_%s_%s" %(request.user.id,course_id,)key = "shopping_car_%s_%s" % (request.user.id, course_id,)print(key,'1111111111')CONN.hset(key, 'id', course_id)CONN.hset(key, 'name', course.name)CONN.hset(key, 'img', course.course_img)CONN.hset(key, 'default_price_id', policy_id)CONN.hset(key, 'price_policy_dict', json.dumps(price_policy_dict))CONN.expire(key, 60 * 12 * 24) # 有效期return Response({'code': 10000, 'data': '購(gòu)買成功'})def destroy(self,request,*args,**kwargs):"""刪除購(gòu)物車中的某個(gè)課程:param request::param args::param kwargs::return:"""response = BaseResponse()try:# courseid = request.GET.get('courseid')courseid = request.data.get('courseid')print(courseid)# key = "shopping_car_%s_%s" % (request.user.id,courseid)key = "shopping_car_%s_%s" % (request.user.id, courseid,)CONN.delete(key)response.data = '刪除成功'except Exception as e:response.code = 10006response.error = '刪除失敗'return Response(response.dict)def update(self,request,*args,**kwargs):"""修改用戶選中的價(jià)格策略:param request::param args::param kwargs::return:""""""1. 獲取課程ID、要修改的價(jià)格策略ID2. 校驗(yàn)合法性(去redis中)"""response = BaseResponse()try:course_id = request.data.get('courseid')policy_id = str(request.data.get('policyid')) if request.data.get('policyid') else None# key = 'shopping_car_%s_%s' %(request.user.id,course_id,)key = "shopping_car_%s_%s" % (request.user.id, course_id,)if not CONN.exists(key):response.code = 10007response.error = '課程不存在'return Response(response.dict)price_policy_dict = json.loads(CONN.hget(key, 'price_policy_dict').decode('utf-8'))if policy_id not in price_policy_dict:response.code = 10008response.error = '價(jià)格策略不存在'return Response(response.dict)CONN.hset(key,'default_price_id',policy_id)CONN.expire(key, 20 * 60)response.data = '修改成功'except Exception as e:response.code = 10009response.error = '修改失敗'return Response(response.dict) View Code

使用postman測(cè)試訪問,要帶上正確的token

訪問正常

?

作為 session backend 使用配置

Django 默認(rèn)可以使用任何 cache backend 作為 session backend, 將 django-redis 作為 session 儲(chǔ)存后端不用安裝任何額外的 backend

SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "default"

?

舉例:

修改settings.py

# ######django-redis的配置 ################# CACHES = {"default": {"BACKEND": "django_redis.cache.RedisCache","LOCATION": "redis://192.168.218.140:6379","OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient","CONNECTION_POOL_KWARGS": {"max_connections": 100},# "PASSWORD": "密碼", }} }###使用redis緩存session SESSION_ENGINE = 'django.contrib.sessions.backends.cache' # 引擎 SESSION_CACHE_ALIAS = 'default' # 使用的緩存別名(默認(rèn)內(nèi)存緩存,也可以是memcache),此處別名依賴緩存的設(shè)置 SESSION_COOKIE_NAME = "sessionid" # Session的cookie保存在瀏覽器上時(shí)的key,即:sessionid=隨機(jī)字符串 SESSION_COOKIE_PATH = "/" # Session的cookie保存的路徑 SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名 SESSION_COOKIE_SECURE = False # 是否Https傳輸cookie SESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http傳輸 SESSION_COOKIE_AGE = 1209600 # Session的cookie失效日期(2周) SESSION_EXPIRE_AT_BROWSER_CLOSE = False # 是否關(guān)閉瀏覽器使得Session過期 SESSION_SAVE_EVERY_REQUEST = False # 是否每次請(qǐng)求都保存Session,默認(rèn)修改之后才保存 View Code

簡(jiǎn)單來(lái)講,加上2行就可以了。下面的那些配置,是參考源碼設(shè)置的。

比如session失效時(shí)間是2周

如果需要修改,在這里指定一下,就可以了!

注意:里面的defalut就是redis配置的defalut,名字是一一對(duì)應(yīng)的!

?

總結(jié):

1. django-redis的作用- 連接redis并在redis中進(jìn)行操作(含redis連接池)。2. 幫助用戶將session放到redis- django-redis的配置- session的配置 View Code

?

作業(yè):

完整結(jié)算中心的代碼,實(shí)現(xiàn)以下功能:

1. 添加

2. 查看

3. 修改

注意:使用認(rèn)證+django-redis?

?

修改utils目錄下的auth.py

當(dāng)為GET請(qǐng)求時(shí),從url中取token,否則從請(qǐng)求體中獲取token

from rest_framework.authentication import BaseAuthentication from rest_framework.exceptions import AuthenticationFailedfrom api import modelsclass LuffyAuthentication(BaseAuthentication):def authenticate(self, request):"""用戶認(rèn)證:param request::return:"""# print(request.method)# 判斷請(qǐng)求方式if request.method == "GET":token = request.query_params.get('token')else:token = request.data.get('token')# print('auth',token)token_obj = models.UserToken.objects.filter(token=token).first()if not token_obj:# 認(rèn)證失敗raise AuthenticationFailed({'code':1008,'error':'認(rèn)證失敗'})# 認(rèn)證成功# return (token_obj.user,token_obj)return (token_obj.user,token_obj) View Code

修改models.py,在用戶表增加字段

from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation from django.contrib.contenttypes.models import ContentType from django.db.models import Q from django.utils.safestring import mark_safe from django.db import models import hashlib# ######################## 課程相關(guān) ########################class CourseCategory(models.Model):"""課程大類, e.g 前端 后端..."""name = models.CharField(max_length=64, unique=True)def __str__(self):return "%s" % self.nameclass Meta:verbose_name_plural = "01.課程大類"class CourseSubCategory(models.Model):"""課程子類, e.g python linux """category = models.ForeignKey("CourseCategory")name = models.CharField(max_length=64, unique=True)def __str__(self):return "%s" % self.nameclass Meta:verbose_name_plural = "02.課程子類"class DegreeCourse(models.Model):"""學(xué)位課程"""name = models.CharField(max_length=128, unique=True)course_img = models.CharField(max_length=255, verbose_name="縮略圖")brief = models.TextField(verbose_name="學(xué)位課程簡(jiǎn)介", )total_scholarship = models.PositiveIntegerField(verbose_name="總獎(jiǎng)學(xué)金(貝里)", default=40000) # 2000 2000mentor_compensation_bonus = models.PositiveIntegerField(verbose_name="本課程的導(dǎo)師輔導(dǎo)費(fèi)用(貝里)", default=15000)period = models.PositiveIntegerField(verbose_name="建議學(xué)習(xí)周期(days)", default=150) # 為了計(jì)算學(xué)位獎(jiǎng)學(xué)金prerequisite = models.TextField(verbose_name="課程先修要求", max_length=1024)teachers = models.ManyToManyField("Teacher", verbose_name="課程講師")# 用于GenericForeignKey反向查詢, 不會(huì)生成表字段,切勿刪除# coupon = GenericRelation("Coupon")# 用于GenericForeignKey反向查詢,不會(huì)生成表字段,切勿刪除degreecourse_price_policy = GenericRelation("PricePolicy")def __str__(self):return self.nameclass Meta:verbose_name_plural = "03.學(xué)位課"class Teacher(models.Model):"""講師、導(dǎo)師表"""name = models.CharField(max_length=32)role_choices = ((0, '講師'), (1, '導(dǎo)師'))role = models.SmallIntegerField(choices=role_choices, default=0)title = models.CharField(max_length=64, verbose_name="職位、職稱")signature = models.CharField(max_length=255, help_text="導(dǎo)師簽名", blank=True, null=True)image = models.CharField(max_length=128)brief = models.TextField(max_length=1024)def __str__(self):return self.nameclass Meta:verbose_name_plural = "04.導(dǎo)師或講師"class Scholarship(models.Model):"""學(xué)位課程獎(jiǎng)學(xué)金"""degree_course = models.ForeignKey("DegreeCourse")time_percent = models.PositiveSmallIntegerField(verbose_name="獎(jiǎng)勵(lì)檔位(時(shí)間百分比)", help_text="只填百分值,如80,代表80%")value = models.PositiveIntegerField(verbose_name="獎(jiǎng)學(xué)金數(shù)額")def __str__(self):return "%s:%s" % (self.degree_course, self.value)class Meta:verbose_name_plural = "05.學(xué)位課獎(jiǎng)學(xué)金"class Course(models.Model):"""專題課/學(xué)位課模塊表"""name = models.CharField(max_length=128, unique=True)course_img = models.CharField(max_length=255)sub_category = models.ForeignKey("CourseSubCategory")course_type_choices = ((0, '付費(fèi)'), (1, 'VIP專享'), (2, '學(xué)位課程'))course_type = models.SmallIntegerField(choices=course_type_choices)# 不為空;學(xué)位課的某個(gè)模塊# 為空;專題課degree_course = models.ForeignKey("DegreeCourse", blank=True, null=True, help_text="若是學(xué)位課程,此處關(guān)聯(lián)學(xué)位表")brief = models.TextField(verbose_name="課程概述", max_length=2048)level_choices = ((0, '初級(jí)'), (1, '中級(jí)'), (2, '高級(jí)'))level = models.SmallIntegerField(choices=level_choices, default=1)pub_date = models.DateField(verbose_name="發(fā)布日期", blank=True, null=True)period = models.PositiveIntegerField(verbose_name="建議學(xué)習(xí)周期(days)", default=7) # order = models.IntegerField("課程順序", help_text="從上一個(gè)課程數(shù)字往后排")attachment_path = models.CharField(max_length=128, verbose_name="課件路徑", blank=True, null=True)status_choices = ((0, '上線'), (1, '下線'), (2, '預(yù)上線'))status = models.SmallIntegerField(choices=status_choices, default=0)template_id = models.SmallIntegerField("前端模板id", default=1)coupon = GenericRelation("Coupon")# 用于GenericForeignKey反向查詢,不會(huì)生成表字段,切勿刪除price_policy = GenericRelation("PricePolicy")asked_question = GenericRelation("OftenAskedQuestion")def __str__(self):return "%s(%s)" % (self.name, self.get_course_type_display())def save(self, *args, **kwargs):if self.course_type == 2:if not self.degree_course:raise ValueError("學(xué)位課程必須關(guān)聯(lián)對(duì)應(yīng)的學(xué)位表")super(Course, self).save(*args, **kwargs)class Meta:verbose_name_plural = "06.專題課或?qū)W位課模塊"class CourseDetail(models.Model):"""課程詳情頁(yè)內(nèi)容"""course = models.OneToOneField("Course")hours = models.IntegerField("課時(shí)")course_slogan = models.CharField(max_length=125, blank=True, null=True)video_brief_link = models.CharField(verbose_name='課程介紹', max_length=255, blank=True, null=True)why_study = models.TextField(verbose_name="為什么學(xué)習(xí)這門課程")what_to_study_brief = models.TextField(verbose_name="我將學(xué)到哪些內(nèi)容")career_improvement = models.TextField(verbose_name="此項(xiàng)目如何有助于我的職業(yè)生涯")prerequisite = models.TextField(verbose_name="課程先修要求", max_length=1024)recommend_courses = models.ManyToManyField("Course", related_name="recommend_by", blank=True)teachers = models.ManyToManyField("Teacher", verbose_name="課程講師")def __str__(self):return "%s" % self.courseclass Meta:verbose_name_plural = "07.課程或?qū)W位模塊詳細(xì)"class OftenAskedQuestion(models.Model):"""常見問題"""content_type = models.ForeignKey(ContentType) # 關(guān)聯(lián)course or degree_courseobject_id = models.PositiveIntegerField()content_object = GenericForeignKey('content_type', 'object_id')question = models.CharField(max_length=255)answer = models.TextField(max_length=1024)def __str__(self):return "%s-%s" % (self.content_object, self.question)class Meta:unique_together = ('content_type', 'object_id', 'question')verbose_name_plural = "08. 常見問題"class CourseOutline(models.Model):"""課程大綱"""course_detail = models.ForeignKey("CourseDetail")title = models.CharField(max_length=128)# 前端顯示順序order = models.PositiveSmallIntegerField(default=1)content = models.TextField("內(nèi)容", max_length=2048)def __str__(self):return "%s" % self.titleclass Meta:unique_together = ('course_detail', 'title')verbose_name_plural = "09. 課程大綱"class CourseChapter(models.Model):"""課程章節(jié)"""course = models.ForeignKey("Course")chapter = models.SmallIntegerField(verbose_name="第幾章", default=1)name = models.CharField(max_length=128)summary = models.TextField(verbose_name="章節(jié)介紹", blank=True, null=True)pub_date = models.DateField(verbose_name="發(fā)布日期", auto_now_add=True)class Meta:unique_together = ("course", 'chapter')verbose_name_plural = "10. 課程章節(jié)"def __str__(self):return "%s:(第%s章)%s" % (self.course, self.chapter, self.name)class CourseSection(models.Model):"""課時(shí)目錄"""chapter = models.ForeignKey("CourseChapter")name = models.CharField(max_length=128)order = models.PositiveSmallIntegerField(verbose_name="課時(shí)排序", help_text="建議每個(gè)課時(shí)之間空1至2個(gè)值,以備后續(xù)插入課時(shí)")section_type_choices = ((0, '文檔'), (1, '練習(xí)'), (2, '視頻'))section_type = models.SmallIntegerField(default=2, choices=section_type_choices)section_link = models.CharField(max_length=255, blank=True, null=True, help_text="若是video,填vid,若是文檔,填link")video_time = models.CharField(verbose_name="視頻時(shí)長(zhǎng)", blank=True, null=True, max_length=32) # 僅在前端展示使用pub_date = models.DateTimeField(verbose_name="發(fā)布時(shí)間", auto_now_add=True)free_trail = models.BooleanField("是否可試看", default=False)class Meta:unique_together = ('chapter', 'section_link')verbose_name_plural = "11. 課時(shí)"def __str__(self):return "%s-%s" % (self.chapter, self.name)class Homework(models.Model):chapter = models.ForeignKey("CourseChapter")title = models.CharField(max_length=128, verbose_name="作業(yè)題目")order = models.PositiveSmallIntegerField("作業(yè)順序", help_text="同一課程的每個(gè)作業(yè)之前的order值間隔1-2個(gè)數(shù)")homework_type_choices = ((0, '作業(yè)'), (1, '模塊通關(guān)考核'))homework_type = models.SmallIntegerField(choices=homework_type_choices, default=0)requirement = models.TextField(max_length=1024, verbose_name="作業(yè)需求")threshold = models.TextField(max_length=1024, verbose_name="踩分點(diǎn)")recommend_period = models.PositiveSmallIntegerField("推薦完成周期(天)", default=7)scholarship_value = models.PositiveSmallIntegerField("為該作業(yè)分配的獎(jiǎng)學(xué)金(貝里)")note = models.TextField(blank=True, null=True)enabled = models.BooleanField(default=True, help_text="本作業(yè)如果后期不需要了,不想讓學(xué)員看到,可以設(shè)置為False")class Meta:unique_together = ("chapter", "title")verbose_name_plural = "12. 章節(jié)作業(yè)"def __str__(self):return "%s - %s" % (self.chapter, self.title)# class CourseReview(models.Model): # """課程評(píng)價(jià)""" # enrolled_course = models.OneToOneField("EnrolledCourse") # about_teacher = models.FloatField(default=0, verbose_name="講師講解是否清晰") # about_video = models.FloatField(default=0, verbose_name="內(nèi)容實(shí)用") # about_course = models.FloatField(default=0, verbose_name="課程內(nèi)容通俗易懂") # review = models.TextField(max_length=1024, verbose_name="評(píng)價(jià)") # disagree_number = models.IntegerField(default=0, verbose_name="踩") # agree_number = models.IntegerField(default=0, verbose_name="贊同數(shù)") # tags = models.ManyToManyField("Tags", blank=True, verbose_name="標(biāo)簽") # date = models.DateTimeField(auto_now_add=True, verbose_name="評(píng)價(jià)日期") # is_recommend = models.BooleanField("熱評(píng)推薦", default=False) # hide = models.BooleanField("不在前端頁(yè)面顯示此條評(píng)價(jià)", default=False) # # def __str__(self): # return "%s-%s" % (self.enrolled_course.course, self.review) # # class Meta: # verbose_name_plural = "13. 課程評(píng)價(jià)(購(gòu)買課程后才能評(píng)價(jià))" # # # class DegreeCourseReview(models.Model): # """學(xué)位課程評(píng)價(jià) # 為了以后可以定制單獨(dú)的評(píng)價(jià)內(nèi)容,所以不與普通課程的評(píng)價(jià)混在一起,單獨(dú)建表 # """ # enrolled_course = models.ForeignKey("EnrolledDegreeCourse") # course = models.ForeignKey("Course", verbose_name="評(píng)價(jià)學(xué)位模塊", blank=True, null=True, # help_text="不填寫即代表評(píng)價(jià)整個(gè)學(xué)位課程", limit_choices_to={'course_type': 2}) # about_teacher = models.FloatField(default=0, verbose_name="講師講解是否清晰") # about_video = models.FloatField(default=0, verbose_name="視頻質(zhì)量") # about_course = models.FloatField(default=0, verbose_name="課程") # review = models.TextField(max_length=1024, verbose_name="評(píng)價(jià)") # disagree_number = models.IntegerField(default=0, verbose_name="踩") # agree_number = models.IntegerField(default=0, verbose_name="贊同數(shù)") # tags = models.ManyToManyField("Tags", blank=True, verbose_name="標(biāo)簽") # date = models.DateTimeField(auto_now_add=True, verbose_name="評(píng)價(jià)日期") # is_recommend = models.BooleanField("熱評(píng)推薦", default=False) # hide = models.BooleanField("不在前端頁(yè)面顯示此條評(píng)價(jià)", default=False) # # def __str__(self): # return "%s-%s" % (self.enrolled_course, self.review) # # class Meta: # verbose_name_plural = "14. 學(xué)位課評(píng)價(jià)(購(gòu)買課程后才能評(píng)價(jià))"class PricePolicy(models.Model):"""價(jià)格與有課程效期表"""content_type = models.ForeignKey(ContentType) # 關(guān)聯(lián)course or degree_courseobject_id = models.PositiveIntegerField()content_object = GenericForeignKey('content_type', 'object_id')# course = models.ForeignKey("Course")valid_period_choices = ((1, '1天'), (3, '3天'),(7, '1周'), (14, '2周'),(30, '1個(gè)月'),(60, '2個(gè)月'),(90, '3個(gè)月'),(180, '6個(gè)月'), (210, '12個(gè)月'),(540, '18個(gè)月'), (720, '24個(gè)月'),)valid_period = models.SmallIntegerField(choices=valid_period_choices)price = models.FloatField()class Meta:unique_together = ("content_type", 'object_id', "valid_period")verbose_name_plural = "15. 價(jià)格策略"def __str__(self):return "%s(%s)%s" % (self.content_object, self.get_valid_period_display(), self.price)# ################################### 優(yōu)惠券相關(guān) #################################class Coupon(models.Model):"""優(yōu)惠券生成規(guī)則"""name = models.CharField(max_length=64, verbose_name="活動(dòng)名稱")brief = models.TextField(blank=True, null=True, verbose_name="優(yōu)惠券介紹")coupon_type_choices = ((0, '立減'), (1, '滿減券'), (2, '折扣券'))coupon_type = models.SmallIntegerField(choices=coupon_type_choices, default=0, verbose_name="券類型")money_equivalent_value = models.IntegerField(verbose_name="等值貨幣")off_percent = models.PositiveSmallIntegerField("折扣百分比", help_text="只針對(duì)折扣券,例7.9折,寫79", blank=True, null=True)minimum_consume = models.PositiveIntegerField("最低消費(fèi)", default=0, help_text="僅在滿減券時(shí)填寫此字段")content_type = models.ForeignKey(ContentType, blank=True, null=True)object_id = models.PositiveIntegerField("綁定課程", blank=True, null=True, help_text="可以把優(yōu)惠券跟課程綁定")content_object = GenericForeignKey('content_type', 'object_id')quantity = models.PositiveIntegerField("數(shù)量(張)", default=1)open_date = models.DateField("優(yōu)惠券領(lǐng)取開始時(shí)間")close_date = models.DateField("優(yōu)惠券領(lǐng)取結(jié)束時(shí)間")valid_begin_date = models.DateField(verbose_name="有效期開始時(shí)間", blank=True, null=True)valid_end_date = models.DateField(verbose_name="有效結(jié)束時(shí)間", blank=True, null=True)# coupon_valid_days = models.PositiveIntegerField(verbose_name="優(yōu)惠券有效期(天)", blank=True, null=True,# help_text="自券被領(lǐng)時(shí)開始算起")date = models.DateTimeField(auto_now_add=True)class Meta:verbose_name_plural = "31. 優(yōu)惠券生成記錄"def __str__(self):return "%s(%s)" % (self.get_coupon_type_display(), self.name)class CouponRecord(models.Model):"""優(yōu)惠券發(fā)放、消費(fèi)紀(jì)錄"""coupon = models.ForeignKey("Coupon")account = models.ForeignKey("Account", verbose_name="擁有者")number = models.CharField(max_length=64, unique=True)status_choices = ((0, '未使用'), (1, '已使用'), (2, '已過期'))status = models.SmallIntegerField(choices=status_choices, default=0)get_time = models.DateTimeField(verbose_name="領(lǐng)取時(shí)間", help_text="用戶領(lǐng)取時(shí)間")used_time = models.DateTimeField(blank=True, null=True, verbose_name="使用時(shí)間")# order = models.ForeignKey("Order", blank=True, null=True, verbose_name="關(guān)聯(lián)訂單") # 一個(gè)訂單可以有多個(gè)優(yōu)惠券order_id = models.IntegerField(verbose_name='關(guān)聯(lián)訂單ID')class Meta:verbose_name_plural = "32. 用戶優(yōu)惠券"def __str__(self):return '%s-%s-%s' % (self.account, self.number, self.status)class Account(models.Model):username = models.CharField("用戶名", max_length=64, unique=True)email = models.EmailField(verbose_name='郵箱',max_length=255,unique=True,blank=True,null=True)password = models.CharField('密碼', max_length=128)balance = models.FloatField('貝里',default=0)class Meta:verbose_name_plural = "33. 用戶表"class UserToken(models.Model):user = models.OneToOneField(to='Account')token = models.CharField(max_length=36)class Meta:verbose_name_plural = "34. token表" View Code

執(zhí)行2個(gè)命令,生成字段

python manage.py makemigrations python manage.py migrate

為用戶加點(diǎn)錢

?

修改admin.py,注冊(cè)所有表

from django.contrib import admin# Register your models here. from api import models admin.site.register(models.CourseCategory) admin.site.register(models.CourseSubCategory) admin.site.register(models.DegreeCourse) admin.site.register(models.Teacher) admin.site.register(models.Scholarship) admin.site.register(models.Course) admin.site.register(models.CourseDetail) admin.site.register(models.OftenAskedQuestion) admin.site.register(models.CourseOutline) admin.site.register(models.CourseChapter) admin.site.register(models.CourseSection) admin.site.register(models.Homework) admin.site.register(models.PricePolicy) admin.site.register(models.Coupon) admin.site.register(models.CouponRecord) admin.site.register(models.Account) View Code

進(jìn)入admin后臺(tái),添加幾條優(yōu)惠券,并綁定用戶

list

修改payment.py,先做get請(qǐng)求的

import json import redis from django.conf import settings from rest_framework.views import APIView from rest_framework.viewsets import ViewSetMixin from rest_framework.response import Response from api.utils.auth import LuffyAuthentication from api import models from api.utils.response import BaseResponsefrom django_redis import get_redis_connectionCONN = get_redis_connection("default") # 使用redis連接池class PaymentView(ViewSetMixin, APIView):authentication_classes = [LuffyAuthentication, ]def create(self, request, *args, **kwargs):"""在結(jié)算中添加課程:param request::param args::param kwargs::return:"""# 1.接收用戶選擇的要結(jié)算的課程ID列表# 2.清空當(dāng)前用戶request.user.id結(jié)算中心的數(shù)據(jù)# key = payment_1*# 3.循環(huán)要加入結(jié)算中的所有課程ID列表"""for course_id in 用戶提交課程ID列表:3.1 根據(jù)course_id,request.user.id去購(gòu)物車中獲取商品信息:商品名稱、圖片、價(jià)格(id,周期,顯示周期,價(jià)格)3.2 根據(jù)course_id,request.user.id獲取 - 當(dāng)前用戶- 當(dāng)前課程- 可用的優(yōu)惠券加入結(jié)算中心提示:可以使用contenttypes"""# 4.獲取當(dāng)前用戶所有未綁定課程優(yōu)惠券# - 未使用# - 有效期內(nèi)# - 加入結(jié)算中心:glocal_coupon_用戶IDdef list(self, request, *args, **kwargs):"""查看結(jié)算中心:param request::param args::param kwargs::return:"""# 1. 根據(jù)用戶ID去結(jié)算中心獲取該用戶所有要結(jié)算課程course_id = request.query_params.get('course_id')print('課程id',course_id)obj = models.Course.objects.filter(id=course_id).first()print('結(jié)算課程',obj.name)# 2. 根據(jù)用戶ID去結(jié)算中心獲取該用戶所有可用未綁定課程的優(yōu)惠券user_id =request.user.idprint('用戶id', user_id)obj2 = models.CouponRecord.objects.filter(account=user_id, coupon__object_id__isnull=True).first()# print(obj2.coupon.get_coupon_type_display())if obj2.coupon.coupon_type == 0:print('{}{}'.format(obj2.coupon.get_coupon_type_display(),obj2.coupon.money_equivalent_value))elif obj2.coupon.coupon_type == 1:print('滿{}減{}'.format(obj2.coupon.minimum_consume,obj2.coupon.money_equivalent_value))else:print(obj2.coupon.id)print('{}折'.format(obj2.coupon.off_percent))# 3. 用戶表中獲取貝里余額beili = models.Account.objects.filter(id=user_id).first()print('用戶貝里',beili.balance)# 4. 以上數(shù)據(jù)構(gòu)造成一個(gè)字典return Response('...')def update(self, request, *args, **kwargs):"""更新優(yōu)惠券:param request::param args::param kwargs::return:"""# 1. 獲取用戶提交:# course_id=1,coupon_id=3# course_id=0,coupon_id=6# 2. course_id=1 --> 去結(jié)算中心獲取當(dāng)前用戶所擁有的綁定當(dāng)前課程優(yōu)惠,并進(jìn)行校驗(yàn)# - 成功:defaul_coupon_id=3# - 否則:非法請(qǐng)求# 3. course_id=0 --> 去結(jié)算中心獲取當(dāng)前用戶所擁有的未綁定課程優(yōu)惠,并進(jìn)行校驗(yàn)# - 成功:defaul_coupon_id=3# - 否則:非法請(qǐng)求 View Code

使用postman發(fā)送GET請(qǐng)求

查看Pycharm控制臺(tái)輸出

課程id 1 結(jié)算課程 Python開發(fā)入門7天特訓(xùn)營(yíng) 用戶id 1 立減10 用戶貝里 100.0

?

posted @ 2018-08-14 15:13 肖祥 閱讀( ...) 評(píng)論( ...) 編輯 收藏

總結(jié)

以上是生活随笔為你收集整理的python 全栈开发,Day104(DRF用户认证,结算中心,django-redis)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

欧美怡红院免费全部视频 | 国产成人精品三级麻豆 | 国产精品资源一区二区 | 自拍偷自拍亚洲精品10p | 欧美丰满熟妇xxxx性ppx人交 | 亚洲s码欧洲m码国产av | 亚洲精品中文字幕乱码 | 国产精品自产拍在线观看 | 午夜性刺激在线视频免费 | 国产另类ts人妖一区二区 | 久久久久久国产精品无码下载 | 成熟妇人a片免费看网站 | 亚洲精品综合五月久久小说 | 久精品国产欧美亚洲色aⅴ大片 | 成人aaa片一区国产精品 | 亚洲色无码一区二区三区 | 精品国产青草久久久久福利 | 男女性色大片免费网站 | 国产成人综合在线女婷五月99播放 | 亚洲爆乳大丰满无码专区 | 亚洲欧美国产精品专区久久 | 亚洲一区二区三区国产精华液 | 色一情一乱一伦一区二区三欧美 | 少妇性荡欲午夜性开放视频剧场 | 亚洲区小说区激情区图片区 | 国产精品久久久久无码av色戒 | 亚洲一区av无码专区在线观看 | 国产成人综合美国十次 | 亚洲乱亚洲乱妇50p | 国产美女精品一区二区三区 | 97夜夜澡人人双人人人喊 | 无码吃奶揉捏奶头高潮视频 | 国产人成高清在线视频99最全资源 | 日本一本二本三区免费 | 精品无人区无码乱码毛片国产 | 无码国产色欲xxxxx视频 | 国产97人人超碰caoprom | 亚洲熟妇色xxxxx欧美老妇y | 日日天干夜夜狠狠爱 | 国产成人人人97超碰超爽8 | 久久亚洲中文字幕无码 | 又黄又爽又色的视频 | 久久久久亚洲精品男人的天堂 | 亚洲精品国产a久久久久久 | 免费无码一区二区三区蜜桃大 | 天堂无码人妻精品一区二区三区 | 久久久精品国产sm最大网站 | 色综合久久中文娱乐网 | 综合激情五月综合激情五月激情1 | 偷窥村妇洗澡毛毛多 | 日韩精品久久久肉伦网站 | 国产一精品一av一免费 | 亚洲国产av美女网站 | 成人性做爰aaa片免费看不忠 | 动漫av一区二区在线观看 | 欧洲精品码一区二区三区免费看 | 色综合久久中文娱乐网 | 午夜精品一区二区三区在线观看 | 99精品久久毛片a片 | 人妻互换免费中文字幕 | 无码福利日韩神码福利片 | 国产一区二区三区日韩精品 | 乱人伦中文视频在线观看 | 一本久道久久综合婷婷五月 | 无码纯肉视频在线观看 | 十八禁视频网站在线观看 | 久久人人爽人人爽人人片ⅴ | 亚洲精品鲁一鲁一区二区三区 | 国内精品人妻无码久久久影院蜜桃 | 亚洲国产欧美国产综合一区 | 丰满少妇熟乱xxxxx视频 | 色五月丁香五月综合五月 | 国产真人无遮挡作爱免费视频 | 亚洲日韩av一区二区三区四区 | 性色av无码免费一区二区三区 | 国产成人人人97超碰超爽8 | 大地资源网第二页免费观看 | 精品aⅴ一区二区三区 | 丝袜美腿亚洲一区二区 | 熟妇人妻无码xxx视频 | 99久久人妻精品免费二区 | av在线亚洲欧洲日产一区二区 | 高清国产亚洲精品自在久久 | 日日摸夜夜摸狠狠摸婷婷 | 国产精品久久久av久久久 | 成人欧美一区二区三区黑人免费 | 亚洲欧美精品伊人久久 | 久久人人爽人人人人片 | 成熟人妻av无码专区 | 国产成人无码av在线影院 | 欧美刺激性大交 | 亚洲精品久久久久avwww潮水 | 国产超级va在线观看视频 | 妺妺窝人体色www在线小说 | 天天av天天av天天透 | 久久久成人毛片无码 | 国内揄拍国内精品少妇国语 | 一本大道久久东京热无码av | 老子影院午夜伦不卡 | 日产精品99久久久久久 | 国产三级精品三级男人的天堂 | 欧美日韩人成综合在线播放 | 免费乱码人妻系列无码专区 | 人人妻人人藻人人爽欧美一区 | 18精品久久久无码午夜福利 | 永久免费观看国产裸体美女 | 国产熟女一区二区三区四区五区 | 性欧美牲交xxxxx视频 | 久久综合九色综合97网 | 人妻天天爽夜夜爽一区二区 | 久久人人爽人人爽人人片av高清 | 亚洲熟妇色xxxxx欧美老妇y | 亚洲色成人中文字幕网站 | 亚洲熟妇自偷自拍另类 | 久久这里只有精品视频9 | 狂野欧美性猛交免费视频 | 一本色道久久综合亚洲精品不卡 | 青青青爽视频在线观看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲人成网站色7799 | 久久久国产一区二区三区 | 亚洲男人av香蕉爽爽爽爽 | 国产精品igao视频网 | 久久精品中文字幕大胸 | 捆绑白丝粉色jk震动捧喷白浆 | 全黄性性激高免费视频 | 国产艳妇av在线观看果冻传媒 | 欧美成人家庭影院 | 色综合久久中文娱乐网 | 久久综合久久自在自线精品自 | 亚洲中文字幕va福利 | 欧美成人午夜精品久久久 | 日欧一片内射va在线影院 | 午夜理论片yy44880影院 | 国产亚洲美女精品久久久2020 | 一个人免费观看的www视频 | 亚洲乱码国产乱码精品精 | 99精品国产综合久久久久五月天 | 国产亚洲日韩欧美另类第八页 | 亲嘴扒胸摸屁股激烈网站 | 无码播放一区二区三区 | 亚洲人成人无码网www国产 | 精品无人区无码乱码毛片国产 | 无码福利日韩神码福利片 | 爆乳一区二区三区无码 | 亚洲综合在线一区二区三区 | 精品久久久无码中文字幕 | 一本久久a久久精品亚洲 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产国语老龄妇女a片 | 纯爱无遮挡h肉动漫在线播放 | 风流少妇按摩来高潮 | 亚洲区小说区激情区图片区 | 中文字幕无码人妻少妇免费 | 荫蒂被男人添的好舒服爽免费视频 | 少妇激情av一区二区 | 中文无码成人免费视频在线观看 | 麻豆国产人妻欲求不满谁演的 | 综合激情五月综合激情五月激情1 | 两性色午夜免费视频 | 中文字幕乱妇无码av在线 | 国产黄在线观看免费观看不卡 | 亚洲成av人片在线观看无码不卡 | 中文字幕av日韩精品一区二区 | 国产人妖乱国产精品人妖 | 中文无码伦av中文字幕 | 久久久国产一区二区三区 | 免费国产成人高清在线观看网站 | 免费无码午夜福利片69 | 国产亚洲欧美在线专区 | 久久精品中文闷骚内射 | 日韩成人一区二区三区在线观看 | av人摸人人人澡人人超碰下载 | 国产真实乱对白精彩久久 | 色噜噜亚洲男人的天堂 | 99久久精品午夜一区二区 | 国产成人久久精品流白浆 | 高清不卡一区二区三区 | 久久久中文久久久无码 | 国产午夜手机精彩视频 | 成人性做爰aaa片免费看 | 国产超碰人人爽人人做人人添 | 两性色午夜免费视频 | 久久久精品456亚洲影院 | 日本精品久久久久中文字幕 | 免费视频欧美无人区码 | 欧美xxxx黑人又粗又长 | 一二三四在线观看免费视频 | 国产成人无码a区在线观看视频app | 亚洲精品一区二区三区婷婷月 | 日韩精品乱码av一区二区 | 精品午夜福利在线观看 | 九九热爱视频精品 | 亲嘴扒胸摸屁股激烈网站 | 久久久久久亚洲精品a片成人 | 亚洲乱码国产乱码精品精 | 又大又黄又粗又爽的免费视频 | 人人澡人摸人人添 | 草草网站影院白丝内射 | av无码电影一区二区三区 | 亚洲色大成网站www | 国产人妻精品一区二区三区不卡 | 国产乱人伦av在线无码 | 少女韩国电视剧在线观看完整 | 内射爽无广熟女亚洲 | av小次郎收藏 | 亚洲国产精品毛片av不卡在线 | 亚洲自偷精品视频自拍 | 日本饥渴人妻欲求不满 | 久久婷婷五月综合色国产香蕉 | 2020最新国产自产精品 | 又湿又紧又大又爽a视频国产 | 人人澡人摸人人添 | 国产97在线 | 亚洲 | 红桃av一区二区三区在线无码av | 国产亚洲人成在线播放 | 麻豆成人精品国产免费 | 成人无码视频在线观看网站 | 亚洲国产日韩a在线播放 | 国产精品国产三级国产专播 | 熟妇人妻激情偷爽文 | 天天av天天av天天透 | 动漫av网站免费观看 | 国产午夜亚洲精品不卡 | 天天燥日日燥 | 久久精品中文字幕一区 | 97人妻精品一区二区三区 | 久久亚洲日韩精品一区二区三区 | 精品无码成人片一区二区98 | 国产精品二区一区二区aⅴ污介绍 | 精品国产一区av天美传媒 | 亚洲va中文字幕无码久久不卡 | 99久久久无码国产aaa精品 | 国产成人无码av在线影院 | 久久综合给久久狠狠97色 | 波多野结衣高清一区二区三区 | 综合网日日天干夜夜久久 | 午夜福利一区二区三区在线观看 | 国产精品亚洲а∨无码播放麻豆 | 午夜精品久久久内射近拍高清 | 久久亚洲精品成人无码 | 国产精品亚洲五月天高清 | 亚洲中文字幕无码一久久区 | 亚洲一区二区三区无码久久 | 奇米影视7777久久精品人人爽 | 亚洲小说图区综合在线 | 国产激情精品一区二区三区 | 青青草原综合久久大伊人精品 | 亚洲色成人中文字幕网站 | 黑人巨大精品欧美一区二区 | 婷婷综合久久中文字幕蜜桃三电影 | 久久综合给久久狠狠97色 | 国产性生交xxxxx无码 | 青青久在线视频免费观看 | 中文字幕av伊人av无码av | 给我免费的视频在线观看 | 亚洲熟悉妇女xxx妇女av | 蜜桃视频插满18在线观看 | 国产亚洲精品久久久久久久久动漫 | 丰满人妻一区二区三区免费视频 | 人妻aⅴ无码一区二区三区 | 少妇无码一区二区二三区 | 日本大乳高潮视频在线观看 | 国产午夜手机精彩视频 | 99riav国产精品视频 | 精品人人妻人人澡人人爽人人 | 俄罗斯老熟妇色xxxx | 国产xxx69麻豆国语对白 | 国产色视频一区二区三区 | 日日摸夜夜摸狠狠摸婷婷 | 欧美黑人性暴力猛交喷水 | av无码久久久久不卡免费网站 | 一本久久伊人热热精品中文字幕 | 性生交大片免费看女人按摩摩 | 亚洲国产精品美女久久久久 | 亚洲天堂2017无码中文 | 97夜夜澡人人爽人人喊中国片 | 俄罗斯老熟妇色xxxx | 熟女少妇人妻中文字幕 | 乱人伦人妻中文字幕无码久久网 | 国产成人一区二区三区别 | 国产真人无遮挡作爱免费视频 | 十八禁真人啪啪免费网站 | 国产亚洲精品久久久久久国模美 | 日本一区二区三区免费高清 | 色情久久久av熟女人妻网站 | 欧美国产日韩亚洲中文 | 无遮挡啪啪摇乳动态图 | 国产av久久久久精东av | 男人的天堂av网站 | 国产性生大片免费观看性 | 久久国内精品自在自线 | 免费无码一区二区三区蜜桃大 | 女人被男人躁得好爽免费视频 | 乱码午夜-极国产极内射 | 无码任你躁久久久久久久 | 在线成人www免费观看视频 | 55夜色66夜色国产精品视频 | 欧美成人免费全部网站 | 成人精品天堂一区二区三区 | 亚洲精品国偷拍自产在线麻豆 | aa片在线观看视频在线播放 | 大色综合色综合网站 | 国内少妇偷人精品视频免费 | 天堂亚洲免费视频 | 中文字幕av伊人av无码av | 国产明星裸体无码xxxx视频 | 亚洲欧洲日本无在线码 | 天堂久久天堂av色综合 | 国产无套粉嫩白浆在线 | 激情人妻另类人妻伦 | 欧美zoozzooz性欧美 | 久久99热只有频精品8 | 精品国产成人一区二区三区 | 中文字幕无码免费久久99 | 国产超碰人人爽人人做人人添 | 亚洲男人av天堂午夜在 | 国产精品久久久久9999小说 | 亚洲va中文字幕无码久久不卡 | 久久精品99久久香蕉国产色戒 | 国产精品美女久久久久av爽李琼 | 十八禁视频网站在线观看 | 噜噜噜亚洲色成人网站 | 久久精品99久久香蕉国产色戒 | 久久久久免费精品国产 | 亚洲综合另类小说色区 | 人人妻人人澡人人爽人人精品 | 亚洲色欲色欲欲www在线 | 亚洲自偷自偷在线制服 | 亚洲色大成网站www | 国产又粗又硬又大爽黄老大爷视 | 国产人妖乱国产精品人妖 | 中文精品无码中文字幕无码专区 | 日本又色又爽又黄的a片18禁 | 欧美一区二区三区视频在线观看 | 秋霞成人午夜鲁丝一区二区三区 | 老熟妇乱子伦牲交视频 | 亚洲区欧美区综合区自拍区 | 久久视频在线观看精品 | 国产精品久久久午夜夜伦鲁鲁 | 老熟妇仑乱视频一区二区 | 激情五月综合色婷婷一区二区 | 日日碰狠狠躁久久躁蜜桃 | 亚洲成av人在线观看网址 | 日本va欧美va欧美va精品 | 高清不卡一区二区三区 | 中国女人内谢69xxxxxa片 | 亚洲国产欧美在线成人 | 精品国产成人一区二区三区 | 双乳奶水饱满少妇呻吟 | 国产农村妇女高潮大叫 | 国产艳妇av在线观看果冻传媒 | 国产av剧情md精品麻豆 | 亚洲国产av精品一区二区蜜芽 | 亚洲国产日韩a在线播放 | 亚洲色欲色欲欲www在线 | 国产精品人妻一区二区三区四 | 免费人成在线观看网站 | 午夜福利试看120秒体验区 | 亚洲一区二区三区香蕉 | 无码精品国产va在线观看dvd | 欧洲熟妇精品视频 | 久久午夜无码鲁丝片午夜精品 | 在线观看欧美一区二区三区 | 欧美 亚洲 国产 另类 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产人妻人伦精品1国产丝袜 | 2020久久超碰国产精品最新 | 亚洲日韩精品欧美一区二区 | 亚洲欧美国产精品久久 | 国产猛烈高潮尖叫视频免费 | 国产九九九九九九九a片 | 水蜜桃亚洲一二三四在线 | 国产精品亚洲а∨无码播放麻豆 | 在线精品亚洲一区二区 | 精品国产av色一区二区深夜久久 | 亚洲欧美精品伊人久久 | 中国女人内谢69xxxx | 色综合久久中文娱乐网 | √8天堂资源地址中文在线 | 少女韩国电视剧在线观看完整 | 国产真实乱对白精彩久久 | 亚洲精品国产精品乱码不卡 | 免费男性肉肉影院 | 国产成人无码区免费内射一片色欲 | 又色又爽又黄的美女裸体网站 | 性做久久久久久久久 | 色婷婷久久一区二区三区麻豆 | 露脸叫床粗话东北少妇 | 中文字幕人成乱码熟女app | 2020久久香蕉国产线看观看 | 欧美 丝袜 自拍 制服 另类 | 精品国产成人一区二区三区 | 动漫av网站免费观看 | 日产精品高潮呻吟av久久 | 亚洲日本va午夜在线电影 | 日本高清一区免费中文视频 | 丰满岳乱妇在线观看中字无码 | 又粗又大又硬毛片免费看 | 台湾无码一区二区 | 久久精品无码一区二区三区 | 精品夜夜澡人妻无码av蜜桃 | 日本熟妇人妻xxxxx人hd | 内射爽无广熟女亚洲 | 亚洲春色在线视频 | 国产一区二区三区精品视频 | 激情内射亚州一区二区三区爱妻 | 国产精品办公室沙发 | 300部国产真实乱 | 欧美第一黄网免费网站 | 精品久久久久久人妻无码中文字幕 | √天堂中文官网8在线 | 国产激情艳情在线看视频 | 99久久99久久免费精品蜜桃 | 狠狠色噜噜狠狠狠狠7777米奇 | 色综合久久久久综合一本到桃花网 | 国产激情艳情在线看视频 | 国产乱人伦偷精品视频 | 少女韩国电视剧在线观看完整 | 日本饥渴人妻欲求不满 | 少妇高潮一区二区三区99 | 麻豆国产人妻欲求不满 | 欧美大屁股xxxxhd黑色 | 西西人体www44rt大胆高清 | 日韩精品成人一区二区三区 | 老司机亚洲精品影院 | 亚洲精品国产第一综合99久久 | 国产麻豆精品一区二区三区v视界 | 波多野结衣一区二区三区av免费 | 精品久久综合1区2区3区激情 | 九九在线中文字幕无码 | 男人和女人高潮免费网站 | 激情国产av做激情国产爱 | 在线欧美精品一区二区三区 | 国产精品99爱免费视频 | 欧美成人免费全部网站 | 亚洲中文字幕无码中文字在线 | 无码av岛国片在线播放 | 亚洲精品国偷拍自产在线观看蜜桃 | 无码av岛国片在线播放 | 久久久精品欧美一区二区免费 | 欧美色就是色 | av香港经典三级级 在线 | 久久久久久a亚洲欧洲av冫 | 鲁大师影院在线观看 | 色一情一乱一伦一视频免费看 | 中文精品久久久久人妻不卡 | 国产精品亚洲五月天高清 | 精品久久久久香蕉网 | 亚洲一区二区三区无码久久 | 久久精品人人做人人综合试看 | 九月婷婷人人澡人人添人人爽 | 国产精品久久国产三级国 | 蜜桃无码一区二区三区 | 色婷婷欧美在线播放内射 | 精品成在人线av无码免费看 | 18黄暴禁片在线观看 | 欧美freesex黑人又粗又大 | 给我免费的视频在线观看 | 亚洲精品中文字幕乱码 | 日韩无码专区 | 精品国偷自产在线视频 | 无码午夜成人1000部免费视频 | 乱人伦人妻中文字幕无码久久网 | 亚洲成a人一区二区三区 | 精品无码国产一区二区三区av | 牛和人交xxxx欧美 | 午夜精品一区二区三区在线观看 | 一本久久a久久精品亚洲 | 成人性做爰aaa片免费看不忠 | 国产特级毛片aaaaaaa高清 | 青青草原综合久久大伊人精品 | v一区无码内射国产 | 无套内谢的新婚少妇国语播放 | 久久久久久亚洲精品a片成人 | 成人免费视频在线观看 | 午夜成人1000部免费视频 | 国产成人无码午夜视频在线观看 | 国産精品久久久久久久 | 日本www一道久久久免费榴莲 | 无遮挡国产高潮视频免费观看 | 欧美xxxx黑人又粗又长 | 国产精品久久久av久久久 | 国产精品香蕉在线观看 | 丰满岳乱妇在线观看中字无码 | 婷婷色婷婷开心五月四房播播 | 精品人妻人人做人人爽 | 午夜福利不卡在线视频 | 亚洲日韩一区二区 | 国产欧美精品一区二区三区 | 成人欧美一区二区三区黑人免费 | 国产乱人无码伦av在线a | 午夜性刺激在线视频免费 | 高清国产亚洲精品自在久久 | 久久精品女人天堂av免费观看 | 国产九九九九九九九a片 | 99视频精品全部免费免费观看 | 欧美变态另类xxxx | 中文字幕人成乱码熟女app | 全球成人中文在线 | 亚洲综合精品香蕉久久网 | 人人妻人人澡人人爽欧美一区九九 | 国产激情艳情在线看视频 | v一区无码内射国产 | 久久国产精品萌白酱免费 | 天天躁日日躁狠狠躁免费麻豆 | 婷婷六月久久综合丁香 | 国产成人无码午夜视频在线观看 | 精品国产精品久久一区免费式 | 台湾无码一区二区 | 欧美 日韩 亚洲 在线 | 东京无码熟妇人妻av在线网址 | 国产午夜无码视频在线观看 | 欧美精品一区二区精品久久 | 国产精品亚洲专区无码不卡 | 人妻少妇精品无码专区二区 | www国产亚洲精品久久久日本 | 午夜精品一区二区三区在线观看 | 国产午夜精品一区二区三区嫩草 | 伊人色综合久久天天小片 | 午夜免费福利小电影 | 国产办公室秘书无码精品99 | 久久久无码中文字幕久... | 精品熟女少妇av免费观看 | 日本熟妇人妻xxxxx人hd | 沈阳熟女露脸对白视频 | 四虎4hu永久免费 | 国产成人综合色在线观看网站 | 国产一区二区三区日韩精品 | 久久99久久99精品中文字幕 | 日本肉体xxxx裸交 | 亚洲欧美日韩国产精品一区二区 | 中文无码精品a∨在线观看不卡 | 国产精品欧美成人 | 中文字幕 亚洲精品 第1页 | 女人和拘做爰正片视频 | 熟妇人妻无码xxx视频 | 国产成人综合在线女婷五月99播放 | 一个人看的视频www在线 | 给我免费的视频在线观看 | 国产九九九九九九九a片 | 无码人妻精品一区二区三区下载 | 牲交欧美兽交欧美 | 性生交大片免费看l | 国产成人综合在线女婷五月99播放 | 小泽玛莉亚一区二区视频在线 | www国产亚洲精品久久网站 | 亚洲aⅴ无码成人网站国产app | 国产无av码在线观看 | 草草网站影院白丝内射 | 国产成人无码午夜视频在线观看 | 999久久久国产精品消防器材 | 亚洲国产综合无码一区 | 男女作爱免费网站 | 日产精品高潮呻吟av久久 | 国产69精品久久久久app下载 | 狠狠cao日日穞夜夜穞av | 红桃av一区二区三区在线无码av | 日日天日日夜日日摸 | 国产成人无码a区在线观看视频app | 精品日本一区二区三区在线观看 | 国产精品va在线观看无码 | 少妇太爽了在线观看 | 国产免费无码一区二区视频 | 无码人妻久久一区二区三区不卡 | 99久久婷婷国产综合精品青草免费 | 2019nv天堂香蕉在线观看 | 国产美女精品一区二区三区 | 天天爽夜夜爽夜夜爽 | 色窝窝无码一区二区三区色欲 | 在线天堂新版最新版在线8 | 国产午夜无码精品免费看 | 少妇性l交大片 | 夜夜夜高潮夜夜爽夜夜爰爰 | 欧洲精品码一区二区三区免费看 | 性欧美牲交xxxxx视频 | 亚洲人交乣女bbw | 人妻少妇精品久久 | 午夜男女很黄的视频 | 亚洲精品久久久久中文第一幕 | 中文字幕日产无线码一区 | 精品久久久久香蕉网 | 午夜丰满少妇性开放视频 | 天天做天天爱天天爽综合网 | 久9re热视频这里只有精品 | 青草视频在线播放 | 天天摸天天碰天天添 | 国产av无码专区亚洲a∨毛片 | 欧美日韩色另类综合 | 奇米影视7777久久精品人人爽 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产午夜手机精彩视频 | 久久久精品成人免费观看 | 一本久道久久综合狠狠爱 | 中文字幕av无码一区二区三区电影 | 欧美老妇交乱视频在线观看 | 无码成人精品区在线观看 | 国产精品久免费的黄网站 | 精品人妻人人做人人爽夜夜爽 | 中文字幕中文有码在线 | 亚洲精品综合五月久久小说 | 天堂无码人妻精品一区二区三区 | 九九在线中文字幕无码 | 青青青手机频在线观看 | 性色欲情网站iwww九文堂 | 鲁大师影院在线观看 | 久久久久se色偷偷亚洲精品av | 成人亚洲精品久久久久 | 亚洲娇小与黑人巨大交 | 久久视频在线观看精品 | 久久99精品国产麻豆 | 精品国产一区二区三区四区在线看 | 成 人 网 站国产免费观看 | 波多野结衣av在线观看 | 久久精品人人做人人综合试看 | 久久久中文久久久无码 | 亚洲成av人片在线观看无码不卡 | 丰满人妻翻云覆雨呻吟视频 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 中文字幕日产无线码一区 | 日本又色又爽又黄的a片18禁 | 亚洲一区二区三区无码久久 | 中文字幕久久久久人妻 | 精品国产乱码久久久久乱码 | 国产一区二区不卡老阿姨 | 国产欧美精品一区二区三区 | 婷婷丁香五月天综合东京热 | 女人被爽到呻吟gif动态图视看 | 午夜精品一区二区三区的区别 | 色狠狠av一区二区三区 | 国产xxx69麻豆国语对白 | 人人爽人人澡人人人妻 | 亚洲呦女专区 | 激情内射日本一区二区三区 | 成人精品视频一区二区三区尤物 | 精品国产精品久久一区免费式 | 国产亚洲日韩欧美另类第八页 | 亚洲精品中文字幕久久久久 | 亚洲精品综合五月久久小说 | 久久天天躁狠狠躁夜夜免费观看 | 国产猛烈高潮尖叫视频免费 | 久久综合九色综合欧美狠狠 | 国产精品亚洲综合色区韩国 | 久久国产精品_国产精品 | 久久97精品久久久久久久不卡 | 婷婷丁香五月天综合东京热 | 亚洲人成网站免费播放 | 久久久精品456亚洲影院 | 精品久久久久香蕉网 | 最新版天堂资源中文官网 | 久久人妻内射无码一区三区 | 久久人人爽人人爽人人片av高清 | 99久久人妻精品免费二区 | 国产国产精品人在线视 | а天堂中文在线官网 | 人妻少妇精品视频专区 | 亚洲国产精品无码久久久久高潮 | 人妻少妇精品无码专区二区 | 日日碰狠狠丁香久燥 | 久久精品国产日本波多野结衣 | 98国产精品综合一区二区三区 | 欧美日韩在线亚洲综合国产人 | 国产乱子伦视频在线播放 | 国产精品久免费的黄网站 | 久久综合狠狠综合久久综合88 | 亚洲 日韩 欧美 成人 在线观看 | 国产成人精品久久亚洲高清不卡 | 98国产精品综合一区二区三区 | 精品无码国产自产拍在线观看蜜 | 国产精品鲁鲁鲁 | 久久久久av无码免费网 | 日日摸夜夜摸狠狠摸婷婷 | 久久国产精品精品国产色婷婷 | 亚洲精品久久久久久久久久久 | 中文字幕无码免费久久99 | 久久综合九色综合97网 | 精品久久久久香蕉网 | 亚洲色欲色欲天天天www | 久久综合激激的五月天 | 99久久亚洲精品无码毛片 | 国模大胆一区二区三区 | 国产欧美精品一区二区三区 | 巨爆乳无码视频在线观看 | 国产午夜精品一区二区三区嫩草 | 国产乱码精品一品二品 | 国内丰满熟女出轨videos | 国产亚洲人成在线播放 | 国产肉丝袜在线观看 | 激情国产av做激情国产爱 | 亚洲色大成网站www国产 | 欧美三级a做爰在线观看 | 亚洲国产精品久久人人爱 | 男人的天堂2018无码 | 日本xxxx色视频在线观看免费 | 国产成人综合美国十次 | 丁香花在线影院观看在线播放 | 大地资源网第二页免费观看 | 亚洲人成网站在线播放942 | 婷婷五月综合缴情在线视频 | 亚洲精品欧美二区三区中文字幕 | 夜精品a片一区二区三区无码白浆 | yw尤物av无码国产在线观看 | 日本精品人妻无码免费大全 | 国产一区二区三区影院 | 日本精品久久久久中文字幕 | 亚洲成色www久久网站 | 色综合久久久久综合一本到桃花网 | 久久午夜夜伦鲁鲁片无码免费 | 日本护士xxxxhd少妇 | 久热国产vs视频在线观看 | 无码人妻精品一区二区三区不卡 | 国产麻豆精品一区二区三区v视界 | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲第一无码av无码专区 | 2019nv天堂香蕉在线观看 | 精品无码成人片一区二区98 | 日韩亚洲欧美中文高清在线 | 日本一区二区三区免费播放 | 日韩精品久久久肉伦网站 | 樱花草在线社区www | 国产精品无码成人午夜电影 | 国产麻豆精品精东影业av网站 | 中文字幕无码视频专区 | 亚洲国产一区二区三区在线观看 | 999久久久国产精品消防器材 | 国产精品久久久久久久9999 | 日韩av无码中文无码电影 | 国产乱人伦av在线无码 | a在线观看免费网站大全 | 免费无码一区二区三区蜜桃大 | 久久天天躁夜夜躁狠狠 | 97久久精品无码一区二区 | 精品人妻人人做人人爽 | 亚洲无人区一区二区三区 | 亚洲欧美日韩国产精品一区二区 | 美女毛片一区二区三区四区 | 九一九色国产 | 亚洲爆乳大丰满无码专区 | 亚洲日韩av一区二区三区四区 | 亚洲成av人片在线观看无码不卡 | 四虎国产精品一区二区 | 亚洲自偷自拍另类第1页 | 精品水蜜桃久久久久久久 | 国产人妻久久精品二区三区老狼 | 亚洲男人av香蕉爽爽爽爽 | 午夜精品久久久久久久 | 亚洲男人av天堂午夜在 | 亚洲人成影院在线观看 | 秋霞成人午夜鲁丝一区二区三区 | 日韩精品成人一区二区三区 | 西西人体www44rt大胆高清 | 亚洲乱码国产乱码精品精 | 久久亚洲精品成人无码 | 国产黄在线观看免费观看不卡 | 无码人妻少妇伦在线电影 | 久久精品无码一区二区三区 | 女人高潮内射99精品 | 国产97人人超碰caoprom | 欧美成人高清在线播放 | 蜜桃臀无码内射一区二区三区 | 扒开双腿吃奶呻吟做受视频 | 亚洲精品综合一区二区三区在线 | 色一情一乱一伦一视频免费看 | 国产猛烈高潮尖叫视频免费 | 亚洲成a人片在线观看无码3d | 永久免费观看国产裸体美女 | 国产亚洲精品久久久久久国模美 | 久久99国产综合精品 | 高清无码午夜福利视频 | 久久综合色之久久综合 | 日产精品高潮呻吟av久久 | 国产精品国产自线拍免费软件 | 亚洲国产精品久久久天堂 | 久久无码中文字幕免费影院蜜桃 | 国产精华av午夜在线观看 | 四虎影视成人永久免费观看视频 | 亚洲爆乳大丰满无码专区 | 国产热a欧美热a在线视频 | 亚洲国产精品毛片av不卡在线 | 人人妻在人人 | 丰满少妇熟乱xxxxx视频 | 啦啦啦www在线观看免费视频 | 国产精品久免费的黄网站 | 狠狠综合久久久久综合网 | 一本色道婷婷久久欧美 | 欧美xxxx黑人又粗又长 | 亚洲乱亚洲乱妇50p | 99麻豆久久久国产精品免费 | 骚片av蜜桃精品一区 | 性欧美大战久久久久久久 | 国产成人无码午夜视频在线观看 | 3d动漫精品啪啪一区二区中 | 国产亚洲tv在线观看 | 永久免费观看美女裸体的网站 | 欧美精品一区二区精品久久 | 无人区乱码一区二区三区 | 97资源共享在线视频 | 窝窝午夜理论片影院 | 最近的中文字幕在线看视频 | 欧美性猛交xxxx富婆 | 国产 浪潮av性色四虎 | 久久国产劲爆∧v内射 | 一本加勒比波多野结衣 | 男女超爽视频免费播放 | 国产精品无码一区二区三区不卡 | 97精品人妻一区二区三区香蕉 | 久久久精品欧美一区二区免费 | 国产精品亚洲五月天高清 | 国产av一区二区精品久久凹凸 | 国产成人综合在线女婷五月99播放 | 久久久久99精品国产片 | 精品久久久久香蕉网 | 高潮毛片无遮挡高清免费 | 国产成人精品无码播放 | 色五月丁香五月综合五月 | 国内精品久久毛片一区二区 | 蜜臀aⅴ国产精品久久久国产老师 | 久久久久久久人妻无码中文字幕爆 | 国产精品二区一区二区aⅴ污介绍 | 美女黄网站人色视频免费国产 | 日韩视频 中文字幕 视频一区 | 欧美真人作爱免费视频 | 欧美性猛交内射兽交老熟妇 | 日本爽爽爽爽爽爽在线观看免 | 色噜噜亚洲男人的天堂 | 成年女人永久免费看片 | 蜜桃视频韩日免费播放 | 精品夜夜澡人妻无码av蜜桃 | а√资源新版在线天堂 | 99视频精品全部免费免费观看 | 久久精品人人做人人综合 | 国产疯狂伦交大片 | 丰满少妇人妻久久久久久 | 国产成人无码区免费内射一片色欲 | 人妻aⅴ无码一区二区三区 | 久久久久久亚洲精品a片成人 | 色五月五月丁香亚洲综合网 | 牲交欧美兽交欧美 | 牲欲强的熟妇农村老妇女视频 | 鲁鲁鲁爽爽爽在线视频观看 | 欧洲欧美人成视频在线 | 好屌草这里只有精品 | 免费无码av一区二区 | 装睡被陌生人摸出水好爽 | 久久亚洲精品成人无码 | 欧美人与动性行为视频 | 黄网在线观看免费网站 | 亚洲综合久久一区二区 | 国产av人人夜夜澡人人爽麻豆 | 亚洲精品久久久久中文第一幕 | а天堂中文在线官网 | 国产免费久久久久久无码 | 玩弄人妻少妇500系列视频 | 日韩成人一区二区三区在线观看 | 荫蒂添的好舒服视频囗交 | 亚洲自偷自偷在线制服 | 少妇性荡欲午夜性开放视频剧场 | a国产一区二区免费入口 | 亚洲中文字幕久久无码 | 丰满肥臀大屁股熟妇激情视频 | 久久精品人人做人人综合 | 我要看www免费看插插视频 | 色诱久久久久综合网ywww | 亚洲精品一区二区三区大桥未久 | 国产精品人人爽人人做我的可爱 | 国产激情无码一区二区 | 好男人www社区 | 乱码av麻豆丝袜熟女系列 | 国产精品资源一区二区 | 无码av最新清无码专区吞精 | 秋霞成人午夜鲁丝一区二区三区 | 人妻有码中文字幕在线 | 全黄性性激高免费视频 | 午夜精品久久久久久久久 | 初尝人妻少妇中文字幕 | 99久久99久久免费精品蜜桃 | 中文字幕av无码一区二区三区电影 | 青草青草久热国产精品 | 亚洲va欧美va天堂v国产综合 | 无码毛片视频一区二区本码 | 国内精品久久久久久中文字幕 | 国产莉萝无码av在线播放 | 夜夜影院未满十八勿进 | 色一情一乱一伦一视频免费看 | 一本久道久久综合狠狠爱 | 日日麻批免费40分钟无码 | 丰满妇女强制高潮18xxxx | 久久久久人妻一区精品色欧美 | 无套内射视频囯产 | 中文字幕无码日韩专区 | 国产成人无码av在线影院 | 成人影院yy111111在线观看 | 永久免费精品精品永久-夜色 | 一本无码人妻在中文字幕免费 | 亚洲国产高清在线观看视频 | 欧美日韩在线亚洲综合国产人 | 76少妇精品导航 | 色婷婷综合激情综在线播放 | 一本色道久久综合亚洲精品不卡 | 日韩精品乱码av一区二区 | 精品国偷自产在线视频 | 精品人妻中文字幕有码在线 | 精品久久综合1区2区3区激情 | 一二三四社区在线中文视频 | 欧美精品无码一区二区三区 | 人人爽人人爽人人片av亚洲 | 一二三四社区在线中文视频 | 水蜜桃色314在线观看 | 国产乱码精品一品二品 | 天天爽夜夜爽夜夜爽 | 丰满妇女强制高潮18xxxx | 色欲人妻aaaaaaa无码 | 四虎国产精品一区二区 | 内射巨臀欧美在线视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产午夜无码视频在线观看 | 亚洲精品一区二区三区在线 | 亚洲精品国产第一综合99久久 | 免费观看的无遮挡av | 日韩精品久久久肉伦网站 | 欧美喷潮久久久xxxxx | 久久久婷婷五月亚洲97号色 | www国产亚洲精品久久网站 | 成年美女黄网站色大免费视频 | 国产亚洲欧美日韩亚洲中文色 | 亚洲精品中文字幕乱码 | 全球成人中文在线 | 欧美日本免费一区二区三区 | 又大又紧又粉嫩18p少妇 | 国产亚洲精品久久久闺蜜 | 无码人妻丰满熟妇区五十路百度 | 国产在线精品一区二区高清不卡 | 装睡被陌生人摸出水好爽 | 国产熟妇高潮叫床视频播放 | 国产精品人妻一区二区三区四 | 中文字幕人成乱码熟女app | 久久久精品成人免费观看 | 国产97人人超碰caoprom | 欧美老熟妇乱xxxxx | 精品国产一区二区三区四区在线看 | 日本精品高清一区二区 | 日本在线高清不卡免费播放 | 日本va欧美va欧美va精品 | 色妞www精品免费视频 | 久久无码专区国产精品s | 国产在热线精品视频 | 少妇厨房愉情理9仑片视频 | 国产 精品 自在自线 | 亚洲小说图区综合在线 | 永久免费精品精品永久-夜色 | 婷婷五月综合缴情在线视频 | 在线播放无码字幕亚洲 | 一本久道高清无码视频 | 欧美日韩一区二区免费视频 | 国产精品久久久久久久9999 | 国产莉萝无码av在线播放 | 日日天干夜夜狠狠爱 | 国产精品久久久 | 色综合久久中文娱乐网 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲七七久久桃花影院 | 国产乱码精品一品二品 | 亚洲一区二区观看播放 | 久久亚洲a片com人成 | 精品乱子伦一区二区三区 | 免费看少妇作爱视频 | 国产精品高潮呻吟av久久4虎 | 牲欲强的熟妇农村老妇女视频 | 国产成人无码专区 | 天堂一区人妻无码 | 国产精品a成v人在线播放 | 国产色xx群视频射精 | 九月婷婷人人澡人人添人人爽 | 久久99精品久久久久久 | 国产乱人偷精品人妻a片 | 激情亚洲一区国产精品 | 亚洲午夜久久久影院 | 成在人线av无码免观看麻豆 | 国产精品视频免费播放 | 亚洲日韩中文字幕在线播放 | 任你躁在线精品免费 | 色情久久久av熟女人妻网站 | 日韩av无码一区二区三区不卡 | 国内揄拍国内精品人妻 | 国产人妻大战黑人第1集 | 亚洲一区二区观看播放 | 无码精品国产va在线观看dvd | 骚片av蜜桃精品一区 | 日日噜噜噜噜夜夜爽亚洲精品 | 人人爽人人澡人人高潮 | 成 人 网 站国产免费观看 | 久久久久成人精品免费播放动漫 | 亚洲国产高清在线观看视频 | 亚洲精品成人av在线 | 丝袜 中出 制服 人妻 美腿 | 日本精品人妻无码77777 天堂一区人妻无码 | 日韩精品一区二区av在线 | 国精品人妻无码一区二区三区蜜柚 | 熟妇人妻无乱码中文字幕 | 国产成人精品视频ⅴa片软件竹菊 | 少妇被黑人到高潮喷出白浆 | 性欧美videos高清精品 | 97久久超碰中文字幕 | 亚洲爆乳无码专区 | 欧美日韩在线亚洲综合国产人 | 免费中文字幕日韩欧美 | 日本一区二区三区免费高清 | 久久久久国色av免费观看性色 | 天天躁夜夜躁狠狠是什么心态 | 亚洲日韩av一区二区三区四区 | 日韩少妇内射免费播放 | 粉嫩少妇内射浓精videos | 亚洲一区二区三区四区 | 亚洲 另类 在线 欧美 制服 | 人人妻人人澡人人爽欧美精品 | 超碰97人人射妻 | 色欲人妻aaaaaaa无码 | 国产香蕉尹人综合在线观看 | 国产三级久久久精品麻豆三级 | 免费人成网站视频在线观看 | 日韩无套无码精品 | 国内精品九九久久久精品 | 国内老熟妇对白xxxxhd | 又黄又爽又色的视频 | 亚洲gv猛男gv无码男同 | 女人和拘做爰正片视频 | 亚洲人成人无码网www国产 | 亚洲乱亚洲乱妇50p | 日韩av无码一区二区三区 | 精品久久久无码人妻字幂 | 欧美丰满少妇xxxx性 | 国产又爽又黄又刺激的视频 | 天堂亚洲免费视频 | 亚洲中文字幕va福利 | 日韩无套无码精品 | 中文无码成人免费视频在线观看 | 国产成人综合色在线观看网站 | 国产成人精品久久亚洲高清不卡 | 野外少妇愉情中文字幕 | 免费看男女做好爽好硬视频 | 久久久久久久人妻无码中文字幕爆 | 欧美熟妇另类久久久久久多毛 | 久久五月精品中文字幕 | 国产精品无码久久av | 乱人伦人妻中文字幕无码 | 国产成人无码专区 | 亚洲午夜福利在线观看 | 丰满少妇熟乱xxxxx视频 | 国产高潮视频在线观看 | 久久午夜无码鲁丝片午夜精品 | 久久99精品久久久久久 | 亲嘴扒胸摸屁股激烈网站 | 久久精品国产大片免费观看 | 综合激情五月综合激情五月激情1 | 国产精品.xx视频.xxtv | 亚洲第一网站男人都懂 | 国产精品人人妻人人爽 | 5858s亚洲色大成网站www | 久久精品国产一区二区三区肥胖 | 久久久久人妻一区精品色欧美 | 午夜熟女插插xx免费视频 | 性开放的女人aaa片 | 狠狠cao日日穞夜夜穞av | 成 人 网 站国产免费观看 | 久久久无码中文字幕久... | 亚洲精品鲁一鲁一区二区三区 | 国产精品久久久久影院嫩草 | 日韩无码专区 | 色窝窝无码一区二区三区色欲 | 精品人妻人人做人人爽夜夜爽 | 免费人成网站视频在线观看 | 国产精品99久久精品爆乳 | 成 人 网 站国产免费观看 | 久久人人97超碰a片精品 | 男人的天堂2018无码 | 麻豆精产国品 | 欧美国产亚洲日韩在线二区 | 色综合久久久久综合一本到桃花网 | 久久久www成人免费毛片 | 国产香蕉97碰碰久久人人 | 日本护士xxxxhd少妇 | 中国大陆精品视频xxxx | 中文字幕无码乱人伦 | 麻豆国产丝袜白领秘书在线观看 | 黑森林福利视频导航 | 欧美35页视频在线观看 | 欧美日韩视频无码一区二区三 | 欧美性猛交xxxx富婆 | 国产成人精品优优av | 国产成人精品一区二区在线小狼 | 三上悠亚人妻中文字幕在线 | 无遮无挡爽爽免费视频 | 最新国产乱人伦偷精品免费网站 | 国产美女精品一区二区三区 | 日本护士xxxxhd少妇 | 亚洲精品久久久久中文第一幕 | 人妻少妇精品视频专区 | 伊在人天堂亚洲香蕉精品区 | 精品人妻人人做人人爽夜夜爽 | 日韩精品一区二区av在线 | 日本va欧美va欧美va精品 | 中文字幕日韩精品一区二区三区 | 国色天香社区在线视频 | 国产色视频一区二区三区 | 国产人妻精品一区二区三区不卡 | 国产精品a成v人在线播放 | 无码毛片视频一区二区本码 | 奇米影视7777久久精品人人爽 | 人妻少妇精品视频专区 | 无码毛片视频一区二区本码 | 精品水蜜桃久久久久久久 | 玩弄人妻少妇500系列视频 | 中文字幕乱码中文乱码51精品 | 欧美人与禽猛交狂配 | 狠狠亚洲超碰狼人久久 | 欧美精品国产综合久久 | 国产av无码专区亚洲awww | 强辱丰满人妻hd中文字幕 | 久久精品国产大片免费观看 | 欧美性生交xxxxx久久久 | 亚洲国精产品一二二线 | yw尤物av无码国产在线观看 | 成人片黄网站色大片免费观看 | 国产一区二区不卡老阿姨 | 欧美日本日韩 | 奇米影视888欧美在线观看 | 丰满妇女强制高潮18xxxx | 精品国产乱码久久久久乱码 | 精品人人妻人人澡人人爽人人 | 亚洲日韩精品欧美一区二区 | 桃花色综合影院 | 国产精华av午夜在线观看 | 成人免费视频在线观看 | 无码人妻久久一区二区三区不卡 | 中文字幕色婷婷在线视频 | 国产乱子伦视频在线播放 | 精品一二三区久久aaa片 | 国产精品理论片在线观看 | 精品国偷自产在线视频 | 偷窥村妇洗澡毛毛多 | 亚洲日韩av一区二区三区中文 | 人妻尝试又大又粗久久 | 在线播放亚洲第一字幕 | 中文精品无码中文字幕无码专区 | 午夜精品久久久内射近拍高清 | 无码人妻少妇伦在线电影 | 久久视频在线观看精品 | 牲欲强的熟妇农村老妇女 | 熟女俱乐部五十路六十路av | 久久久久人妻一区精品色欧美 | 成人免费视频在线观看 | 男女猛烈xx00免费视频试看 | 大地资源中文第3页 | 99久久99久久免费精品蜜桃 | 色婷婷av一区二区三区之红樱桃 | 夜先锋av资源网站 | 无套内射视频囯产 | 国产成人无码专区 | 天堂а√在线地址中文在线 | 老熟妇乱子伦牲交视频 | 久久久久se色偷偷亚洲精品av | 成人欧美一区二区三区 | www国产亚洲精品久久网站 | 两性色午夜免费视频 | 真人与拘做受免费视频一 | 在线а√天堂中文官网 | 小sao货水好多真紧h无码视频 | 国产精品免费大片 | 小泽玛莉亚一区二区视频在线 | 丰腴饱满的极品熟妇 | 亚洲爆乳精品无码一区二区三区 | 中文字幕av无码一区二区三区电影 | 国产成人综合在线女婷五月99播放 | 5858s亚洲色大成网站www | 精品亚洲韩国一区二区三区 | а√天堂www在线天堂小说 | 欧美肥老太牲交大战 | 黑人巨大精品欧美黑寡妇 | 人妻体内射精一区二区三四 | 乱人伦人妻中文字幕无码久久网 | 无码一区二区三区在线 | 性啪啪chinese东北女人 | 欧美 丝袜 自拍 制服 另类 | 国产片av国语在线观看 | 国产av久久久久精东av | 18精品久久久无码午夜福利 | 大色综合色综合网站 | 少妇一晚三次一区二区三区 | 日韩av无码中文无码电影 | 国产成人无码av在线影院 | 国产av人人夜夜澡人人爽麻豆 | 国产一区二区三区精品视频 | 久久精品中文字幕一区 | 免费无码一区二区三区蜜桃大 | 国产人妻精品午夜福利免费 | 欧美freesex黑人又粗又大 | 欧美丰满熟妇xxxx性ppx人交 | 欧美老熟妇乱xxxxx | 精品无码国产一区二区三区av | 无遮无挡爽爽免费视频 | 99久久人妻精品免费一区 | 亚洲va欧美va天堂v国产综合 | 欧美 丝袜 自拍 制服 另类 | 婷婷色婷婷开心五月四房播播 | 99re在线播放 | 青青草原综合久久大伊人精品 | 人人妻人人澡人人爽人人精品浪潮 | 国产人妻精品一区二区三区不卡 | 水蜜桃色314在线观看 | 午夜精品久久久内射近拍高清 | www国产亚洲精品久久久日本 | 男人和女人高潮免费网站 | 亚洲色无码一区二区三区 | 色欲久久久天天天综合网精品 | 少妇高潮一区二区三区99 | 国产av人人夜夜澡人人爽麻豆 | 国语精品一区二区三区 | 国产乡下妇女做爰 | 中文字幕无码人妻少妇免费 | 久久国产36精品色熟妇 | 天天躁日日躁狠狠躁免费麻豆 | 成人无码影片精品久久久 | 在线欧美精品一区二区三区 | 狠狠躁日日躁夜夜躁2020 | 亚洲s色大片在线观看 | 国产99久久精品一区二区 | 国内精品久久久久久中文字幕 | 无码人妻丰满熟妇区五十路百度 | 无码一区二区三区在线 | 人人妻人人澡人人爽精品欧美 | 日韩 欧美 动漫 国产 制服 | 乱码午夜-极国产极内射 | 久久zyz资源站无码中文动漫 | 中文字幕亚洲情99在线 | 亚洲精品无码人妻无码 | 亚洲一区二区三区香蕉 | 午夜熟女插插xx免费视频 | 一本久道久久综合狠狠爱 | 蜜臀av在线播放 久久综合激激的五月天 | 国产午夜视频在线观看 | 成人免费视频视频在线观看 免费 | 少妇性荡欲午夜性开放视频剧场 | 国产精品久久久久影院嫩草 | 日韩av无码一区二区三区不卡 | 超碰97人人做人人爱少妇 | 2019午夜福利不卡片在线 | 性啪啪chinese东北女人 | 国产午夜无码视频在线观看 | 中国大陆精品视频xxxx | 2020久久超碰国产精品最新 | 装睡被陌生人摸出水好爽 | 久久久久成人精品免费播放动漫 | 丰满少妇人妻久久久久久 | 欧美国产日韩久久mv | 骚片av蜜桃精品一区 | 在线亚洲高清揄拍自拍一品区 | 国产精品二区一区二区aⅴ污介绍 | 国产成人一区二区三区别 | 精品欧美一区二区三区久久久 | 久久综合激激的五月天 | 久久国产劲爆∧v内射 | 午夜嘿嘿嘿影院 | 欧美日韩视频无码一区二区三 | 亚洲综合另类小说色区 | 国产69精品久久久久app下载 | 99国产欧美久久久精品 | 香蕉久久久久久av成人 | 国产三级久久久精品麻豆三级 | 成在人线av无码免观看麻豆 | 亚洲va欧美va天堂v国产综合 | 久久亚洲a片com人成 | 黄网在线观看免费网站 | 熟妇人妻无乱码中文字幕 | 性欧美疯狂xxxxbbbb | 成人无码视频免费播放 | 国产在热线精品视频 | 亚洲综合另类小说色区 | 中文字幕av无码一区二区三区电影 | 大乳丰满人妻中文字幕日本 | 欧美日本免费一区二区三区 | 鲁鲁鲁爽爽爽在线视频观看 | 国产精品18久久久久久麻辣 | 久久久精品欧美一区二区免费 | 日本熟妇人妻xxxxx人hd | 国产精品igao视频网 | 欧美熟妇另类久久久久久多毛 | 国产69精品久久久久app下载 | 在线a亚洲视频播放在线观看 | 天下第一社区视频www日本 | 两性色午夜免费视频 | 无遮挡国产高潮视频免费观看 | 小sao货水好多真紧h无码视频 | 色综合久久久无码网中文 | 装睡被陌生人摸出水好爽 | 久久综合香蕉国产蜜臀av | 无码av最新清无码专区吞精 | 亚洲成av人综合在线观看 | 国产精品人人爽人人做我的可爱 | 999久久久国产精品消防器材 | 日本大香伊一区二区三区 | 色综合久久久久综合一本到桃花网 | 亚洲国产日韩a在线播放 | 亚洲性无码av中文字幕 | 久久99久久99精品中文字幕 | 国产精品怡红院永久免费 | 亚拍精品一区二区三区探花 | 免费无码av一区二区 | 欧美丰满少妇xxxx性 | 国产精品香蕉在线观看 | 乱人伦人妻中文字幕无码久久网 | 国产无套粉嫩白浆在线 | 国产乱人伦偷精品视频 | 日韩在线不卡免费视频一区 | 久久久精品456亚洲影院 | 亚洲国产精品无码久久久久高潮 | 色一情一乱一伦一区二区三欧美 | 清纯唯美经典一区二区 | 欧美性猛交内射兽交老熟妇 | 日本丰满熟妇videos | 日本一区二区三区免费高清 | 免费视频欧美无人区码 | 日本熟妇乱子伦xxxx | 国产精品99久久精品爆乳 | 永久免费观看美女裸体的网站 | 激情国产av做激情国产爱 | 欧美国产日产一区二区 | 狠狠躁日日躁夜夜躁2020 | 美女扒开屁股让男人桶 | 欧美老妇交乱视频在线观看 | 亚洲精品午夜无码电影网 | 成人无码影片精品久久久 | 99国产欧美久久久精品 | 欧美老妇交乱视频在线观看 | 欧美亚洲国产一区二区三区 | 一本久道久久综合狠狠爱 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 亚洲中文字幕无码中文字在线 | 欧美熟妇另类久久久久久多毛 | 丰满护士巨好爽好大乳 | 天下第一社区视频www日本 | 国产内射爽爽大片视频社区在线 | 亚洲无人区一区二区三区 | 水蜜桃av无码 | 奇米影视888欧美在线观看 | 精品亚洲韩国一区二区三区 | 高潮毛片无遮挡高清免费 | 日产国产精品亚洲系列 | 国产精品久久久久无码av色戒 | yw尤物av无码国产在线观看 | 亚洲 另类 在线 欧美 制服 | 天天拍夜夜添久久精品 | 强伦人妻一区二区三区视频18 | 小鲜肉自慰网站xnxx | 窝窝午夜理论片影院 | 亚洲另类伦春色综合小说 | 久久精品视频在线看15 | 精品无码一区二区三区的天堂 | 亚洲娇小与黑人巨大交 | 亚洲春色在线视频 | av无码久久久久不卡免费网站 | 少女韩国电视剧在线观看完整 | 丝袜 中出 制服 人妻 美腿 | 亚洲欧美日韩国产精品一区二区 | 国产熟妇高潮叫床视频播放 | 扒开双腿吃奶呻吟做受视频 | 帮老师解开蕾丝奶罩吸乳网站 | 中文字幕人妻无码一夲道 | 国产成人无码av一区二区 | 一个人看的视频www在线 | 乱人伦中文视频在线观看 | 亚洲另类伦春色综合小说 | 久久99精品国产.久久久久 | 欧美成人午夜精品久久久 | 一本久道久久综合婷婷五月 | 亚洲欧洲日本无在线码 | 国产精品二区一区二区aⅴ污介绍 | 少妇太爽了在线观看 | 男女下面进入的视频免费午夜 | 亚洲一区av无码专区在线观看 | 成人性做爰aaa片免费看不忠 | 丰满少妇弄高潮了www | 国产成人无码区免费内射一片色欲 | 亚洲乱码日产精品bd | 国产av一区二区三区最新精品 | 老子影院午夜伦不卡 | 人人妻人人藻人人爽欧美一区 | 欧美国产日韩久久mv | 欧美真人作爱免费视频 | 最近中文2019字幕第二页 | 色婷婷综合激情综在线播放 | 性史性农村dvd毛片 | 天天摸天天透天天添 | 色老头在线一区二区三区 | 丰满妇女强制高潮18xxxx | 少妇久久久久久人妻无码 | 亚洲欧洲无卡二区视頻 | 国产人妻人伦精品 | 久9re热视频这里只有精品 | 国产69精品久久久久app下载 | 精品欧洲av无码一区二区三区 | 无码人妻丰满熟妇区毛片18 | 亚洲国产av精品一区二区蜜芽 | 伊人久久婷婷五月综合97色 | 色诱久久久久综合网ywww | 亚洲色偷偷偷综合网 | 久久久久av无码免费网 | 精品亚洲成av人在线观看 | 亚洲男女内射在线播放 | 国内丰满熟女出轨videos | 国产人妻久久精品二区三区老狼 | 在线精品亚洲一区二区 | 日韩精品一区二区av在线 | 久久久亚洲欧洲日产国码αv | 成人无码精品1区2区3区免费看 | 狠狠cao日日穞夜夜穞av | 人妻少妇精品久久 | 国产在线精品一区二区高清不卡 | 欧美性猛交内射兽交老熟妇 | 欧美丰满熟妇xxxx性ppx人交 | 沈阳熟女露脸对白视频 | 欧美性生交活xxxxxdddd | 十八禁视频网站在线观看 | 真人与拘做受免费视频 | 久久国产劲爆∧v内射 | 麻豆国产丝袜白领秘书在线观看 | 亚洲精品综合一区二区三区在线 | 四虎国产精品一区二区 | 未满成年国产在线观看 | www国产亚洲精品久久网站 | 国产免费久久精品国产传媒 | 无码一区二区三区在线观看 | 中文字幕精品av一区二区五区 | 无码任你躁久久久久久久 | 国产在线精品一区二区三区直播 | 99久久婷婷国产综合精品青草免费 | 日韩av无码一区二区三区不卡 | 桃花色综合影院 | 国产熟妇高潮叫床视频播放 | 国产精品自产拍在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 老熟妇仑乱视频一区二区 | 国产乱子伦视频在线播放 | 鲁大师影院在线观看 | 无码人妻丰满熟妇区毛片18 | 成人精品一区二区三区中文字幕 | yw尤物av无码国产在线观看 | 免费观看激色视频网站 | 中文字幕人妻丝袜二区 | 国产成人亚洲综合无码 | 久久精品国产亚洲精品 | 东京热男人av天堂 | 国产精品无码永久免费888 | 国产亚av手机在线观看 | 日韩无套无码精品 | 日日噜噜噜噜夜夜爽亚洲精品 | 7777奇米四色成人眼影 | 日本精品高清一区二区 | 捆绑白丝粉色jk震动捧喷白浆 | 色综合久久久无码中文字幕 | 日韩人妻无码一区二区三区久久99 | 国产精品久久久久影院嫩草 | 女人被男人爽到呻吟的视频 | 亚洲综合色区中文字幕 | yw尤物av无码国产在线观看 | 亚洲性无码av中文字幕 | 欧美国产日韩亚洲中文 | 久久国语露脸国产精品电影 | 中文字幕乱妇无码av在线 | 欧美日韩久久久精品a片 | 国产精品人人妻人人爽 | 亚洲欧美日韩综合久久久 | 人人妻人人澡人人爽精品欧美 | 最新国产乱人伦偷精品免费网站 | av在线亚洲欧洲日产一区二区 | 中文字幕乱码人妻无码久久 | 激情综合激情五月俺也去 | 午夜男女很黄的视频 | 欧美成人午夜精品久久久 | 亚洲熟妇色xxxxx亚洲 | 久久久精品国产sm最大网站 | 最近免费中文字幕中文高清百度 | а天堂中文在线官网 | 久久人人爽人人爽人人片ⅴ | 高潮毛片无遮挡高清免费视频 | 亚洲欧洲中文日韩av乱码 | 亚洲成av人片在线观看无码不卡 | v一区无码内射国产 | 午夜精品久久久久久久久 | 中文字幕av伊人av无码av | 久久久精品国产sm最大网站 | 国产明星裸体无码xxxx视频 | 黑人巨大精品欧美黑寡妇 | 亚洲一区二区三区播放 | 无码成人精品区在线观看 | 久久99精品国产.久久久久 | 欧美日韩视频无码一区二区三 | 久久精品国产日本波多野结衣 | 日本大乳高潮视频在线观看 | 麻豆av传媒蜜桃天美传媒 | 成人欧美一区二区三区黑人 | 国产亚洲视频中文字幕97精品 | 亚洲va中文字幕无码久久不卡 | 亚洲精品中文字幕 | 99在线 | 亚洲 | 色欲av亚洲一区无码少妇 | 国产成人久久精品流白浆 | 无码人妻少妇伦在线电影 | 亚洲无人区午夜福利码高清完整版 | 亚洲 a v无 码免 费 成 人 a v | 熟女少妇在线视频播放 | 无套内谢的新婚少妇国语播放 | 国产又爽又黄又刺激的视频 | 高潮毛片无遮挡高清免费 | 亚洲s码欧洲m码国产av | 久久亚洲a片com人成 | 成人欧美一区二区三区黑人免费 | 国产va免费精品观看 | 窝窝午夜理论片影院 | 日日摸日日碰夜夜爽av | 捆绑白丝粉色jk震动捧喷白浆 | 国产免费无码一区二区视频 | 国内精品一区二区三区不卡 | 亚洲の无码国产の无码影院 | 久久久www成人免费毛片 | 亚洲精品国产精品乱码视色 | 日本xxxx色视频在线观看免费 | 国产人妻大战黑人第1集 | 欧美三级不卡在线观看 | 97无码免费人妻超级碰碰夜夜 | √8天堂资源地址中文在线 | 久久久久久亚洲精品a片成人 | 久久精品人人做人人综合试看 | 国产黄在线观看免费观看不卡 | 人人澡人人妻人人爽人人蜜桃 | 精品偷自拍另类在线观看 | 人妻无码αv中文字幕久久琪琪布 | 久久国产精品偷任你爽任你 | 波多野结衣aⅴ在线 | 捆绑白丝粉色jk震动捧喷白浆 | 国产在热线精品视频 | 日韩 欧美 动漫 国产 制服 | 亚洲中文字幕在线观看 | 国产精品无码永久免费888 | 中文无码成人免费视频在线观看 | 欧美日本精品一区二区三区 | 国产欧美熟妇另类久久久 | 无码人妻丰满熟妇区毛片18 | 国产 浪潮av性色四虎 | 精品厕所偷拍各类美女tp嘘嘘 | 在线观看国产午夜福利片 | 最近中文2019字幕第二页 | 水蜜桃av无码 | 欧美日韩人成综合在线播放 | 99久久精品日本一区二区免费 | 精品偷拍一区二区三区在线看 | 亚洲日韩av一区二区三区四区 | 亚洲精品久久久久中文第一幕 | 久久国产精品偷任你爽任你 | 精品夜夜澡人妻无码av蜜桃 | 精品国偷自产在线 | 久久亚洲精品成人无码 | 给我免费的视频在线观看 | 无遮挡国产高潮视频免费观看 | 国产激情无码一区二区 | 国产免费久久久久久无码 | 思思久久99热只有频精品66 | 性欧美videos高清精品 | 欧洲精品码一区二区三区免费看 | 亚洲精品一区二区三区大桥未久 | 日韩av无码中文无码电影 | 成人女人看片免费视频放人 | 无码人妻精品一区二区三区不卡 | 国产av一区二区三区最新精品 | 国产乱人伦av在线无码 | 亚洲精品一区二区三区在线观看 | 国内少妇偷人精品视频 | 丝袜美腿亚洲一区二区 | 久久亚洲中文字幕精品一区 | 久久精品国产日本波多野结衣 | 欧美亚洲国产一区二区三区 | 蜜桃视频韩日免费播放 | 国产麻豆精品精东影业av网站 | 天下第一社区视频www日本 | 日本丰满护士爆乳xxxx | 伊人久久大香线焦av综合影院 | 亚洲国产精品久久久天堂 | 天天av天天av天天透 | 亚洲色大成网站www国产 | 亚洲色欲色欲天天天www | 久9re热视频这里只有精品 | 欧美性猛交内射兽交老熟妇 | 97精品国产97久久久久久免费 | 人妻少妇精品无码专区动漫 | 国产精品无码久久av | 夜夜躁日日躁狠狠久久av | 一本色道婷婷久久欧美 | 久久国语露脸国产精品电影 | 日本xxxx色视频在线观看免费 | 亚洲色在线无码国产精品不卡 | 午夜精品久久久久久久 | 亚洲人成影院在线观看 | 无套内谢的新婚少妇国语播放 | 亚洲а∨天堂久久精品2021 | 欧美丰满老熟妇xxxxx性 | 无码av免费一区二区三区试看 | www成人国产高清内射 | 最近中文2019字幕第二页 | 亚洲爆乳精品无码一区二区三区 | 日本饥渴人妻欲求不满 | 97人妻精品一区二区三区 | 久久久久免费精品国产 | 国产在线精品一区二区三区直播 | 亚洲人成网站色7799 | 国产精品99久久精品爆乳 | 成人免费视频一区二区 | 日韩亚洲欧美精品综合 | 蜜桃视频插满18在线观看 | 欧洲极品少妇 | 亚洲s码欧洲m码国产av | 伊人久久大香线蕉午夜 | 久久久久se色偷偷亚洲精品av | 国产精品久久久午夜夜伦鲁鲁 | 色综合久久久无码网中文 | 18禁黄网站男男禁片免费观看 | 久久综合狠狠综合久久综合88 | 精品国产一区av天美传媒 | 2019nv天堂香蕉在线观看 | 免费男性肉肉影院 | 激情五月综合色婷婷一区二区 | 强开小婷嫩苞又嫩又紧视频 | 人妻少妇精品无码专区动漫 | 中文字幕久久久久人妻 | 18黄暴禁片在线观看 | 日本乱人伦片中文三区 | 在线 国产 欧美 亚洲 天堂 | 午夜福利一区二区三区在线观看 | 中文字幕无码av波多野吉衣 | 99久久99久久免费精品蜜桃 | 国产偷自视频区视频 | 亚洲午夜福利在线观看 | 中文无码成人免费视频在线观看 | 亚洲欧洲无卡二区视頻 | 欧美激情综合亚洲一二区 | 亚洲爆乳大丰满无码专区 | 亚洲成av人影院在线观看 | 玩弄中年熟妇正在播放 | 在线天堂新版最新版在线8 | 亚洲人成无码网www | 欧美阿v高清资源不卡在线播放 | 亚洲欧洲无卡二区视頻 | 国产97色在线 | 免 | 日韩精品成人一区二区三区 | 精品一二三区久久aaa片 | 内射爽无广熟女亚洲 | 亚洲国产高清在线观看视频 | 国产真人无遮挡作爱免费视频 | 精品久久综合1区2区3区激情 | 国产极品美女高潮无套在线观看 | 国产suv精品一区二区五 | 中文毛片无遮挡高清免费 | 亚洲中文字幕无码中字 | 六十路熟妇乱子伦 | 久久精品国产大片免费观看 | 久精品国产欧美亚洲色aⅴ大片 | 影音先锋中文字幕无码 | 又色又爽又黄的美女裸体网站 | 国产人妻精品一区二区三区不卡 | 午夜精品一区二区三区的区别 | 欧美国产日韩久久mv | 欧美野外疯狂做受xxxx高潮 | 精品偷自拍另类在线观看 | 奇米影视7777久久精品人人爽 | 中文字幕乱码人妻二区三区 | 亚洲精品国产精品乱码视色 | 日本饥渴人妻欲求不满 |