精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

用Python寫(xiě)一個(gè)簡(jiǎn)單的Web框架

開(kāi)發(fā) 后端
本文嘗試寫(xiě)一個(gè)類似web.py的Web框架。好吧,我承認(rèn)我夸大其辭了:首先,web.py并不簡(jiǎn)單;其次,本文只重點(diǎn)實(shí)現(xiàn)了 URL調(diào)度(URL dispatch)部分。

用Python寫(xiě)一個(gè)簡(jiǎn)單的Web框架

  •  一、概述
  • 二、從demo_app開(kāi)始
  • 三、WSGI中的application
  • 四、區(qū)分URL
  • 五、重構(gòu)
    • 1、正則匹配URL
    • 2、DRY
    • 3、抽象出框架
  • 六、參考

一、概述

在Python中,WSGI(Web Server Gateway Interface)定義了Web服務(wù)器與Web應(yīng)用(或Web框架)之間的標(biāo)準(zhǔn)接口。在WSGI的規(guī)范下,各種各樣的Web服務(wù)器和Web框架都可以很好的交互。

由于WSGI的存在,用Python寫(xiě)一個(gè)簡(jiǎn)單的Web框架也變得非常容易。然而,同很多其他的強(qiáng)大軟件一樣,要實(shí)現(xiàn)一個(gè)功能豐富、健壯高效的Web框架并非易事;如果您打算這么做,可能使用一個(gè)現(xiàn)成的Web框架(如 Django、Tornado、web.py 等)會(huì)是更合適的選擇。

本文嘗試寫(xiě)一個(gè)類似web.py的Web框架。好吧,我承認(rèn)我夸大其辭了:首先,web.py并不簡(jiǎn)單;其次,本文只重點(diǎn)實(shí)現(xiàn)了 URL調(diào)度(URL dispatch)部分。

二、從demo_app開(kāi)始

首先,作為一個(gè)初步體驗(yàn),我們可以借助 wsgiref.simple_server 來(lái)搭建一個(gè)簡(jiǎn)單無(wú)比(trivial)的Web應(yīng)用:

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. from wsgiref.simple_server import make_server, demo_app 
  8.  
  9.   
  10.  
  11. httpd = make_server('', 8086, demo_app) 
  12.  
  13. sa = httpd.socket.getsockname() 
  14.  
  15. print 'http://{0}:{1}/'.format(*sa) 
  16.  
  17.   
  18.  
  19. # Respond to requests until process is killed 
  20.  
  21. httpd.serve_forever()  

運(yùn)行腳本:

  1. $ python code.py 
  2.  
  3. http://0.0.0.0:8086/  

打開(kāi)瀏覽器,輸入http://0.0.0.0:8086/后可以看到:一行”Hello world!” 和 眾多環(huán)境變量值。

三、WSGI中的application

WSGI中規(guī)定:application是一個(gè) 可調(diào)用對(duì)象(callable object),它接受 environ 和 start_response 兩個(gè)參數(shù),并返回一個(gè) 字符串迭代對(duì)象。

其中,可調(diào)用對(duì)象 包括 函數(shù)、方法、類 或者 具有__call__方法的 實(shí)例;environ 是一個(gè)字典對(duì)象,包括CGI風(fēng)格的環(huán)境變量(CGI-style environment variables)和 WSGI必需的變量(WSGI-required variables);start_response 是一個(gè)可調(diào)用對(duì)象,它接受兩個(gè) 常規(guī)參數(shù)(status,response_headers)和 一個(gè) 默認(rèn)參數(shù)(exc_info);字符串迭代對(duì)象 可以是 字符串列表、生成器函數(shù) 或者 具有__iter__方法的可迭代實(shí)例。更多細(xì)節(jié)參考 Specification Details。

