日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python 全栈开发,Day116(可迭代对象,type创建动态类,偏函数,面向对象的封装,获取外键数据,组合搜索,领域驱动设计(DDD))...

發布時間:2024/4/15 python 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 全栈开发,Day116(可迭代对象,type创建动态类,偏函数,面向对象的封装,获取外键数据,组合搜索,领域驱动设计(DDD))... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

昨日內容回顧

1. 三個類 ChangeList,封裝列表頁面需要的所有數據。StarkConfig,生成URL和視圖對應關系 + 默認配置 AdminSite,用于保存 數據庫類 和 處理該類的對象 的對應關系 + 路由分發_registry = {} 2. 知識點 inclusion_tagyieldurlencode_meta.model_name_meta.app_label深淺拷貝 QueryDict對象默認不可改 _mutable=True 生成器 路由分發:- include- ([],None,None)函數和方法的區別?Q的作用?構造復雜的查詢條件models.User.object.filter(name__contains='')models.User.object.filter(name__contains='',email__contains='')構造 or c1 = Q()c1.connector = 'OR'c1.children.append( ('name__contains','') )c1.children.append( ('email__contains','') )c2 = Q()c2.connector = 'ADN'c2.children.append( ('id__gt',2) )c3.children.append( ('age__lte',5) )c3 = Q()c3.connector = 'ADN'c3.add(c1,"ADN")c3.add(c2,"ADN")等同于(name=li or email = li) AND ( id>2 and age<=5)models.User.object.filter(con)反射 有2個地方用到了反射list_display: # 顯示指定的列 row.name getattr(row,'name')# 批量操作response = getattr(self, action_name)(request)pass繼承 class RoleConfig(StarkConfig):pass self到底是誰?反向生成URLreverse('xxx')reverse('namespace:xxx')多個namespace,也是以冒號分隔分頁(保留原搜索條件) 跳轉的url中保留_filter=原搜索條件ModelForm組件添加和修改functools- wraps,用于保留原函數的元信息(函數名/函數注釋等信息)- partial,偏函數為函數默認傳參。import functoolsdef func(a1,a2):print(a1+a2)new_func = functools.partial(func,8)new_func(7)new_func(2)new_func(8)預留可擴展位置request.GETrequest.GET.get('x')request.GET['x']request.GET.getlist('xxx')request.GET._mutable = True request.GET.copy()request.GET.urlencode()mark_safe xss攻擊是什么?跨站腳本攻擊一般用js代碼,進行攻擊。獲取cookie,模擬登錄,做非法操作!單例模式- 多個模塊之間導入- 共享同一個數據時獲取函數名__name__autodiscover_module自動發現模塊裝飾器 添加request參數,方便非視圖函數調用requestorder_by排序展示__str__在models.py中使用3. QueryDict對象 params = request.GET.copy() # 使用深copyparams._mutable = True # 允許修改 params['k1'] = 'v1' # 添加單個params.setlist('k2',[11,22]) # 添加多個 View Code

?

一、可迭代對象

什么是可迭代對象

在之前學過的容器中,許多容器都是可迭代對象,可以直接用于for…in…循環的而對象都是可迭代對象,比如:list,tuple,dict,set,str等等。

可迭代對象滿足條件:實現了__iter__方法

?

注意:__iter__方法必須返回一個迭代器(iter)

?

可迭代對象并不是一種具體的數據類型,比如list是可迭代對象,dict也是可迭代對象。

如何判斷一個對象是否是可迭代對象? 使用isinstance()函數

from collections import Iterablea = isinstance("123",Iterable) b = isinstance(1,Iterable) print(a) #字符串是不是可迭代對象 返回True print(b) #數字是不是可迭代對象 返回False

?

舉例1

看下面一段代碼

class Foo(object):passobj = Foo() for item in obj:print(item)

執行報錯:

TypeError: 'Foo' object is not iterable

提示不可迭代,怎么讓它可以迭代?

先來看可迭代對象滿足條件:實現了__iter__方法

?

那么在類中,定義一個__iter__方法,返回迭代器就可以了!

class Foo(object):def __iter__(self):# return iter([11,22,33,44]) # 返回迭代器yield 11 # 返回生成器(迭代器的一種)obj = Foo() for item in obj:print(item)

執行輸出: 11

?

舉例2

這是汽車之家的篩選頁面,每一個行的數據是循環展示的!如何構造這些數據?

方法一:使用字典

data_list= [['1.0以下','1.1-1.6'],['汽油','柴油','混合動力','電動'], ]for row in data_list:for field in row:print(field)

執行輸出:

1.0以下 1.1-1.6 汽油 柴油 混合動力 電動 View Code

?

方法二:使用對象+yield

class Row(object):def __init__(self,data):self.data = datadef __iter__(self):for item in self.data:yield itemdata_list= [Row(['1.0以下','1.1-1.6']),Row(['汽油','柴油','混合動力','電動']), ]for row in data_list:for field in row:print(field) View Code

執行輸出,效果同上!

?

為什么要用對象構造數據?因為要構造更復雜的數據結構!

class Row(object):def __init__(self,data):self.data = datadef __iter__(self):yield "<div>"yield '全部'for item in self.data:yield "<a href='/index/?p1=1.0'>%s</a>" %itemyield "</div>"data_list= [Row(['1.0以下','1.1-1.6']),Row(['汽油','柴油','混合動力','電動']), ]for row in data_list:for field in row:print(field) View Code

執行輸出:

<div> 全部 <a href='/index/?p1=1.0'>1.0以下</a> <a href='/index/?p1=1.0'>1.1-1.6</a> </div> <div> 全部 <a href='/index/?p1=1.0'>汽油</a> <a href='/index/?p1=1.0'>柴油</a> <a href='/index/?p1=1.0'>混合動力</a> <a href='/index/?p1=1.0'>電動</a> </div> View Code

可以看出,這段數據,比上面的復雜!

如果用列表,那么有很多if判斷!使用類,2層for循環就出來了!

為什么要輸出a標簽?因為前端渲染麻煩,后端生成a標簽。前端容易展示,還可以做一些復雜的需求!

?

二、type創建動態類

前戲

舉例1

def gen_cls():class Foo(object):passreturn Foocls = gen_cls()print(cls) View Code

執行輸出:

<class '__main__.gen_cls.<locals>.Foo'>

對象是由類創建的。那么類是由誰創建的?先帶著這個疑問

舉例2

name = "Foo" country = "中國" detail = lambda self, x: x + 1

根據以上三個參數創建一個類,類中有兩個成員。實現的效果如下:

class Foo(object):country = '中國'def detail(self,x):return x + 1

如何用代碼實現呢?

不能這么寫

class name(object):country = '中國'...

那么class名就是name了,需要使用type

?

type創建動態類

type還有一種完全不同的功能,動態的創建類。

type可以接受一個類的描述作為參數,然后返回一個類。(要知道,根據傳入參數的不同,同一個函數擁有兩種完全不同的用法是一件很傻的事情,但這在Python中是為了保持向后兼容性)

?

type可以像這樣工作:

type(類名,由父類名稱組成的元組(針對繼承的情況,可以為空),包含屬性的字典(名稱和值))?

根據上面的3個條件,使用type創建一個類

name = "Foo" country = "中國" detail = lambda self, x: x + 1 # 使用type創建動態類 cls = type(name, (object,), {'country': '中國', 'detail': lambda self, x: x + 1})obj = cls() print(obj) print(obj.country) print(obj.detail(100)) View Code

執行輸出:

<__main__.Foo object at 0x000001E0FBF2DA20> 中國 101

根據條件,由type動態創建了一個類。類的基本操作,比如實例化,獲取靜態字段,傳參,都沒有問題!

?

函數type實際上是一個元類。type就是Python在背后用來創建所有類的元類。type就是Python的內建元類

總結:對象是由類創建的。那么類默認是由type創建的

?

三、偏函數

什么是偏函數

偏函數是2.5版本以后引進來的東西。屬于函數式編程的一部分,使用偏函數可以通過有效地"凍結"那些預先確定的參數,來緩存函數參數,然后在運行時,當獲得需要的剩余參數后,可以將他們解凍,傳遞到最終的參數中,從而使用最終確定的所有參數去調用函數。

舉例

示例函數

def func(a1,a2):return a1+a2res = func(1,3) print(res)

執行輸出:4

使用偏函數

import functools def func(a1,a2):return a1+a2# 相當于給第一個參數,設置默認參數8 new_func = functools.partial(func,8) # 傳入第二個參數 res = new_func(7) print(res)

執行輸出:15

?

func有2個參數,怎么確定是給第一個參數,設置了默認參數?

import functools def func(a1,a2=22):return a1+a2# 相當于給第一個參數,設置默認參數8 new_func = functools.partial(func,8) # 傳入第二個參數 res = new_func(7) print(res)

執行輸出:15

注意:a1直接設置默認參數,是會報錯的!默認參數必須在位置參數的后面!

在flask中,會用到偏函數

?

四、面向對象的封裝

看下面一段數據

list_filter = ['全智賢','高圓圓','胡歌',]

如何用代碼區分性別?

?

第一種方法:使用字典

list_filter = [{'name':'全智賢','sex':''},{'name':'高圓圓','sex':''},{'name':'胡歌','sex':''}, ]

再區分衣服的顏色呢?

list_filter = [{'name':'全智賢','sex':'','color':'pink'},{'name':'高圓圓','sex':'','color':'red'},{'name':'胡歌','sex':'','color':'black'}, ]

如果還有其它屬性呢?繼續加?

使用字典也是一個封裝思想

?

第二種方法:使用類(推薦)