The Application/Framework Side 中給出了一個(gè)典型的application實(shí)現(xiàn):

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """application.py""" 
  8.  
  9.   
  10.  
  11. def simple_app(environ, start_response): 
  12.  
  13.     """Simplest possible application object""" 
  14.  
  15.     status = '200 OK' 
  16.  
  17.     response_headers = [('Content-type''text/plain')] 
  18.  
  19.     start_response(status, response_headers) 
  20.  
  21.     return ['Hello world!\n' 

現(xiàn)在用simple_app來(lái)替換demo_app:

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """code.py""" 
  8.  
  9.   
  10.  
  11. from wsgiref.simple_server import make_server 
  12.  
  13. from application import simple_app as app 
  14.  
  15.   
  16.  
  17. if __name__ == '__main__'
  18.  
  19.     httpd = make_server('', 8086, app) 
  20.  
  21.     sa = httpd.socket.getsockname() 
  22.  
  23.     print 'http://{0}:{1}/'.format(*sa) 
  24.  
  25.   
  26.  
  27.     # Respond to requests until process is killed 
  28.  
  29.     httpd.serve_forever()  

運(yùn)行腳本code.py后,訪問(wèn)http://0.0.0.0:8086/就可以看到那行熟悉的句子:Hello world!

四、區(qū)分URL

倒騰了一陣子后,您會(huì)發(fā)現(xiàn)不管如何改變URL中的path部分,得到的響應(yīng)都是一樣的。因?yàn)閟imple_app只識(shí)別host+port部分。

為了對(duì)URL中的path部分進(jìn)行區(qū)分處理,需要修改application.py的實(shí)現(xiàn)。

首先,改用 類 來(lái)實(shí)現(xiàn)application:

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """application.py""" 
  8.  
  9.   
  10.  
  11. class my_app: 
  12.  
  13.     def __init__(self, environ, start_response): 
  14.  
  15.         self.environ = environ 
  16.  
  17.         self.start = start_response 
  18.  
  19.   
  20.  
  21.     def __iter__(self): 
  22.  
  23.         status = '200 OK' 
  24.  
  25.         response_headers = [('Content-type''text/plain')] 
  26.  
  27.         self.start(status, response_headers) 
  28.  
  29.         yield "Hello world!\n"  

然后,增加對(duì)URL中path部分的區(qū)分處理:

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """application.py""" 
  8.  
  9.   
  10.  
  11. class my_app: 
  12.  
  13.     def __init__(self, environ, start_response): 
  14.  
  15.         self.environ = environ 
  16.  
  17.         self.start = start_response 
  18.  
  19.   
  20.  
  21.     def __iter__(self): 
  22.  
  23.         path = self.environ['PATH_INFO'
  24.  
  25.         if path == "/"
  26.  
  27.             return self.GET_index() 
  28.  
  29.         elif path == "/hello"
  30.  
  31.             return self.GET_hello() 
  32.  
  33.         else
  34.  
  35.             return self.notfound() 
  36.  
  37.   
  38.  
  39.     def GET_index(self): 
  40.  
  41.         status = '200 OK' 
  42.  
  43.         response_headers = [('Content-type''text/plain')] 
  44.  
  45.         self.start(status, response_headers) 
  46.  
  47.         yield "Welcome!\n" 
  48.  
  49.   
  50.  
  51.     def GET_hello(self): 
  52.  
  53.         status = '200 OK' 
  54.  
  55.         response_headers = [('Content-type''text/plain')] 
  56.  
  57.         self.start(status, response_headers) 
  58.  
  59.         yield "Hello world!\n" 
  60.  
  61.   
  62.  
  63.     def notfound(self): 
  64.  
  65.         status = '404 Not Found' 
  66.  
  67.         response_headers = [('Content-type''text/plain')] 
  68.  
  69.         self.start(status, response_headers) 
  70.  
  71.         yield "Not Found\n"  

修改code.py中的from application import simple_app as app,用my_app來(lái)替換simple_app后即可體驗(yàn)效果。

五、重構(gòu)

上面的代碼雖然奏效,但是在編碼風(fēng)格和靈活性方面有很多問(wèn)題,下面逐步對(duì)其進(jìn)行重構(gòu)。

1、正則匹配URL

消除URL硬編碼,增加URL調(diào)度的靈活性:

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """application.py""" 
  8.  
  9.   
  10.  
  11. import re ##########修改點(diǎn) 
  12.  
  13.   
  14.  
  15. class my_app: 
  16.  
  17.   
  18.  
  19.     urls = ( 
  20.  
  21.         ("/""index"), 
  22.  
  23.         ("/hello/(.*)""hello"), 
  24.  
  25.     ) ##########修改點(diǎn) 
  26.  
  27.   
  28.  
  29.     def __init__(self, environ, start_response): 
  30.  
  31.         self.environ = environ 
  32.  
  33.         self.start = start_response 
  34.  
  35.   
  36.  
  37.     def __iter__(self): ##########修改點(diǎn) 
  38.  
  39.         path = self.environ['PATH_INFO'
  40.  
  41.         method = self.environ['REQUEST_METHOD'
  42.  
  43.   
  44.  
  45.         for pattern, name in self.urls: 
  46.  
  47.             m = re.match('^' + pattern + '$', path) 
  48.  
  49.             if m: 
  50.  
  51.                 # pass the matched groups as arguments to the function 
  52.  
  53.                 args = m.groups() 
  54.  
  55.                 funcname = method.upper() + '_' + name 
  56.  
  57.                 if hasattr(self, funcname): 
  58.  
  59.                     func = getattr(self, funcname) 
  60.  
  61.                     return func(*args) 
  62.  
  63.   
  64.  
  65.         return self.notfound() 
  66.  
  67.   
  68.  
  69.     def GET_index(self): 
  70.  
  71.         status = '200 OK' 
  72.  
  73.         response_headers = [('Content-type''text/plain')] 
  74.  
  75.         self.start(status, response_headers) 
  76.  
  77.         yield "Welcome!\n" 
  78.  
  79.   
  80.  
  81.     def GET_hello(self, name): ##########修改點(diǎn) 
  82.  
  83.         status = '200 OK' 
  84.  
  85.         response_headers = [('Content-type''text/plain')] 
  86.  
  87.         self.start(status, response_headers) 
  88.  
  89.         yield "Hello %s!\n" % name 
  90.  
  91.   
  92.  
  93.     def notfound(self): 
  94.  
  95.         status = '404 Not Found' 
  96.  
  97.         response_headers = [('Content-type''text/plain')] 
  98.  
  99.         self.start(status, response_headers) 
  100.  
  101.         yield "Not Found\n"  

2、DRY

消除GET_*方法中的重復(fù)代碼,并且允許它們返回字符串:

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """application.py""" 
  8.  
  9.   
  10.  
  11. import re 
  12.  
  13.   
  14.  
  15. class my_app: 
  16.  
  17.   
  18.  
  19.     urls = ( 
  20.  
  21.         ("/""index"), 
  22.  
  23.         ("/hello/(.*)""hello"), 
  24.  
  25.     ) 
  26.  
  27.   
  28.  
  29.     def __init__(self, environ, start_response): ##########修改點(diǎn) 
  30.  
  31.         self.environ = environ 
  32.  
  33.         self.start = start_response 
  34.  
  35.         self.status = '200 OK' 
  36.  
  37.         self._headers = [] 
  38.  
  39.   
  40.  
  41.     def __iter__(self): ##########修改點(diǎn) 
  42.  
  43.         result = self.delegate() 
  44.  
  45.         self.start(self.status, self._headers) 
  46.  
  47.   
  48.  
  49.         # 將返回值result(字符串 或者 字符串列表)轉(zhuǎn)換為迭代對(duì)象 
  50.  
  51.         if isinstance(result, basestring): 
  52.  
  53.             return iter([result]) 
  54.  
  55.         else
  56.  
  57.             return iter(result) 
  58.  
  59.   
  60.  
  61.     def delegate(self): ##########修改點(diǎn) 
  62.  
  63.         path = self.environ['PATH_INFO'
  64.  
  65.         method = self.environ['REQUEST_METHOD'
  66.  
  67.   
  68.  
  69.         for pattern, name in self.urls: 
  70.  
  71.             m = re.match('^' + pattern + '$', path) 
  72.  
  73.             if m: 
  74.  
  75.                 # pass the matched groups as arguments to the function 
  76.  
  77.                 args = m.groups() 
  78.  
  79.                 funcname = method.upper() + '_' + name 
  80.  
  81.                 if hasattr(self, funcname): 
  82.  
  83.                     func = getattr(self, funcname) 
  84.  
  85.                     return func(*args) 
  86.  
  87.   
  88.  
  89.         return self.notfound() 
  90.  
  91.   
  92.  
  93.     def header(self, name, value): ##########修改點(diǎn) 
  94.  
  95.         self._headers.append((name, value)) 
  96.  
  97.   
  98.  
  99.     def GET_index(self): ##########修改點(diǎn) 
  100.  
  101.         self.header('Content-type''text/plain'
  102.  
  103.         return "Welcome!\n" 
  104.  
  105.   
  106.  
  107.     def GET_hello(self, name): ##########修改點(diǎn) 
  108.  
  109.         self.header('Content-type''text/plain'
  110.  
  111.         return "Hello %s!\n" % name 
  112.  
  113.   
  114.  
  115.     def notfound(self): ##########修改點(diǎn) 
  116.  
  117.         self.status = '404 Not Found' 
  118.  
  119.         self.header('Content-type''text/plain'
  120.  
  121.         return "Not Found\n"  

3、抽象出框架

為了將類my_app抽象成一個(gè)獨(dú)立的框架,需要作出以下修改:

  • 剝離出其中的具體處理細(xì)節(jié):urls配置 和 GET_*方法(改成在多個(gè)類中實(shí)現(xiàn)相應(yīng)的GET方法)
  • 把方法header實(shí)現(xiàn)為類方法(classmethod),以方便外部作為功能函數(shù)調(diào)用
  • 改用 具有__call__方法的 實(shí)例 來(lái)實(shí)現(xiàn)application

修改后的application.py(最終版本):

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """application.py""" 
  8.  
  9.   
  10.  
  11. import re 
  12.  
  13.   
  14.  
  15. class my_app: 
  16.  
  17.     """my simple web framework""" 
  18.  
  19.   
  20.  
  21.     headers = [] 
  22.  
  23.   
  24.  
  25.     def __init__(self, urls=(), fvars={}): 
  26.  
  27.         self._urls = urls 
  28.  
  29.         self._fvars = fvars 
  30.  
  31.   
  32.  
  33.     def __call__(self, environ, start_response): 
  34.  
  35.         self._status = '200 OK' # 默認(rèn)狀態(tài)OK 
  36.  
  37.         del self.headers[:] # 清空上一次的headers 
  38.  
  39.   
  40.  
  41.         result = self._delegate(environ) 
  42.  
  43.         start_response(self._status, self.headers) 
  44.  
  45.   
  46.  
  47.         # 將返回值result(字符串 或者 字符串列表)轉(zhuǎn)換為迭代對(duì)象 
  48.  
  49.         if isinstance(result, basestring): 
  50.  
  51.             return iter([result]) 
  52.  
  53.         else
  54.  
  55.             return iter(result) 
  56.  
  57.   
  58.  
  59.     def _delegate(self, environ): 
  60.  
  61.         path = environ['PATH_INFO'
  62.  
  63.         method = environ['REQUEST_METHOD'
  64.  
  65.   
  66.  
  67.         for pattern, name in self._urls: 
  68.  
  69.             m = re.match('^' + pattern + '$', path) 
  70.  
  71.             if m: 
  72.  
  73.                 # pass the matched groups as arguments to the function 
  74.  
  75.                 args = m.groups() 
  76.  
  77.                 funcname = method.upper() # 方法名大寫(xiě)(如GET、POST) 
  78.  
  79.                 klass = self._fvars.get(name) # 根據(jù)字符串名稱查找類對(duì)象 
  80.  
  81.                 if hasattr(klass, funcname): 
  82.  
  83.                     func = getattr(klass, funcname) 
  84.  
  85.                     return func(klass(), *args) 
  86.  
  87.   
  88.  
  89.         return self._notfound() 
  90.  
  91.   
  92.  
  93.     def _notfound(self): 
  94.  
  95.         self._status = '404 Not Found' 
  96.  
  97.         self.header('Content-type''text/plain'
  98.  
  99.         return "Not Found\n" 
  100.  
  101.   
  102.  
  103.     @classmethod 
  104.  
  105.     def header(cls, name, value): 
  106.  
  107.         cls.headers.append((name, value))  

對(duì)應(yīng)修改后的code.py(最終版本):

  1. #!/usr/bin/env python 
  2.  
  3. # -*- coding: utf-8 -*- 
  4.  
  5.   
  6.  
  7. """code.py""" 
  8.  
  9.   
  10.  
  11. from application import my_app 
  12.  
  13.   
  14.  
  15. urls = ( 
  16.  
  17.     ("/""index"), 
  18.  
  19.     ("/hello/(.*)""hello"), 
  20.  
  21.  
  22.   
  23.  
  24. wsgiapp = my_app(urls, globals()) 
  25.  
  26.   
  27.  
  28. class index
  29.  
  30.     def GET(self): 
  31.  
  32.         my_app.header('Content-type''text/plain'
  33.  
  34.         return "Welcome!\n" 
  35.  
  36.   
  37.  
  38. class hello: 
  39.  
  40.     def GET(self, name): 
  41.  
  42.         my_app.header('Content-type''text/plain'
  43.  
  44.         return "Hello %s!\n" % name 
  45.  
  46.   
  47.  
  48. if __name__ == '__main__'
  49.  
  50.     from wsgiref.simple_server import make_server 
  51.  
  52.     httpd = make_server('', 8086, wsgiapp) 
  53.  
  54.   
  55.  
  56.     sa = httpd.socket.getsockname() 
  57.  
  58.     print 'http://{0}:{1}/'.format(*sa) 
  59.  
  60.   
  61.  
  62.     # Respond to requests until process is killed 
  63.  
  64.     httpd.serve_forever()  

當(dāng)然,您還可以在code.py中配置更多的URL映射,并實(shí)現(xiàn)相應(yīng)的類來(lái)對(duì)請(qǐng)求作出響應(yīng)。

六、參考

本文主要參考了 How to write a web framework in Python(作者 anandology 是web.py代碼的兩位維護(hù)者之一,另一位則是大名鼎鼎卻英年早逝的 Aaron Swartz),在此基礎(chǔ)上作了一些調(diào)整和修改,并摻雜了自己的一些想法。

如果您還覺(jué)得意猶未盡,Why so many Python web frameworks? 也是一篇很好的文章,也許它會(huì)讓您對(duì)Python中Web框架的敬畏之心蕩然無(wú)存:-)

責(zé)任編輯:龐桂玉 來(lái)源: Python開(kāi)發(fā)者
相關(guān)推薦

2015-10-12 16:45:26

NodeWeb應(yīng)用框架

2016-09-14 17:48:44

2016-12-20 13:55:52

2022-04-01 15:18:42

Web 框架網(wǎng)絡(luò)通信

2020-07-20 10:00:52

Python翻譯工具命令行

2010-04-19 17:21:36

Oracle寫(xiě)文件

2018-10-31 10:11:24

Python編程語(yǔ)言語(yǔ)音播放

2022-03-24 14:42:19

Python編程語(yǔ)言

2020-09-29 15:08:47

Go UI框架開(kāi)發(fā)

2019-09-23 09:11:02

Python文本編輯器操作系統(tǒng)

2023-04-07 15:45:13

Emojicode開(kāi)源編碼語(yǔ)言

2021-05-14 10:45:21

PythonNoSQL數(shù)據(jù)庫(kù)

2017-05-18 12:16:03

LinuxPythonNoSql

2021-08-04 11:55:45

Python天氣查詢PySide2

2023-05-10 08:05:41

GoWeb應(yīng)用

2023-04-10 14:20:47

ChatGPTRESTAPI

2009-05-08 09:32:27

JavaWeb編程框架

2020-06-04 12:55:44

PyTorch分類器神經(jīng)網(wǎng)絡(luò)

2019-05-14 12:30:07

PythonPygame游戲框架

2014-04-14 15:54:00

print()Web服務(wù)器
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

久久久午夜精品| 久久xxxx精品视频| 日韩午夜av一区| 国产精品视频网站在线观看| 午夜精品久久久久久久第一页按摩 | 色哟哟网站在线观看| 狠狠操一区二区三区| 久久久噜噜噜久久人人看| 成人激情视频在线观看| 国产情侣在线视频| 999久久久国产精品| 精品国产乱码久久久久久夜甘婷婷| 国产精品50p| 91最新在线视频| 国产午夜精品久久久久久免费视 | 中文字幕欧美人妻精品| 欧美特黄一区| 日韩在线观看免费av| 992kp免费看片| 国产成人精品亚洲日本在线观看| 亚洲激情第一区| 日本在线视频不卡| 好吊视频一二三区| 国产美女一区二区三区| 国产91在线播放| 久久精品美女视频| **女人18毛片一区二区| 一级做a爰片久久毛片美女图片| 激情小说欧美色图| 粉嫩av一区二区三区四区五区| 亚洲va国产va欧美va观看| 中文精品视频一区二区在线观看| 能在线看的av| 成人毛片老司机大片| 成人日韩av在线| 中国一区二区视频| 日韩精品一二三区| 欧美孕妇与黑人孕交| 久久久久久久国产精品毛片| 91精品国产乱码久久久久久| 亚洲网站在线观看| 在线免费观看成年人视频| 国产精品99久久免费| 欧美性感一类影片在线播放| 欧美私人情侣网站| 中国字幕a在线看韩国电影| 亚洲高清视频中文字幕| 91网站在线观看免费| 成人av黄色| 亚洲精品国产精华液| 宅男一区二区三区| 欧美一区二区三区在线观看免费| 国产日韩三级在线| 日韩久久精品一区二区三区| 蜜桃视频在线观看网站| www精品美女久久久tv| 久久综合九色欧美狠狠| 色中色在线视频| 久久综合九色综合欧美就去吻| 精品无码久久久久久久动漫| 香蕉久久一区二区三区| 91麻豆国产福利在线观看| 免费观看成人高| 国产视频二区在线观看| 国产日韩v精品一区二区| 色婷婷精品国产一区二区三区| 精彩国产在线| 国产精品日韩精品欧美在线| 亚洲永久激情精品| av大大超碰在线| 亚洲www啪成人一区二区麻豆 | 男女男精品视频网| 国产精品福利小视频| 一本久道久久综合无码中文| 韩国一区二区在线观看| 97神马电影| 亚洲色欧美另类| 中文一区二区在线观看| 黄色网络在线观看| 91丝袜在线| 色乱码一区二区三区88| 成人黄色一级大片| 国产精品x8x8一区二区| 亚洲欧美激情一区| 国产成人av免费在线观看| 欧美一区二区三区久久精品茉莉花| 欧美激情视频一区| 天堂网视频在线| 国产又黄又大久久| 噜噜噜噜噜久久久久久91| 色综合久久影院| 亚洲18色成人| 在线观看免费av网址| 成人免费直播在线| 中文字幕亚洲图片| www.99re7.com| 日韩激情视频网站| 国产激情一区二区三区在线观看| 人成在线免费视频| 亚洲人成网站精品片在线观看| 久操网在线观看| 欧美少妇激情| 日韩精品视频在线观看免费| 午夜激情视频在线播放| 99精品免费| 91精品视频专区| 毛片在线播放网站| 亚洲综合激情另类小说区| 亚洲色图38p| 伦理一区二区| 欧美精品一区二区三区国产精品| 免费av中文字幕| 国产99久久久精品| 亚洲一区二区三区欧美| 欧美大胆a人体大胆做受| 8x8x8国产精品| 蜜桃传媒一区二区亚洲| 精品1区2区3区4区| 亚洲aaaaaa| 2021av在线| 色综合久久66| 性欧美丰满熟妇xxxx性久久久| 天天综合网91| 国产精品久久久久久久久免费| 天天综合在线视频| 亚洲国产日韩a在线播放| 九九九九九九九九| 精品免费在线| 热久久这里只有精品| 天天色棕合合合合合合合| 亚洲久草在线视频| 日日夜夜精品视频免费观看| 日韩毛片视频| 国产精品中文字幕在线观看| 色婷婷av一区二区三| 一区二区三区av电影| 亚洲综合在线一区二区| 五月天激情综合网| 成人国产精品久久久| 免费在线观看黄色| 欧美三区免费完整视频在线观看| 亚洲国产欧美视频| 欧美亚洲一区| 欧美一区二区视频在线| 亚洲精品www久久久| 亚洲视频在线观看日本a| 在线观看a级片| 91精品国产乱码久久蜜臀| 小向美奈子av| 久久99精品久久久久| 亚洲一区在线免费| 国产精品日韩精品在线播放| 日韩在线小视频| 国产精品探花视频| 亚洲精品国产a| 能看毛片的网站| 欧美精品一区二区三区久久久竹菊| 成人中文字幕在线观看| 国产精品剧情| 日韩免费一区二区| 久久久一二三区| 99这里都是精品| 日韩少妇内射免费播放18禁裸乳| 图片婷婷一区| 国产精品2018| 黄色网页在线观看| 欧美xxxx老人做受| 日本三级网站在线观看| 91伊人久久大香线蕉| 日本精品一区二区三区四区| 国产剧情一区| 成人久久久久久久| 波多野结衣乳巨码无在线观看| 亚洲成人精品视频| 国产亚洲欧美在线精品| 中文在线一区二区| 日韩高清一二三区| 新67194成人永久网站| 视频一区二区综合| 国内精品视频| 5566日本婷婷色中文字幕97| 国产51人人成人人人人爽色哟哟| 欧美福利一区二区| 日本亚洲欧美在线| 欧美韩国日本一区| 精品人妻一区二区乱码| 性伦欧美刺激片在线观看| 亚洲欧美成人一区| 国产精品18hdxxxⅹ在线| 国产高清在线不卡| 久久免费电影| 在线视频欧美性高潮| 精品人妻一区二区三区三区四区 | 日韩精品中文字幕在线| 成人黄色片在线观看| 亚洲精品第一国产综合野| 亚洲最大的黄色网| 紧缚捆绑精品一区二区| 免费看的黄色大片| 中文字幕av亚洲精品一部二部| 久久久久久草| 久久国际精品| 国产精品久久久久久av| 97人澡人人添人人爽欧美| 在线日韩第一页| 天天摸天天干天天操| 51精品视频一区二区三区| 国产精品第5页| 一区二区三区国产| 天堂网av2018| 国产午夜精品一区二区| 亚洲av成人精品一区二区三区| 久久国产精品色| 日本黄网站免费| 日韩视频二区| 2021狠狠干| 国产大片一区| 日韩三级电影| 真实原创一区二区影院| 粉嫩高清一区二区三区精品视频 | 免费看电影在线| 日韩中文av在线| 国产日本在线| 日韩精品亚洲精品| 蜜臀av午夜精品| 日韩一区二区三区电影| 亚洲中文一区二区三区| 91黄色激情网站| 国产高清中文字幕| 精品国产乱码久久久久久婷婷| 欧美激情一区二区视频| 亚洲三级理论片| 亚洲怡红院在线观看| 中文字幕av在线一区二区三区| 蜜桃av免费看| 久久久久久久久久久电影| 一出一进一爽一粗一大视频| 成人小视频在线| 中文字幕无人区二| 国产suv精品一区二区三区| 手机精品视频在线| 国产综合色在线视频区| 亚洲最大综合网| 日本中文字幕不卡| 国产又粗又长又大的视频| 久久人人97超碰国产公开结果| 国产特级黄色大片| 亚洲免费网址| 毛葺葺老太做受视频| 久久中文欧美| 在线免费观看视频黄| 欧美aaa在线| 奇米视频7777| 国产一区二区三区在线观看免费| 手机在线国产视频| 国产剧情一区在线| 稀缺小u女呦精品呦| 99久久er热在这里只有精品66| jlzzjizz在线播放观看| 久久综合狠狠综合久久激情| 国产精品三级在线观看无码| 91免费观看国产| 日本二区在线观看| 国产精品女主播在线观看| 免费成人深夜夜行网站| 亚洲乱码中文字幕综合| 久久久久亚洲AV| 欧美午夜激情在线| 最近中文字幕在线免费观看| 欧美精三区欧美精三区| 亚洲男人天堂久久| 日韩成人高清在线| 97电影在线观看| 欧美成人免费在线视频| а√天堂中文在线资源8| 日本精品性网站在线观看| 国产精品66| 成人一区二区三区四区| 首页亚洲中字| 中文字幕中文字幕在线中一区高清| 欧美在线播放| 久久无码高潮喷水| 久久精品国产亚洲高清剧情介绍| 亚洲国产综合av| 久久这里只精品最新地址| 少妇高潮一区二区三区喷水| 一区二区日韩av| 91视频久久久| 精品久久久久久久人人人人传媒 | 欧美激情在线观看| 无人区在线高清完整免费版 一区二| 91精品久久久久久久久中文字幕 | 性欧美videohd高精| 91色中文字幕| 日韩有码中文字幕在线| 中文字幕剧情在线观看一区| 夜久久久久久| 婷婷激情小说网| 久久久青草青青国产亚洲免观| 日本精品人妻无码77777| 精品久久在线播放| 国产精品毛片一区二区在线看舒淇| 精品国产1区2区3区| 91亚洲欧美| 9.1国产丝袜在线观看| 欧日韩不卡在线视频| 免费精品一区| 相泽南亚洲一区二区在线播放 | 亚洲天堂免费在线观看视频| 91看片在线播放| 欧美一二区视频| 在线观看a视频| 97视频色精品| ccyy激情综合| 大地资源第二页在线观看高清版| 午夜综合激情| 亚洲一区二区乱码| 亚洲一区影音先锋| 在线免费av片| 亚洲最新av在线网站| 国产免费拔擦拔擦8x在线播放 | 国产丝袜视频在线观看 | 日本理论片午伦夜理片在线观看| 国产精品成人一区| 日韩高清在线免费观看| 国产成人在线小视频| 国产综合久久久久影院| 超薄肉色丝袜一二三| 黑人巨大精品欧美一区二区| www香蕉视频| 欧美精品性视频| 国产成年精品| 黄色www在线观看| 久久se这里有精品| 国产日产在线观看| 欧美日韩一区二区三区在线看| 免费在线超碰| 国产成人一区二区三区| 综合亚洲自拍| 红桃av在线播放| 久久亚洲影视婷婷| av网站中文字幕| 亚洲精品中文字幕女同| 制服丝袜专区在线| 欧洲久久久久久| 青青草国产精品97视觉盛宴| 免费一级做a爰片久久毛片潮| 日韩欧美一区二区三区| 每日更新av在线播放| 国产精品电影久久久久电影网| 九九久久精品| 日本va中文字幕| 国产精品午夜在线| 国产原创中文av| 欧美成人午夜激情在线| 日韩区欧美区| 99色这里只有精品| 2021国产精品久久精品| 波多野结衣午夜| 日韩亚洲欧美中文高清在线| 亚洲欧美综合久久久久久v动漫| 在线视频亚洲自拍| 成人丝袜18视频在线观看| 日韩av男人天堂| 亚洲欧美精品在线| 久久99国产精品二区高清软件| 这里只有精品66| 成人性生交大片免费看中文网站| xxxx 国产| 国产香蕉一区二区三区在线视频| 日韩欧国产精品一区综合无码| 免费成人进口网站| av在线不卡免费看| 国产又粗又猛又爽又| 久久久成人精品视频| 黑色丝袜福利片av久久| 凹凸日日摸日日碰夜夜爽1| 国产精品嫩草99a| 懂色av一区二区三区四区| 欧美一区二区三区四区在线| 日韩不卡一区| 国产亚洲精品成人a| 色老汉一区二区三区| 黄色av电影在线播放| 国产区二精品视| 免费观看30秒视频久久| 精品无码人妻一区二区三区品| 亚洲欧美日韩精品久久亚洲区 | 久久综合婷婷| 亚洲国产精品久| 亚洲午夜av电影| 亚洲午夜免费| 一级在线免费视频| 亚洲高清视频在线| 免费a级人成a大片在线观看| 国产欧美一区二区视频 | 99久久人妻无码中文字幕系列| 欧美视频在线观看一区二区| 搞黄网站在线看| 一区二区三区的久久的视频|