class Option(object):def __init__(self,name,sex,color):self.name = nameself.sex = sexself.color = colorlist_filter = [# 字典對象做封裝Option(name='全智賢',sex='',color = 'pink'),Option(name='高圓圓',sex='',color = 'red'),Option(name='胡歌',sex='',color = 'black'), ]for item in list_filter:print(item.__dict__) View Code

執行輸出:

{'name': '全智賢', 'color': 'pink', 'sex': ''} {'name': '高圓圓', 'color': 'red', 'sex': ''} {'name': '胡歌', 'color': 'black', 'sex': ''}

通過這2種方法對比,使用類更好一點!

如果使用字典,那么第一條數據,加了一個參數。而另外2條數據,卻沒有加!

那么頁面展示就會錯亂!

而使用類,則不會這個情況!另外一點,使用類,可以構造更加復雜的數據結構!

使用類,是新的 封裝思想。可擴展功能比較方便

?

五、獲取外鍵數據

外鍵分為3種:?FK/M2M/O2O,分別對應一對多,多對多,一對一

給定2個參數

model_class = Depart # 模型表類 _field = "user" # 外鍵字段

要獲取外鍵字段對應的所有數據,如何獲取?

?

新建項目untitled4,注意:django版本為1.11

?

修改models.py,新建2個表

from django.db import models# Create your models here. class UserInfo(models.Model):title = models.CharField(verbose_name='標題',max_length=32)def __str__(self):return self.titleclass Depart(models.Model):name = models.CharField(verbose_name='部門名稱',max_length=32)tel = models.CharField(verbose_name='聯系電話',max_length=32)user = models.ForeignKey(verbose_name='負責人',to='UserInfo')def __str__(self):return self.name View Code

使用2個命令生成表

python manage.py makemigrations python manage.py migrate

?

增加數據,使用Navicat打開sqlite3數據庫,執行sql語句

INSERT INTO "app01_depart" ("name", "tel", "user_id") VALUES ('總經理', 23456342, 1); INSERT INTO "app01_depart" ("name", "tel", "user_id") VALUES ('技術部', 34565422, 1); INSERT INTO "app01_depart" ("name", "tel", "user_id") VALUES ('運營部', 34344523, 2);INSERT INTO "app01_userinfo" ("title") VALUES ('xiao'); INSERT INTO "app01_userinfo" ("title") VALUES ('zhang'); View Code

?

修改urls.py,增加路徑

from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [url(r'^admin/', admin.site.urls),url(r'^index/', views.index), ] View Code

?

修改views.py,增加視圖函數

from django.shortcuts import render,HttpResponse from app01 import models # Create your views here. def index(request):# 外鍵對象,通過get_field獲取fk_obj = models.Depart._meta.get_field("user")print(fk_obj,type(fk_obj))# .all表示獲取所有數據user_info_queryset = fk_obj.rel.model.objects.all()print(user_info_queryset)for i in user_info_queryset:print('row:',i) # 打印每一個行的數據return HttpResponse('...') View Code

啟動django項目,訪問首頁

查看Pycharm控制臺輸出:

app01.Depart.user <class 'django.db.models.fields.related.ForeignKey'> <QuerySet [<UserInfo: xiao>, <UserInfo: zhang>]> row: xiao row: zhang

注意:FK/M2M/O2O都是通過get_field來獲取的

?

六、組合搜索

展示頁面

務必下載github代碼:

https://github.com/987334176/luffy_stark/archive/v1.2.zip

因為下面的內容,都是這份代碼來修改的!

?

修改?stark-->templates-->stark-->changelist.html

{% extends 'stark/layout.html' %} {% load stark %}{% block css %}<style>.comb-search {padding: 5px 20px;}.comb-search .row .whole {width: 60px;float: left;}.comb-search .row .others {padding-left: 60px;}.comb-search .row a {display: inline-block;padding: 5px 8px;margin: 3px;border: 1px solid #d4d4d4; }.comb-search .row a {display: inline-block;padding: 5px 8px;margin: 3px;border: 1px solid #d4d4d4; }.comb-search a.active {color: #fff;background-color: #337ab7;border-color: #2e6da4; }</style> {% endblock %} {% block content %}<div>{#組合搜索#}<div class="comb-search"><div class="row"><div class="whole"><a href="#">全部</a></div><div class="others"><a href="#">條件1</a><a href="#">條件2</a><a href="#">條件3</a></div></div></div>{#添加按鈕#}{% if cl.add_btn %}<div style="margin: 5px 0;">{{ cl.add_btn }}</div>{% endif %}{#搜索框#}{% if cl.search_list %}<div style="float: right;"><form method="GET" class="form-inline"><div class="form-group"><input class="form-control" type="text" name="q" value="{{ cl.q }}" placeholder="關鍵字搜索"><button class="btn btn-primary" type="submit"><i class="fa fa-search" aria-hidden="true"></i></button></div></form></div>{% endif %}<form class="form-inline" method="post">{% csrf_token %}{#批量操作#}{% if cl.action_list %}<div class="form-group"><select name="action" class="form-control" style="min-width: 200px;"><option>請選擇功能</option>{% for item in cl.action_list %}<option value="{{ item.name }}">{{ item.text }}</option>{% endfor %}</select><input class="btn btn-primary" type="submit" value="執行"></div>{% endif %}{#使用table展示數據#}{% table cl %}{#分頁展示#}<nav aria-label="Page navigation"><ul class="pagination">{{ cl.page.page_html|safe }}</ul></nav></form></div>{% endblock %} View Code

訪問url:?http://127.0.0.1:8000/stark/app01/depart/list/

效果如下:

?

修改 stark-->server-->stark.py,增加變量 list_filter,增加一個鉤子函數?get_list_filter

使用get_field獲取字段

import functools from django.conf.urls import url from django.shortcuts import HttpResponse,render,redirect from types import FunctionType from django.utils.safestring import mark_safe from django.urls import reverse from django import forms from django.db.models import Q from django.http import QueryDictclass ChangeList(object):"""封裝列表頁面需要的所有功能"""def __init__(self,config,queryset,q,search_list,page):### 處理搜索 ###self.q = q # 搜索條件self.search_list = search_list # 搜索字段self.page = page # 分頁# 配置參數self.config = config# 批量操作self.action_list = [{'name': func.__name__, 'text': func.text} for func in config.get_action_list()]# 添加按鈕self.add_btn = config.get_add_btn()# ORM執行結果self.queryset = queryset# 顯示的列self.list_display = config.get_list_display()class StarkConfig(object):def __init__(self,model_class,site):self.model_class = model_classself.site = site# 定義request變量,用于非視圖函數使用。# 在wrapper裝飾器中,對這個值重新賦值!self.request = None# url中的搜索條件,存在字典中。key為_filterself.back_condition_key = "_filter"def display_checkbox(self,row=None,header=False): # 顯示復選框if header:# 輸出中文return "選擇"# 注意:這里要寫row.pk,不能寫row.id。你不能保證每一個表的主鍵都是idreturn mark_safe("<input type='checkbox' name='pk' value='%s' />" % row.pk)def display_edit(self, row=None, header=False):if header:return "編輯"return mark_safe('<a href="%s"><i class="fa fa-edit" aria-hidden="true"></i></a></a>' % self.reverse_edit_url(row))def display_del(self, row=None, header=False):if header:return "刪除"return mark_safe('<a href="%s"><i class="fa fa-trash-o" aria-hidden="true"></i></a>' % self.reverse_del_url(row))def display_edit_del(self, row=None, header=False):if header:return "操作"tpl = """<a href="%s"><i class="fa fa-edit" aria-hidden="true"></i></a></a> |<a href="%s"><i class="fa fa-trash-o" aria-hidden="true"></i></a>""" % (self.reverse_edit_url(row), self.reverse_del_url(row),)return mark_safe(tpl)def multi_delete(self, request): # 批量刪除"""批量刪除的action:param request::return:"""pk_list = request.POST.getlist('pk')self.model_class.objects.filter(pk__in=pk_list).delete()# return HttpResponse('刪除成功') multi_delete.text = "批量刪除" # 添加自定義屬性textdef multi_init(self,request): # 批量初始化print('批量初始化')multi_init.text = "批量初始化" # 添加自定義屬性text order_by = [] # 需要排序的字段,由用戶自定義list_display = [] # 定義顯示的列,由用戶自定義model_form_class = None # form組件需要的model_classaction_list = [] # 批量操作方法# 搜索字段,如果是跨表字段,要按照ORM語法來search_list = []list_filter = [] # 組合搜索def get_order_by(self): # 獲取排序列表return self.order_bydef get_list_display(self): # 獲取顯示的列return self.list_displaydef get_add_btn(self): # 顯示添加按鈕return mark_safe('<a href="%s" class="btn btn-success">添加</a>' % self.reverse_add_url())def get_model_form_class(self):"""獲取ModelForm類:return:"""if self.model_form_class:return self.model_form_classclass AddModelForm(forms.ModelForm):class Meta:model = self.model_classfields = "__all__"return AddModelFormdef get_action_list(self): # 獲取批量操作方法val = [] # 空列表# 擴展列表的元素 val.extend(self.action_list)return valdef get_action_dict(self): # 獲取匹配操作字典val = {}for item in self.action_list:# 以方法名為keyval[item.__name__] = itemreturn valdef get_search_list(self): # 獲取搜索字段val = []val.extend(self.search_list)return valdef get_search_condition(self, request): # 根據關鍵字,組合ORM查詢語句search_list = self.get_search_list() # ['name','tel']q = request.GET.get('q', "") # 搜索條件con = Q()con.connector = "OR" # 以OR作為連接符if q: # 判斷條件不為空for field in search_list:# 合并條件進行查詢, __contains表示使用like查詢con.children.append(('%s__contains' % field, q))return search_list, q, condef get_list_filter(self): # 獲取組合搜索條件val = []val.extend(self.list_filter)return valdef changelist_view(self, request):"""所有URL查看列表頁面:param request::return:"""if request.method == 'POST':action_name = request.POST.get('action')action_dict = self.get_action_dict()if action_name not in action_dict:return HttpResponse('非法請求')response = getattr(self, action_name)(request)if response:return response### 處理搜索 ###search_list, q, con = self.get_search_condition(request)# ##### 處理分頁 #####from stark.utils.pagination import Pagination# 總條數total_count = self.model_class.objects.filter(con).count()# 復制GET參數query_params = request.GET.copy()# 允許編輯query_params._mutable = True# 使用分頁類Pagination,傳入參數。每頁顯示3條page = Pagination(request.GET.get('page'), total_count, request.path_info, query_params, per_page=3)# 根據排序列表進行排序,以及分頁功能queryset = self.model_class.objects.filter(con).order_by(*self.get_order_by())[page.start:page.end]cl = ChangeList(self, queryset, q, search_list, page)# ######## 組合搜索 ########## list_filter = ['name','user']list_filter = self.get_list_filter()for field in list_filter:# 如果field = "name" --> 查Depart所有數據# 如果field = "user" --> 查UserInfo所有數據_field = self.model_class._meta.get_field(field)print(_field,type(_field)) # 打印字段類型 context = {'cl': cl}# 注意:要傳入參數return render(request,'stark/changelist.html',context)def add_view(self, request):"""所有的添加頁面,都在此方法處理使用ModelForm實現:param request::return:"""# 添加數據,使用ModelFormAddModelForm = self.get_model_form_class()if request.method == "GET":form = AddModelForm()return render(request,'stark/change.html',{'form':form})form = AddModelForm(request.POST) # 接收POST數據if form.is_valid(): # 驗證數據form.save() # 自動保存數據# 反向生成url,跳轉到列表頁面return redirect(self.reverse_list_url())# 渲染頁面,此時會保存表單數據return render(request, 'stark/change.html', {'form': form})def change_view(self, request, pk):"""所有編輯頁面:param request::param pk::return:"""# 查看單條數據obj = self.model_class.objects.filter(pk=pk).first()if not obj:return HttpResponse('數據不存在')# 獲取model_form類ModelFormClass = self.get_model_form_class()if request.method == 'GET':# instance表示生成默認值form = ModelFormClass(instance=obj)# 渲染頁面,添加和修改可以共用一個一個模板文件return render(request, 'stark/change.html', {'form': form})# instance = obj 表示指定給誰做修改form = ModelFormClass(data=request.POST, instance=obj)if form.is_valid():form.save() # 修改數據# 跳轉到列表頁面return redirect(self.reverse_list_url())return render(request, 'stark/change.html', {'form': form})def delete_view(self, request, pk):"""所有刪除頁面:param request::param pk::return:"""if request.method == "GET":# cancel_url表示用戶點擊取消時,跳轉到列表頁面return render(request, 'stark/delete.html', {'cancel_url': self.reverse_list_url()})# 定位單條數據,并刪除!self.model_class.objects.filter(pk=pk).delete()return redirect(self.reverse_list_url())def wrapper(self, func):@functools.wraps(func)def inner(request, *args, **kwargs):self.request = requestreturn func(request, *args, **kwargs)return innerdef get_urls(self):info = self.model_class._meta.app_label, self.model_class._meta.model_nameurlpatterns = [url(r'^list/$', self.wrapper(self.changelist_view), name='%s_%s_changelist' % info),url(r'^add/$', self.wrapper(self.add_view), name='%s_%s_add' % info),url(r'^(?P<pk>\d+)/change/', self.wrapper(self.change_view), name='%s_%s_change' % info),url(r'^(?P<pk>\d+)/del/', self.wrapper(self.delete_view), name='%s_%s_del' % info),]extra = self.extra_url()if extra: # 判斷變量不為空# 擴展路由 urlpatterns.extend(extra)# print(urlpatterns)return urlpatternsdef extra_url(self): # 額外的路由,由調用者重構passdef reverse_list_url(self): # 反向生成訪問列表的urlapp_label = self.model_class._meta.app_labelmodel_name = self.model_class._meta.model_namenamespace = self.site.namespacename = '%s:%s_%s_changelist' % (namespace, app_label, model_name)list_url = reverse(name)# 獲取當前請求的_filter參數,也就是跳轉之前的搜索條件origin_condition = self.request.GET.get(self.back_condition_key)if not origin_condition: # 如果沒有獲取到return list_url # 返回列表頁面# 列表地址和搜索條件拼接list_url = "%s?%s" % (list_url, origin_condition,)return list_urldef reverse_add_url(self): # 反向生成添加urlapp_label = self.model_class._meta.app_labelmodel_name = self.model_class._meta.model_namenamespace = self.site.namespacename = '%s:%s_%s_add' % (namespace, app_label, model_name)add_url = reverse(name)if not self.request.GET: # 判斷get參數為空return add_url # 返回原url# request.GET的數據類型為QueryDict# 對QueryDict做urlencode編碼param_str = self.request.GET.urlencode() # 比如q=xiao&age=20# 允許對QueryDict做修改new_query_dict = QueryDict(mutable=True)# 添加鍵值對. _filter = param_strnew_query_dict[self.back_condition_key] = param_str# 添加url和搜索條件做拼接add_url = "%s?%s" % (add_url, new_query_dict.urlencode(),)# 返回最終urlreturn add_urldef reverse_edit_url(self, row): # 反向生成編輯行內容的urlapp_label = self.model_class._meta.app_label # app名model_name = self.model_class._meta.model_name # 表名namespace = self.site.namespace # 命名空間# 拼接字符串,這里為changename = '%s:%s_%s_change' % (namespace, app_label, model_name)# 反向生成url,傳入參數pk=row.pkedit_url = reverse(name, kwargs={'pk': row.pk})if not self.request.GET:return edit_urlparam_str = self.request.GET.urlencode()new_query_dict = QueryDict(mutable=True)new_query_dict[self.back_condition_key] = param_stredit_url = "%s?%s" % (edit_url, new_query_dict.urlencode(),)return edit_urldef reverse_del_url(self, row): # 反向生成刪除行內容的urlapp_label = self.model_class._meta.app_labelmodel_name = self.model_class._meta.model_namenamespace = self.site.namespace# 注意:這里為delname = '%s:%s_%s_del' % (namespace, app_label, model_name)del_url = reverse(name, kwargs={'pk': row.pk})if not self.request.GET:return del_urlparam_str = self.request.GET.urlencode()new_query_dict = QueryDict(mutable=True)new_query_dict[self.back_condition_key] = param_strdel_url = "%s?%s" % (del_url, new_query_dict.urlencode(),)return del_url@propertydef urls(self):return self.get_urls()class AdminSite(object):def __init__(self):self._registry = {}self.app_name = 'stark'self.namespace = 'stark'def register(self,model_class,stark_config=None):# not None的結果為Tureif not stark_config:# 也就是說,當其他應用調用register時,如果不指定stark_config參數# 那么必然執行下面這段代碼!# stark_config和StarkConfig是等值的!都能實例化stark_config = StarkConfig# 添加鍵值對,實例化類StarkConfig,傳入參數model_class# self指的是AdminSite類self._registry[model_class] = stark_config(model_class,self)# print(self._registry) # 打印字典"""{app01.models.UserInfo:StarkConfig(app01.models.UserInfo)app02.models.Role:RoleConfig(app02.models.Role)}"""# for k, v in self._registry.items():# print(k,v)def get_urls(self):urlpatterns = []for k, v in self._registry.items():# k=modes.UserInfo,v=StarkConfig(models.UserInfo), # 封裝:model_class=UserInfo,site=site對象# k=modes.Role,v=RoleConfig(models.Role) # 封裝:model_class=Role,site=site對象app_label = k._meta.app_labelmodel_name = k._meta.model_nameurlpatterns.append(url(r'^%s/%s/' % (app_label, model_name,), (v.urls, None, None)))return urlpatterns@propertydef urls(self):# 調用get_urls方法# self.app_name和self.namespace值是一樣的,都是starkreturn self.get_urls(), self.app_name, self.namespacesite = AdminSite() # 實例化類 View Code

?

修改 app01-->stark.py,增加list_filter屬性

from stark.server.stark import site, StarkConfig from app01 import models from django import forms from django.shortcuts import render from django.conf.urls import urlclass UserInfoConfig(StarkConfig):list_display = ['id', 'username']class DepartModelForm(forms.ModelForm):class Meta:model = models.Departfields = "__all__"def clean_name(self): # 定義鉤子# print(self.cleaned_data['name'])return self.cleaned_data['name']class DepartConfig(StarkConfig):list_display = [StarkConfig.display_checkbox,'id','name', 'tel', 'user',StarkConfig.display_edit_del]# model_form_class = DepartModelForm# 批量操作action_list = [StarkConfig.multi_delete,StarkConfig.multi_init]# 搜索字段,如果是跨表字段,要按照ORM語法來search_list = ['name', 'tel', 'user__username']list_filter = ["name","user"] # 組合搜索# def get_add_btn(self): # 返回None,表示不顯示添加按鈕# pass# def changelist_view(self, request): # 重寫changelist_view方法# # 渲染自定義的列表頁面# return render(request,'stark/custom_list.html')# def get_urls(self): # 自定義路由# info = self.model_class._meta.app_label, self.model_class._meta.model_name# # urlpatterns = [# url(r'^list/$', self.changelist_view, name='%s_%s_changelist' % info),# ]# return urlpatterns site.register(models.UserInfo, UserInfoConfig) site.register(models.Depart, DepartConfig) View Code

刷新頁面,查看Pycharm控制臺輸出:

app01.Depart.name <class 'django.db.models.fields.CharField'> app01.Depart.user <class 'django.db.models.fields.related.ForeignKey'>

ForeignKey表示一對多

?

修改?stark-->server-->stark.py,導入模塊ForeignKey,判斷類型。如果是FK,就跨表查詢。

添加list_filter_rows列表,并傳給模板

import functools from django.conf.urls import url from django.shortcuts import HttpResponse,render,redirect from types import FunctionType from django.utils.safestring import mark_safe from django.urls import reverse from django import forms from django.db.models import Q from django.http import QueryDict from django.db.models.fields.related import ForeignKeyclass ChangeList(object):"""封裝列表頁面需要的所有功能"""def __init__(self,config,queryset,q,search_list,page):### 處理搜索 ###self.q = q # 搜索條件self.search_list = search_list # 搜索字段self.page = page # 分頁# 配置參數self.config = config# 批量操作self.action_list = [{'name': func.__name__, 'text': func.text} for func in config.get_action_list()]# 添加按鈕self.add_btn = config.get_add_btn()# ORM執行結果self.queryset = queryset# 顯示的列self.list_display = config.get_list_display()class StarkConfig(object):def __init__(self,model_class,site):self.model_class = model_classself.site = site# 定義request變量,用于非視圖函數使用。# 在wrapper裝飾器中,對這個值重新賦值!self.request = None# url中的搜索條件,存在字典中。key為_filterself.back_condition_key = "_filter"def display_checkbox(self,row=None,header=False): # 顯示復選框if header:# 輸出中文return "選擇"# 注意:這里要寫row.pk,不能寫row.id。你不能保證每一個表的主鍵都是idreturn mark_safe("<input type='checkbox' name='pk' value='%s' />" % row.pk)def display_edit(self, row=None, header=False):if header:return "編輯"return mark_safe('<a href="%s"><i class="fa fa-edit" aria-hidden="true"></i></a></a>' % self.reverse_edit_url(row))def display_del(self, row=None, header=False):if header:return "刪除"return mark_safe('<a href="%s"><i class="fa fa-trash-o" aria-hidden="true"></i></a>' % self.reverse_del_url(row))def display_edit_del(self, row=None, header=False):if header:return "操作"tpl = """<a href="%s"><i class="fa fa-edit" aria-hidden="true"></i></a></a> |<a href="%s"><i class="fa fa-trash-o" aria-hidden="true"></i></a>""" % (self.reverse_edit_url(row), self.reverse_del_url(row),)return mark_safe(tpl)def multi_delete(self, request): # 批量刪除"""批量刪除的action:param request::return:"""pk_list = request.POST.getlist('pk')self.model_class.objects.filter(pk__in=pk_list).delete()# return HttpResponse('刪除成功') multi_delete.text = "批量刪除" # 添加自定義屬性textdef multi_init(self,request): # 批量初始化print('批量初始化')multi_init.text = "批量初始化" # 添加自定義屬性text order_by = [] # 需要排序的字段,由用戶自定義list_display = [] # 定義顯示的列,由用戶自定義model_form_class = None # form組件需要的model_classaction_list = [] # 批量操作方法# 搜索字段,如果是跨表字段,要按照ORM語法來search_list = []list_filter = [] # 組合搜索def get_order_by(self): # 獲取排序列表return self.order_bydef get_list_display(self): # 獲取顯示的列return self.list_displaydef get_add_btn(self): # 顯示添加按鈕return mark_safe('<a href="%s" class="btn btn-success">添加</a>' % self.reverse_add_url())def get_model_form_class(self):"""獲取ModelForm類:return:"""if self.model_form_class:return self.model_form_classclass AddModelForm(forms.ModelForm):class Meta:model = self.model_classfields = "__all__"return AddModelFormdef get_action_list(self): # 獲取批量操作方法val = [] # 空列表# 擴展列表的元素 val.extend(self.action_list)return valdef get_action_dict(self): # 獲取匹配操作字典val = {}for item in self.action_list:# 以方法名為keyval[item.__name__] = itemreturn valdef get_search_list(self): # 獲取搜索字段val = []val.extend(self.search_list)return valdef get_search_condition(self, request): # 根據關鍵字,組合ORM查詢語句search_list = self.get_search_list() # ['name','tel']q = request.GET.get('q', "") # 搜索條件con = Q()con.connector = "OR" # 以OR作為連接符if q: # 判斷條件不為空for field in search_list:# 合并條件進行查詢, __contains表示使用like查詢con.children.append(('%s__contains' % field, q))return search_list, q, condef get_list_filter(self): # 獲取組合搜索條件val = []val.extend(self.list_filter)return valdef changelist_view(self, request):"""所有URL查看列表頁面:param request::return:"""if request.method == 'POST':action_name = request.POST.get('action')action_dict = self.get_action_dict()if action_name not in action_dict:return HttpResponse('非法請求')response = getattr(self, action_name)(request)if response:return response### 處理搜索 ###search_list, q, con = self.get_search_condition(request)# ##### 處理分頁 #####from stark.utils.pagination import Pagination# 總條數total_count = self.model_class.objects.filter(con).count()# 復制GET參數query_params = request.GET.copy()# 允許編輯query_params._mutable = True# 使用分頁類Pagination,傳入參數。每頁顯示3條page = Pagination(request.GET.get('page'), total_count, request.path_info, query_params, per_page=3)# 根據排序列表進行排序,以及分頁功能queryset = self.model_class.objects.filter(con).order_by(*self.get_order_by())[page.start:page.end]cl = ChangeList(self, queryset, q, search_list, page)# ######## 組合搜索 ########## list_filter = ['name','user']list_filter = self.get_list_filter()list_filter_rows = []for field in list_filter:# 如果field = "name" --> 查Depart所有數據# 如果field = "user" --> 查UserInfo所有數據_field = self.model_class._meta.get_field(field)# print(_field,type(_field)) # 打印字段類型if isinstance(_field,ForeignKey):row = _field.rel.model.objects.all()else:row = self.model_class.objects.all()list_filter_rows.append(row)context = {'cl': cl,'list_filter_rows':list_filter_rows}# 注意:要傳入參數return render(request,'stark/changelist.html',context)def add_view(self, request):"""所有的添加頁面,都在此方法處理使用ModelForm實現:param request::return:"""# 添加數據,使用ModelFormAddModelForm = self.get_model_form_class()if request.method == "GET":form = AddModelForm()return render(request,'stark/change.html',{'form':form})form = AddModelForm(request.POST) # 接收POST數據if form.is_valid(): # 驗證數據form.save() # 自動保存數據# 反向生成url,跳轉到列表頁面return redirect(self.reverse_list_url())# 渲染頁面,此時會保存表單數據return render(request, 'stark/change.html', {'form': form})def change_view(self, request, pk):"""所有編輯頁面:param request::param pk::return:"""# 查看單條數據obj = self.model_class.objects.filter(pk=pk).first()if not obj:return HttpResponse('數據不存在')# 獲取model_form類ModelFormClass = self.get_model_form_class()if request.method == 'GET':# instance表示生成默認值form = ModelFormClass(instance=obj)# 渲染頁面,添加和修改可以共用一個一個模板文件return render(request, 'stark/change.html', {'form': form})# instance = obj 表示指定給誰做修改form = ModelFormClass(data=request.POST, instance=obj)if form.is_valid():form.save() # 修改數據# 跳轉到列表頁面return redirect(self.reverse_list_url())return render(request, 'stark/change.html', {'form': form})def delete_view(self, request, pk):"""所有刪除頁面:param request::param pk::return:"""if request.method == "GET":# cancel_url表示用戶點擊取消時,跳轉到列表頁面return render(request, 'stark/delete.html', {'cancel_url': self.reverse_list_url()})# 定位單條數據,并刪除!self.model_class.objects.filter(pk=pk).delete()return redirect(self.reverse_list_url())def wrapper(self, func):@functools.wraps(func)def inner(request, *args, **kwargs):self.request = requestreturn func(request, *args, **kwargs)return innerdef get_urls(self):info = self.model_class._meta.app_label, self.model_class._meta.model_nameurlpatterns = [url(r'^list/$', self.wrapper(self.changelist_view), name='%s_%s_changelist' % info),url(r'^add/$', self.wrapper(self.add_view), name='%s_%s_add' % info),url(r'^(?P<pk>\d+)/change/', self.wrapper(self.change_view), name='%s_%s_change' % info),url(r'^(?P<pk>\d+)/del/', self.wrapper(self.delete_view), name='%s_%s_del' % info),]extra = self.extra_url()if extra: # 判斷變量不為空# 擴展路由 urlpatterns.extend(extra)# print(urlpatterns)return urlpatternsdef extra_url(self): # 額外的路由,由調用者重構passdef reverse_list_url(self): # 反向生成訪問列表的urlapp_label = self.model_class._meta.app_labelmodel_name = self.model_class._meta.model_namenamespace = self.site.namespacename = '%s:%s_%s_changelist' % (namespace, app_label, model_name)list_url = reverse(name)# 獲取當前請求的_filter參數,也就是跳轉之前的搜索條件origin_condition = self.request.GET.get(self.back_condition_key)if not origin_condition: # 如果沒有獲取到return list_url # 返回列表頁面# 列表地址和搜索條件拼接list_url = "%s?%s" % (list_url, origin_condition,)return list_urldef reverse_add_url(self): # 反向生成添加urlapp_label = self.model_class._meta.app_labelmodel_name = self.model_class._meta.model_namenamespace = self.site.namespacename = '%s:%s_%s_add' % (namespace, app_label, model_name)add_url = reverse(name)if not self.request.GET: # 判斷get參數為空return add_url # 返回原url# request.GET的數據類型為QueryDict# 對QueryDict做urlencode編碼param_str = self.request.GET.urlencode() # 比如q=xiao&age=20# 允許對QueryDict做修改new_query_dict = QueryDict(mutable=True)# 添加鍵值對. _filter = param_strnew_query_dict[self.back_condition_key] = param_str# 添加url和搜索條件做拼接add_url = "%s?%s" % (add_url, new_query_dict.urlencode(),)# 返回最終urlreturn add_urldef reverse_edit_url(self, row): # 反向生成編輯行內容的urlapp_label = self.model_class._meta.app_label # app名model_name = self.model_class._meta.model_name # 表名namespace = self.site.namespace # 命名空間# 拼接字符串,這里為changename = '%s:%s_%s_change' % (namespace, app_label, model_name)# 反向生成url,傳入參數pk=row.pkedit_url = reverse(name, kwargs={'pk': row.pk})if not self.request.GET:return edit_urlparam_str = self.request.GET.urlencode()new_query_dict = QueryDict(mutable=True)new_query_dict[self.back_condition_key] = param_stredit_url = "%s?%s" % (edit_url, new_query_dict.urlencode(),)return edit_urldef reverse_del_url(self, row): # 反向生成刪除行內容的urlapp_label = self.model_class._meta.app_labelmodel_name = self.model_class._meta.model_namenamespace = self.site.namespace# 注意:這里為delname = '%s:%s_%s_del' % (namespace, app_label, model_name)del_url = reverse(name, kwargs={'pk': row.pk})if not self.request.GET:return del_urlparam_str = self.request.GET.urlencode()new_query_dict = QueryDict(mutable=True)new_query_dict[self.back_condition_key] = param_strdel_url = "%s?%s" % (del_url, new_query_dict.urlencode(),)return del_url@propertydef urls(self):return self.get_urls()class AdminSite(object):def __init__(self):self._registry = {}self.app_name = 'stark'self.namespace = 'stark'def register(self,model_class,stark_config=None):# not None的結果為Tureif not stark_config:# 也就是說,當其他應用調用register時,如果不指定stark_config參數# 那么必然執行下面這段代碼!# stark_config和StarkConfig是等值的!都能實例化stark_config = StarkConfig# 添加鍵值對,實例化類StarkConfig,傳入參數model_class# self指的是AdminSite類self._registry[model_class] = stark_config(model_class,self)# print(self._registry) # 打印字典"""{app01.models.UserInfo:StarkConfig(app01.models.UserInfo)app02.models.Role:RoleConfig(app02.models.Role)}"""# for k, v in self._registry.items():# print(k,v)def get_urls(self):urlpatterns = []for k, v in self._registry.items():# k=modes.UserInfo,v=StarkConfig(models.UserInfo), # 封裝:model_class=UserInfo,site=site對象# k=modes.Role,v=RoleConfig(models.Role) # 封裝:model_class=Role,site=site對象app_label = k._meta.app_labelmodel_name = k._meta.model_nameurlpatterns.append(url(r'^%s/%s/' % (app_label, model_name,), (v.urls, None, None)))return urlpatterns@propertydef urls(self):# 調用get_urls方法# self.app_name和self.namespace值是一樣的,都是starkreturn self.get_urls(), self.app_name, self.namespacesite = AdminSite() # 實例化類 View Code

修改?stark-->templates-->stark-->changelist.html,for循環list_filter_rows列表

{% extends 'stark/layout.html' %} {% load stark %}{% block css %}<style>.comb-search {padding: 5px 20px;}.comb-search .row .whole {width: 60px;float: left;}.comb-search .row .others {padding-left: 60px;}.comb-search .row a {display: inline-block;padding: 5px 8px;margin: 3px;border: 1px solid #d4d4d4; }.comb-search .row a {display: inline-block;padding: 5px 8px;margin: 3px;border: 1px solid #d4d4d4; }.comb-search a.active {color: #fff;background-color: #337ab7;border-color: #2e6da4; }</style> {% endblock %} {% block content %}<div>{#組合搜索#}<div class="comb-search">{% for row in list_filter_rows %}<div class="row"><div class="whole"><a href="#">全部</a></div><div class="others">{% for obj in row %}<a href="#">{{ obj }}</a>{% endfor %}</div></div>{% endfor %}</div>{#添加按鈕#}{% if cl.add_btn %}<div style="margin: 5px 0;">{{ cl.add_btn }}</div>{% endif %}{#搜索框#}{% if cl.search_list %}<div style="float: right;"><form method="GET" class="form-inline"><div class="form-group"><input class="form-control" type="text" name="q" value="{{ cl.q }}" placeholder="關鍵字搜索"><button class="btn btn-primary" type="submit"><i class="fa fa-search" aria-hidden="true"></i></button></div></form></div>{% endif %}<form class="form-inline" method="post">{% csrf_token %}{#批量操作#}{% if cl.action_list %}<div class="form-group"><select name="action" class="form-control" style="min-width: 200px;"><option>請選擇功能</option>{% for item in cl.action_list %}<option value="{{ item.name }}">{{ item.text }}</option>{% endfor %}</select><input class="btn btn-primary" type="submit" value="執行"></div>{% endif %}{#使用table展示數據#}{% table cl %}{#分頁展示#}<nav aria-label="Page navigation"><ul class="pagination">{{ cl.page.page_html|safe }}</ul></nav></form></div>{% endblock %} View Code

刷新頁面,效果如下:

?

?

?

?

?

?

后臺搜索

?

關于后面的詳細步驟,沒有時間寫了。附上完整代碼:

鏈接:https://pan.baidu.com/s/1fLOGH_3G7hPTvCYKX84UdQ 密碼:m8rh

?

七、領域驅動設計(DDD)

什么是領域驅動設計(DDD)

2004年著名建模專家Eric Evans發表了他最具影響力的書籍:《Domain-Driven Design –Tackling Complexity in the Heart of Software》(中文譯名:領域驅動設計—軟件核心復雜性應對之道),書中提出了“領域驅動設計(簡稱 DDD)”的概念。

  領域驅動設計事實上是針對OOAD的一個擴展和延伸,DDD基于面向對象分析與設計技術,對技術架構進行了分層規劃,同時對每個類進行了策略和類型的劃分。

  領域模型是領域驅動的核心。采用DDD的設計思想,業務邏輯不再集中在幾個大型的類上,而是由大量相對小的領域對象(類)組成,這些類具備自己的狀態和行為,每個類是相對完整的獨立體,并與現實領域的業務對象映射。領域模型就是由這樣許多的細粒度的類組成?;陬I域驅動的設計,保證了系統的可維護性、擴展性和復用性,在處理復雜業務邏輯方面有著先天的優勢。

領域驅動設計的特點

領域驅動的核心應用場景就是解決復雜業務的設計問題,其特點與這一核心主題息息相關:

  • 分層架構與職責劃分:領域驅動設計很好的遵循了關注點分離的原則,提出了成熟、清晰的分層架構。同時對領域對象進行了明確的策略和職責劃分,讓領域對象和現實世界中的業務形成良好的映射關系,為領域專家與開發人員搭建了溝通的橋梁。
  • 復用:在領域驅動設計中,領域對象是核心,每個領域對象都是一個相對完整的內聚的業務對象描述,所以可以形成直接的復用。同時設計過程是基于領域對象而不是基于數據庫的Schema,所以整個設計也是可以復用的。
  • 使用場景:適合具備復雜業務邏輯的軟件系統,對軟件的可維護性和擴展性要求比較高。不適用簡單的增刪改查業務。
  • ?

    舉例:商品價格

    一個商品,有商品名(name),原價(price),折扣價(discount)。如何用類來表示呢?

    常規類

    class Goods(object):def __init__(self,name,price,discount):self.name = nameself.price = priceself.discount = discount

    如果要增加優惠券(滿減,立減,折扣),怎么辦?

    領域驅動設計

    class BaseCoupon(object):"""優惠券基礎類"""passclass Coupon1(BaseCoupon):"""滿減"""passclass Coupon2(BaseCoupon):"""立減"""passclass Coupon3(BaseCoupon):"""折扣"""passclass Price(object):"""商品價格"""def __init__(self,price,discount):self.price = priceself.discount = discountdef pay(self): # 交易價格passclass Goods(object):def __init__(self,name):self.name = name View Code

    重點就是建模
    一般做3年開發,就可以領悟 領域驅動設計。具體還得看個人的領悟能力!

    ?

    其他更多信息,請參考鏈接:

    https://www.cnblogs.com/yihaha/p/3977496.html

    ?

    關于python方面領域驅動設計的相關書籍,暫時還沒有。

    主流的是JAVA,C#,PHP

    ?

    領域驅動設計它是一種編程思想,重點就是建模!對于開發一個大型項目,尤為重要!

    在python源代碼中,就利用這種思想。類中層層嵌套類!

    對于個人編程能力的提升,可以看一下相關書籍!

    ?

    未完待續...

    轉載于:https://www.cnblogs.com/xiao987334176/p/9575783.html

    總結

    以上是生活随笔為你收集整理的python 全栈开发,Day116(可迭代对象,type创建动态类,偏函数,面向对象的封装,获取外键数据,组合搜索,领域驱动设计(DDD))...的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    91免费国产在线观看 | 国产一级在线免费观看 | 开心激情综合网 | 在线a视频 | 免费网站看v片在线a | 日韩性xxx| a视频在线观看 | 亚洲最大色 | 狠狠色丁香婷综合久久 | 国产日韩精品一区二区三区 | 成人av在线资源 | 午夜久久电影网 | 中文字幕日本在线 | 日日躁夜夜躁xxxxaaaa | www.啪啪.com| 三级免费黄色 | 日韩免费网址 | 久久精品二区 | 中文字幕在线看视频 | 日韩在线一区二区免费 | 欧美-第1页-屁屁影院 | 亚洲伊人第一页 | 国产精品永久在线 | 欧美日韩一级久久久久久免费看 | 久久午夜鲁丝片 | 欧美一级特黄aaaaaa大片在线观看 | 成人在线播放免费观看 | 激情校园亚洲 | 亚洲精品午夜aaa久久久 | 91亚洲狠狠婷婷综合久久久 | 国产一区二区高清 | 亚洲国产网址 | 国产伦理一区 | 精品久久久久久亚洲综合网 | 怡红院av久久久久久久 | 91在线观看视频网站 | 91成人短视频在线观看 | 国产精品乱码久久 | 日韩av一卡二卡三卡 | 干狠狠 | 日本久久不卡视频 | 日产乱码一二三区别免费 | 成人wwwxxx视频 | 国产对白av | 欧美日韩国产高清视频 | 亚洲最大激情中文字幕 | 久久av一区二区三区亚洲 | 欧美影院久久 | 亚洲一区二区黄色 | 97在线看| 麻豆免费视频观看 | 粉嫩av一区二区三区四区五区 | 911亚洲精品第一 | 精品国产免费观看 | 久久国产精品久久国产精品 | 91视频这里只有精品 | 91九色在线视频 | 日韩最新理论电影 | www黄com| 久久99精品国产91久久来源 | 天天干天天插 | 成人福利在线播放 | 亚洲三级国产 | 欧美另类激情 | 亚洲久草在线 | 日韩精品视频在线观看网址 | 黄色免费在线视频 | 草久草久 | 激情网站免费观看 | 精品国产一区二区三区免费 | 国产精品资源 | 亚洲精品自在在线观看 | 亚洲美女精品视频 | 国产一级二级三级在线观看 | 美女免费视频一区二区 | 天天拍天天爽 | 国产精品 日韩 欧美 | 日韩精品在线免费播放 | 婷婷久久国产 | 永久精品视频 | 2022中文字幕在线观看 | 日韩在线观看视频中文字幕 | 国产69精品久久app免费版 | 国产1级视频 | 毛片视频网址 | 国产免费作爱视频 | 欧美日韩亚洲国产一区 | 午夜黄网 | 久久久久久久国产精品影院 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 17videosex性欧美 | 色视频在线看 | 超碰在线最新 | 久久艹在线观看 | 精品一区二区6 | 国产亚洲一区二区在线观看 | 福利视频入口 | 天天操天天玩 | 国产在线观看h | 色999精品 | 欧美精品视 | 丁香花中文字幕 | 91亚洲精品久久久中文字幕 | 一区二区三区电影大全 | 亚洲人成精品久久久久 | 日韩激情免费视频 | 99精品在这里 | 中文字幕在线视频网站 | 欧美韩国在线 | 中文字幕精品三级久久久 | 玖玖精品在线 | 久久99精品国产91久久来源 | 午夜视频在线观看欧美 | 久久久综合九色合综国产精品 | 国产资源网站 | 久久激情视频免费观看 | 顶级bbw搡bbbb搡bbbb | 中文字幕av一区二区三区四区 | 中文字幕在线免费观看 | 国产精品自产拍在线观看蜜 | 色婷婷电影 | 久久精品欧美一区 | 免费久久久久久久 | 91精品啪在线观看国产线免费 | 日日天天干 | 丁香婷婷激情网 | 色综合天天天天做夜夜夜夜做 | 日韩天天干 | 久久欧美在线电影 | 国产在线国偷精品产拍 | 欧美一级淫片videoshd | 婷婷开心久久网 | 久久av在线播放 | 国产精品美女www爽爽爽视频 | 成人在线一区二区 | 亚州人成在线播放 | 日韩av电影国产 | 在线日韩视频 | 激情久久久久 | 国产精品乱码久久久久久1区2区 | 日韩精品在线看 | 午夜在线日韩 | 六月婷操 | 成人av免费| av在线播放快速免费阴 | 国产精品国产自产拍高清av | 日韩视频免费观看高清完整版在线 | 久久精品国产99国产 | 天天艹天天干天天 | 婷婷在线视频观看 | 色哟哟国产精品 | 一本一道久久a久久精品蜜桃 | 亚洲天堂网视频在线观看 | 日本不卡123区 | 五月婷婷丁香 | 亚洲欧美综合 | 制服丝袜天堂 | 91久久精品一区 | 国产高清不卡一区二区三区 | 午夜999| 日韩高清不卡一区二区三区 | 国产香蕉久久精品综合网 | 在线观看精品视频 | 在线观看中文字幕第一页 | 超碰在线亚洲 | 黄网站免费久久 | 亚洲资源网 | 国产成人久久精品一区二区三区 | 免费高清看电视网站 | 操操碰 | 欧美视频日韩 | 欧美一区二区三区免费看 | 亚洲国产精品一区二区尤物区 | 99c视频在线 | 国产精品2020 | 韩日视频在线 | 久草在线视频精品 | 97超碰成人在线 | 中文国产字幕 | 欧美日韩精品免费观看 | 成人国产精品入口 | 亚洲国产精品日韩 | 91片在线观看 | 91亚洲在线观看 | 日韩手机在线观看 | 国产精品美女久久久久aⅴ 干干夜夜 | 91在线免费视频观看 | 亚洲女欲精品久久久久久久18 | 久久国产电影 | 国产精品久久久毛片 | 国产日韩欧美在线观看视频 | 日韩99热 | 国产精品久久久久久av | 天天干夜夜干 | 在线视频 91 | 国产精品2区 | 天天人人综合 | 最近更新的中文字幕 | 黄色资源网站 | 五月婷婷综合在线视频 | 亚洲夜夜网 | 欧美性生活大片 | 亚洲视频2 | 国产日韩在线视频 | 91在线文字幕 | 激情五月综合 | 精品福利在线视频 | 福利网在线 | 免费亚洲片 | 国产成a人亚洲精v品在线观看 | 十八岁免进欧美 | 最近字幕在线观看第一季 | 日韩视频免费在线 | 伊人色综合久久天天 | www色com| 在线亚洲小视频 | 丁香婷婷综合色啪 | 九色琪琪久久综合网天天 | 在线观看资源 | 久久久久亚洲a | 成人一区二区在线 | 国产999久久久 | 中文字幕色播 | 又黄又爽又色无遮挡免费 | 美女视频免费一区二区 | 久久精品一区 | 亚洲国产精选 | 日韩在线高清 | 美女久久网站 | 欧美孕妇与黑人孕交 | 五月婷婷综合久久 | 99久热精品 | 91精品国产综合久久福利不卡 | 丁香六月av | 国产99中文字幕 | 久久久精品久久日韩一区综合 | 亚洲综合色视频 | 精精国产xxxx视频在线播放 | 日韩欧美亚州 | 国产日韩中文字幕 | 日韩午夜电影 | 狠狠干夜夜爽 | 欧美一级特黄aaaaaa大片在线观看 | 久草在线99| 黄污网站在线观看 | 欧美少妇xxx | 婷婷5月激情5月 | 亚洲天天做 | 久久免费视频1 | 精品久久久成人 | 欧美日韩网站 | 97国产精品视频 | 免费亚洲精品 | 久久成熟 | 九九九热精品免费视频观看网站 | 99在线视频播放 | 在线观看亚洲电影 | www.亚洲视频| 麻豆一区二区三区视频 | av线上免费看| 国产高清绿奴videos | 天天操天天干天天操天天干 | 国产精品综合在线观看 | 91麻豆国产福利在线观看 | 国产精品欧美日韩在线观看 | 免费看日韩 | 日韩av在线网站 | 久久avav| 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 天堂av网在线 | 人人澡人人爽欧一区 | 日韩精品一区二区三区中文字幕 | 成片免费 | .国产精品成人自产拍在线观看6 | 在线香蕉视频 | 日韩在线免费观看视频 | 美女视频免费精品 | 中文字幕丝袜一区二区 | 97超碰在线久草超碰在线观看 | 日本不卡久久 | 911av视频| 久久99视频 | 毛片基地黄久久久久久天堂 | 开心激情五月网 | 久久久免费毛片 | 国产精品久久久毛片 | 日韩在线一二三区 | 中文字幕亚洲字幕 | 国产亚洲精品久 | 久久久久久久av | 成人毛片久久 | 成人久久18免费网站图片 | 久久一区二区三区超碰国产精品 | 在线观看免费成人av | 亚洲无吗天堂 | 天天干天天操天天爱 | 国产精品一区二区三区在线 | 亚洲aaa毛片 | 精品一二 | 91成人精品一区在线播放69 | 免费亚洲婷婷 | 99九九热只有国产精品 | 69久久夜色精品国产69 | 亚洲色图激情文学 | 日韩啪视频 | 日韩一区二区免费在线观看 | 久久久综合精品 | 在线日韩亚洲 | 五月婷婷一区 | 国产精品每日更新 | 亚洲在线视频免费 | 国产又粗又猛又色 | 在线观看国产www | 国产探花视频在线播放 | 国产小视频网站 | 黄色av电影在线观看 | 国产黄色精品在线 | 色综合久久精品 | 日韩精品免费 | 午夜精品一二区 | 成人久久久久久久久久 | 成人理论电影 | 久草香蕉在线 | 玖玖玖影院 | 中文区中文字幕免费看 | 91成人免费在线 | 国产aa免费视频 | 国产成人久久精品77777 | 91精品小视频 | 夜夜夜草 | 婷婷色在线资源 | 成年人国产精品 | 9幺看片 | 一级久久精品 | 久久影视网 | 久精品视频在线观看 | 亚洲精品美女在线观看播放 | 九九热只有这里有精品 | a成人在线| 一 级 黄 色 片免费看的 | 日韩在线观看视频免费 | 在线观看成人小视频 | 日韩电影精品一区 | 久久久久国产精品www | 国产九色91 | 久久免费看毛片 | 天堂在线一区二区 | 免费又黄又爽 | 人人狠狠综合久久亚洲婷 | 久久国产成人午夜av影院潦草 | 人人插人人艹 | 特黄色大片 | 91香蕉视频好色先生 | 国产黄色片免费在线观看 | 亚洲国产日韩av | 六月天综合网 | 久久精品国产亚洲a | 99热精品免费观看 | 黄色三级免费网址 | 天天干,夜夜爽 | 免费日韩一区二区三区 | 99一区二区三区 | 九九免费在线观看 | 亚洲欧洲美洲av | 麻豆小视频在线观看 | 免费在线国产视频 | 国产视| 国产精品久久久久一区二区三区共 | 91av福利视频 | 激情视频一区二区三区 | 九九热精品在线 | 久久在线免费观看视频 | 日韩.com | 成人在线视频免费 | 精品99在线 | 青青河边草手机免费 | 久久免费av| 麻豆一精品传二传媒短视频 | 99精品国产成人一区二区 | 亚洲视频精品在线 | 91在线视频一区 | av一级片在线观看 | 2021av在线 | 激情xxxx| 伊人五月天 | www.天天草 | 九色91在线 | 在线精品亚洲一区二区 | 丁香色综合 | 国内免费久久久久久久久久久 | 国产精品久久久久久久久久久久久久 | 91成人精品一区在线播放69 | av网站免费在线 | 激情欧美国产 | 国产精品手机在线播放 | 国产成人综合精品 | 国产一级在线观看视频 | 人人揉人人揉人人揉人人揉97 | 国产日韩精品一区二区 | 国产一二区视频 | 97人人射 | 日韩欧美精品在线 | 中文字幕在线观看视频一区二区三区 | 婷婷亚洲激情 | 美女视频黄是免费的 | 中文字幕永久在线 | 黄色电影在线免费观看 | 国产手机视频在线播放 | 国内丰满少妇猛烈精品播放 | 五月天色综合 | 中文字幕在线高清 | 手机在线免费av | 国产精品免费av | 日韩精品短视频 | www.在线观看av| 日韩免费一级a毛片在线播放一级 | 最近中文字幕大全中文字幕免费 | 在线黄av| 丝袜美腿在线 | 99精品福利 | 69绿帽绿奴3pvideos | 欧美精品乱码久久久久 | 精品久久精品 | 91片黄在线观 | 在线观看色网 | 久久激五月天综合精品 | 精品久久久久国产 | 国产中文字幕在线播放 | 超碰日韩在线 | www亚洲国产 | 国产精品久久久久久电影 | 伊人天堂网| 亚洲精品视频久久 | 日产乱码一二三区别在线 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 九九热在线精品视频 | 日本性生活一级片 | 日韩欧美高清在线观看 | 成人影音av | av中文字幕亚洲 | 色婷婷亚洲 | 国产免费看| 少妇bbb搡bbbb搡bbbb′ | 狠狠躁夜夜a产精品视频 | 国产又粗又猛又爽 | 狂野欧美激情性xxxx | av中文电影 | 99久久久久久久久久 | 在线免费观看视频一区二区三区 | 亚洲精品国产成人av在线 | 成人亚洲精品久久久久 | 欧美日韩免费视频 | a一片一级 | 欧美国产日韩一区二区三区 | 操久在线| 欧美激情视频三区 | 99久久精品免费一区 | 国产亚洲精品久久久久久电影 | 欧美精品一区二区性色 | 天躁狠狠躁 | 国产免费三级在线观看 | 亚洲精品一区二区三区在线观看 | 在线观看视频黄 | 国产精品v欧美精品 | 亚洲激情在线 | 色视频在线免费观看 | 999视频在线播放 | 91精品国产乱码久久桃 | 中文字幕在线视频免费播放 | 热久久免费国产视频 | 亚洲电影成人 | 久久99国产精品免费网站 | 日本免费久久高清视频 | 久久综合狠狠 | 国产黄色精品在线观看 | 国产精品免费视频网站 | 亚洲国产精品va在线 | 久久综合狠狠综合久久激情 | 麻豆一二 | 五月激情五月激情 | 国产一级电影免费观看 | 日韩中文字幕电影 | 国产99中文字幕 | 色婷婷中文 | av大全在线观看 | 在线观看你懂的网址 | www.成人久久 | 欧美色噜噜 | 在线观看av免费 | 欧美性生活一级片 | 国产高清福利在线 | 成人91在线 | 久久综合狠狠综合久久狠狠色综合 | 91视频观看免费 | 国产成人一区二区三区 | 成人国产网址 | 波多野结衣一区二区三区中文字幕 | 成人播放器 | 久久天天躁夜夜躁狠狠躁2022 | 91精品一区二区三区久久久久久 | 精品国产免费一区二区三区五区 | 九九九热视频 | 国产伦精品一区二区三区在线 | 日韩免费在线网站 | 国产主播大尺度精品福利免费 | 女人久久久久 | 国产码电影 | 97电影在线看视频 | 国内精品美女在线观看 | 久久久久久在线观看 | 日韩,中文字幕 | 亚洲欧美日韩一区二区三区在线观看 | 91| 四虎永久视频 | 国产一区二区三区免费在线观看 | 国产精品久久久久久久久久免费看 | 91亚洲国产 | 中文字幕精品三级久久久 | 色婷婷综合成人av | 国产精品99久久免费黑人 | 中文字幕日韩免费视频 | 欧美日韩免费看 | 91av视频在线免费观看 | 国产精品一级在线 | 国产色在线观看 | 国产精品美女久久久久久久网站 | 亚洲一区二区三区毛片 | 99tvdz@gmail.com| 国产亚洲高清视频 | 精品久久久久久久久久久院品网 | 国产女教师精品久久av | 国产成人综合图片 | 91中文在线视频 | 欧美国产91| 成人小视频在线观看免费 | 日韩性xxxx | 久久免费资源 | 色婷婷狠狠干 | 91.精品高清在线观看 | 久久久免费国产 | 天天射天天艹 | 色天天综合网 | 国产特级毛片aaaaaa | 五月天亚洲激情 | 亚洲精品小视频在线观看 | 久久免费观看少妇a级毛片 久久久久成人免费 | 色五婷婷| 麻豆激情电影 | 97在线看| 久久久久亚洲国产精品 | 激情五月网站 | 天天玩天天操天天射 | 在线播放 日韩专区 | 国产精品久久久久久久久岛 | 色婷婷久久久 | 91看片淫黄大片一级在线观看 | 免费成人av电影 | 2023国产精品自产拍在线观看 | 亚洲有 在线| 91精品国产三级a在线观看 | 久草电影网| 97人人模人人爽人人喊中文字 | 亚洲美女视频在线观看 | 亚洲精品国产综合久久 | a精品视频 | 国产在线不卡一区 | 最新av在线网址 | 超碰国产在线观看 | 999成人网| 久久久久久久av麻豆果冻 | 亚洲成人免费在线 | 免费一级特黄毛大片 | 国产精品1024 | 精品久久久久久久久久岛国gif | 成人a在线| 中文在线资源 | 久久综合射 | 国产精品久久久久久久久久直播 | 黄色99视频 | 久久毛片网站 | 91视频在线观看下载 | 人人澡超碰碰97碰碰碰软件 | 亚洲国产一区在线观看 | 玖玖在线播放 | 亚洲狠狠婷婷综合久久久 | 免费视频你懂得 | 西西大胆免费视频 | 国产免费作爱视频 | 三级av在线播放 | 色欧美成人精品a∨在线观看 | 狠狠色狠狠色综合日日小说 | 天无日天天操天天干 | 草在线 | 天天天色综合a | 人成免费网站 | 999精品 | 天天舔天天射天天操 | 午夜免费久久看 | 日韩电影在线看 | 999电影免费在线观看 | 免费看成年人 | 国产精品一级在线 | 日韩在线观看第一页 | 亚洲国产成人在线观看 | 日韩欧美电影在线 | 国产护士在线 | 国产精品99久久久精品免费观看 | 涩涩网站在线 | 免费看的黄色小视频 | 婷婷夜夜 | 亚洲jizzjizz日本少妇 | 日韩中文在线视频 | 久久国产综合视频 | 色噜噜日韩精品一区二区三区视频 | 91亚洲国产成人久久精品网站 | 中文字幕欲求不满 | 天天综合天天综合 | 国产麻豆果冻传媒在线观看 | 久久久精品99| 中文字幕一区二区三区乱码不卡 | 玖玖综合网 | 国产黄色免费看 | 人人揉人人揉人人揉人人揉97 | 五月婷婷色丁香 | 夜夜干天天操 | 国产成人综合图片 | 亚洲第一成网站 | 国产精品wwwwww | 在线观看视频黄色 | 国产黄色片在线 | 国产一级免费在线观看 | 六月丁香激情综合 | 99久久久国产精品免费观看 | 午夜精品久久久久久久99婷婷 | 9色在线视频 | av在线免费观看网站 | 在线导航av | 日韩免费小视频 | 免费观看国产精品视频 | 亚洲精品在线免费观看视频 | 久久久久麻豆v国产 | 国产成人在线免费观看 | 成人午夜网址 | 99久久精 | 久久综合狠狠综合久久狠狠色综合 | 欧美中文字幕第一页 | 婷婷丁香激情综合 | 欧美日性视频 | 天天色天天爱天天射综合 | 色婷婷激情综合 | 国产高清专区 | 亚洲区视频在线 | 伊人午夜| 婷婷激情在线 | 99精品国产一区二区三区不卡 | 处女av在线 | 蜜臀av网址 | 亚洲午夜久久久综合37日本 | 中文字幕在线一区观看 | 久久国产日韩 | 精品国模一区二区 | 成年人在线观看视频免费 | 欧美成年网站 | 精品一区二区免费视频 | 亚洲综合涩| 亚洲国产电影在线观看 | 亚洲一区二区观看 | 免费亚洲精品 | 在线综合 亚洲 欧美在线视频 | 亚洲视屏在线播放 | 日韩高清精品一区二区 | 国产视频二 | 国产成人精品一区二区在线观看 | 色91av| 亚洲午夜精品福利 | 久久夜靖品| 免费色视频在线 | 成年人视频在线免费播放 | 久久精品视频国产 | 日韩欧美电影网 | 五月婷婷深开心 | 99精品乱码国产在线观看 | 精品免费久久久久 | 欧美日韩精品二区第二页 | 四虎影视国产精品免费久久 | 黄色国产在线观看 | 欧美一级黄大片 | 黄色精品一区 | 丝袜一区在线 | 日韩精品久久一区二区三区 | 99久久999久久久精玫瑰 | 精品福利片| 久久这里只有精品首页 | 亚洲国产成人在线观看 | 丁香六月在线观看 | 91日韩在线播放 | a级一a一级在线观看 | 九色最新网址 | 一区二区精品国产 | 中文字幕不卡在线88 | 五月丁色 | 超碰精品在线 | 免费在线观看av网站 | 日韩,精品电影 | 亚洲欧洲国产日韩精品 | 亚州精品成人 | 国产精品网红直播 | 国产综合精品一区二区三区 | 91亚洲在线 | 亚洲精品456在线播放 | 欧美性脚交 | 国产精品正在播放 | 成人黄色电影免费观看 | 波多野结依在线观看 | 男女全黄一级一级高潮免费看 | 亚洲电影黄色 | 免费看黄网站在线 | 欧美日韩亚洲在线观看 | www.色com| 亚洲国产视频直播 | 在线国产精品视频 | 久草免费福利在线观看 | 日韩高清片 | 日韩欧美高清在线观看 | 久久精品99国产国产精 | 中文字幕中文字幕在线中文字幕三区 | 麻豆一区二区三区视频 | 久久少妇免费视频 | 欧美激情视频一区二区三区免费 | 在线成人性视频 | 国产免费高清视频 | 黄色一级大片在线观看 | 亚州av成人 | 国产精品情侣视频 | 国产美女主播精品一区二区三区 | 在线播放 亚洲 | 91大神dom调教在线观看 | 亚洲精品视 | 国产精品k频道 | 国产成人一区二区三区免费看 | 成年人黄色免费看 | 99久久精品国产欧美主题曲 | 中文在线字幕免 | 天天色综合三 | 最近免费中文字幕大全高清10 | 欧美精品一区二区免费 | 日本久久成人 | 五月色丁香 | 一区二区三区在线视频观看58 | 日韩精品一区二区三区免费观看视频 | 丁香六月天婷婷 | 国产一区二区三区免费在线 | 亚洲精品日韩在线观看 | 久久国产系列 | www久久久久| 国产成人精品一区二区三区福利 | 中文视频一区二区 | 国产一区二区三区网站 | 美女网站视频免费黄 | h动漫中文字幕 | 久草在线电影网 | 日韩欧美亚州 | 国产精品一区二区电影 | 黄色网中文字幕 | 中中文字幕av在线 | 久久精品免费观看 | 国产成人久久 | 婷婷在线精品视频 | 最新亚洲视频 | 免费国产黄线在线观看视频 | 91九色视频导航 | 日韩色在线观看 | 亚洲欧美视频在线 | 91成人精品一区在线播放 | 国产一级性生活视频 | 久久久蜜桃一区二区 | 日韩欧美有码在线 | 久久超| 99成人免费视频 | 久久av免费观看 | 夜夜爽天天爽 | 中文字幕乱码一区二区 | 久久艹精品 | av资源免费看 | 久久99精品久久久久婷婷 | 97精品欧美91久久久久久 | 成人午夜剧场在线观看 | 国内外成人在线视频 | 日韩综合一区二区 | 99re中文字幕 | 欧美a级片免费看 | 手机看片国产 | 日日摸日日添夜夜爽97 | 亚洲综合狠狠干 | 精品久久久久久久久中文字幕 | 国产中文字幕视频在线观看 | 国产伦精品一区二区三区无广告 | 免费特级黄毛片 | 在线观看黄a | 久久婷婷五月综合色丁香 | 成人在线观看av | 天天天综合网 | 国产成人在线精品 | 欧美日本国产在线观看 | 国产一级片久久 | 天天色天天艹 | 亚洲国产成人在线 | 亚洲视频专区在线 | 亚洲精品高清视频在线观看 | 日韩精品一区二区免费 | 国产无吗一区二区三区在线欢 | 国产成人精品在线播放 | 精品91视频 | 精品国产一区二区三区久久影院 | 又黄又刺激视频 | 亚洲,国产成人av | www.国产在线 | 中文字幕高清免费日韩视频在线 | www,黄视频 | av在线播放网址 | 亚洲欧美视频 | 日韩在线观看第一页 | 久久五月激情 | av片子在线观看 | 国产精品普通话 | 99精品在线观看视频 | 国产精品中文 | av官网在线| 一级电影免费在线观看 | 国产精品国产三级国产不产一地 | 国产精品毛片久久 | 欧美精品久久久久久久久老牛影院 | 亚洲免费不卡 | 欧美日韩国产在线观看 | 丁香五月网久久综合 | 婷婷久操 | 日韩激情片在线观看 | 亚洲永久在线 | 91麻豆精品国产自产在线 | 国产精品系列在线播放 | av日韩在线网站 | 成人黄色视 | 99久久这里只有精品 | 免费看的黄色的网站 | 青草视频在线 | 日韩电影一区二区三区在线观看 | 天天干,天天射,天天操,天天摸 | 五月天堂网 | 亚洲精品自拍视频在线观看 | 国产精品久久久久久久久蜜臀 | 久久99精品国产99久久 | 免费在线色电影 | 亚洲人在线 | 久久精品九色 | 五月婷婷激情综合 | 国产精品久久久久久久久毛片 | 免费黄色av电影 | 成年人国产在线观看 | 国产精品刺激对白麻豆99 | 天天干夜夜干 | 在线国产片 | 色综久久 | 美女国内精品自产拍在线播放 | 欧美大片aaa | 国产午夜激情视频 | 免费看污在线观看 | 视频99爱 | 亚洲一区欧美精品 | 国产精品久久久久永久免费观看 | 特级黄录像视频 | 色综合久久综合网 | 国产精品激情 | 久久久免费精品国产一区二区 | 美女激情影院 | 亚洲精品欧美专区 | 精品视频国产 | 91丨九色丨国产丨porny精品 | 亚洲精品国产精品99久久 | 中文字幕中文中文字幕 | 婷婷中文在线 | 97免费在线观看视频 | 日韩欧美精品一区二区三区经典 | 三日本三级少妇三级99 | 91正在播放| 国产精品欧美一区二区 | 91亚洲永久精品 | 日韩高清成人 | 91在线网址 | 久久高清片 | 中文字幕在线精品 | 日韩欧美在线观看一区 | 麻豆一精品传二传媒短视频 | 国产美女在线观看 | 最新av网站在线观看 | 免费视频黄 | 在线性视频日韩欧美 | 亚洲精品乱码久久久久久蜜桃不爽 | 天天色成人 | 国产麻豆精品在线观看 | 久久人人爽人人片av | 亚洲在线看 | 亚洲视频一级 | 国产在线精品视频 | 狠狠色婷婷丁香六月 | 91av视频在线播放 | 91麻豆精品国产91久久久无需广告 | 97国产| 看国产黄色大片 | 97成人免费 | 色国产精品一区在线观看 | 96在线| 波多野结衣在线中文字幕 | 六月丁香在线视频 | 亚洲免费av一区二区 | 亚洲精品国产精品99久久 | 成人国产精品免费 | 久久久天天操 | 一区二区三区四区五区六区 | 国产色在线 | 久久久999 | 日韩三级精品 | 888av| 91高清视频免费 | 丁香在线观看完整电影视频 | 99草视频| 天天综合日日夜夜 | 天天天天天天天操 | 久久首页| 操操操日日 | 国产资源免费在线观看 | 国内久久久久久 | 日日夜操 | 精品国内自产拍在线观看视频 | 国产精品久久婷婷六月丁香 | 精品成人a区在线观看 | 免费在线色视频 | 亚洲美女免费精品视频在线观看 | 免费看国产曰批40分钟 | 999久久| 99久久久国产免费 | 中文字幕2021| 狠狠撸电影 | 亚欧日韩成人h片 | 国产老太婆免费交性大片 | 亚洲闷骚少妇在线观看网站 | 婷色在线 | 久久社区视频 | 伊人导航 | 美女黄网站视频免费 | 日韩高清激情 | av网站免费线看精品 | 久久综合色一综合色88 | 欧美久久久一区二区三区 | 久久精品久久99精品久久 | 91在线中文字幕 | 在线观看的av | www.神马久久 | 日韩一级黄色片 | 97在线影视 | 九九九热精品 | 精品国产一区二区三区噜噜噜 | 免费av在线播放 | 国产午夜精品久久久久久久久久 | 最近中文字幕在线播放 | 天天做天天射 | 麻豆mv在线观看 | 国产一线在线 | 国产91电影在线观看 | 国产黄色片免费 | 91一区啪爱嗯打偷拍欧美 | 天天射天天舔天天干 | 婷婷久草 | 天天综合区 | 久久久电影 | 免费在线观看一级片 | 精品av网站| 黄色av一级 | 色婷婷成人网 | 久插视频 | 99热最新| 天天插天天爱 | 亚洲三级在线免费观看 | 久久99热这里只有精品国产 | 探花视频在线观看 | 国产在线超碰 | 免费成人黄色片 | 这里有精品在线视频 | 在线播放一区二区三区 | 欧美午夜性 | 91精品在线观看入口 | 久久久久免费看 | 午夜精品久久久久久久久久久 | 成人少妇影院yyyy | 狠狠色伊人亚洲综合网站野外 | 国产片网站| 国产又粗又猛又色又黄视频 | 韩国av一区二区 | 欧美日韩99 |