久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

如何理解python接口自動化之logging日志模塊

瀏覽:3日期:2022-06-16 16:04:41
目錄一、logging模塊介紹二、日志等級三、日志收集器四、日志處理器五、日志過濾器六、日志格式器七、日志滾動八、模塊封裝一、logging模塊介紹

​前言:我們之前運行代碼時都是將日志直接輸出到控制臺,而實際項目中常常需要把日志存儲到文件,便于查閱,如運行時間、描述信息以及錯誤或者異常發生時候的特定上下文信息。

​Python中自帶的logging模塊提供了標準的日志接口,在debug時使用往往會事半功倍。為什么不直接使用print去輸出呢?這種方式對簡單的腳本來說有用,對于復雜的系統來說相當于一個花瓶擺設,大量的print輸出很容易被遺忘在代碼里,并且print是標準輸出,這很難從一堆信息里去判斷哪些是你需要重點關注的。

​logging的優勢就在于可以控制日志的級別,把不需要的信息進行過濾,且可以決定它輸出到什么地方、如何輸出,還可以通過控制等級把特定等級的信息輸出到特定的位置等。logging一共分為四個部分:

Loggers:日志收集器,可供程序直接調用的接口,app通過調用提供的api來記錄日志 Handlers:日志處理器, 決定將日志記錄分配至正確的目的地 Filters:日志過濾器,對日志信息進行過濾, 提供更細粒度的日志是否輸出的判斷 Formatters:日志格式器,制定最終記錄打印的格式布局二、日志等級

​logging將logger的等級劃分成5個level,由低到高分別是DEBUG、INFO、WARNING、ERROE、CRITICAL,默認是WARNING級別,CRITICAL最高,相關等級說明如下:

Level 說明 DEBUG 輸出詳細的運行信息,主要用于調試,追蹤問題時使用 INFO 輸出正常的運行的信息,一切按預期進行的情況 WARNING 一些意想不到的或即將會發生的情況,比如警告:內存空間不足,但不影響程序運行 ERROR 由于某些問題,程序的一些功能會受到影響,還可以繼續運行 CRITICAL 一個嚴重的錯誤,表明程序本身可能無法繼續運行

​這些等級的日志中低包含高,比如INFO,會收集INFO及以上等級的日志,DEBUG等級的日志將不進行收集。下面我們來輸出這5個等級的日志:

import logging'''logging模塊默認收集的日志是warning以上等級的'''a = 100logging.debug(a)logging.info(’這是INFO等級的信息’)logging.warning(’這是WARNING等級的信息’)logging.error(’這是ERROR等級的信息’)logging.critical(’這是CRITICAL等級的信息’)

​輸出結果:

C:softwarepythonpython.exe D:/learn/test.py

WARNING:root:這是WARNING等級的信息

ERROR:root:這是ERROR等級的信息

CRITICAL:root:這是CRITICAL等級的信息

Process finished with exit code 0

三、日志收集器

​日志是怎么被收集和輸出的呢?答案就是日志收集器,設置一個收集器,把指等級的日志信息輸出到指定的地方,控制臺或文件等,其工作過程大致如下:

如何理解python接口自動化之logging日志模塊

​logging中默認的日志收集器是root,收集等級默認是WARNING,我們可以通過setLevel來改變它的收集等級。

# 獲取默認的日志收集器rootmy_log = logging.getLogger()# 設置默認的日志收集器等級my_log.setLevel('DEBUG') # 日志將全部被收集a = 100logging.debug(a)logging.info(’這是INFO等級的信息’)logging.warning(’這是WARNING等級的信息’)logging.error(’這是ERROR等級的信息’)logging.critical(’這是CRITICAL等級的信息’)

​輸出結果:

C:softwarepythonpython.exe D:/learn/test.py

DEBUG:root:100

INFO:root:這是INFO等級的信息

WARNING:root:這是WARNING等級的信息

ERROR:root:這是ERROR等級的信息

CRITICAL:root:這是CRITICAL等級的信息

Process finished with exit code 0

​除了使用默認的日志收集器,我們也可以自己創建一個收集器logging.getLogger,如下:

import loggingmy_logger = logging.getLogger(’my_logger’)# 創建logging對象my_logger.setLevel(’INFO’)# 設置日志收集等級a = 100logging.debug(a)logging.info(’這是INFO等級的信息’)logging.warning(’這是WARNING等級的信息’)logging.error(’這是ERROR等級的信息’)logging.critical(’這是CRITICAL等級的信息’)

​輸出結果:

C:softwarepythonpython.exe D:/learn/test.py

WARNING:root:這是WARNING等級的信息

ERROR:root:這是ERROR等級的信息

CRITICAL:root:這是CRITICAL等級的信息

Process finished with exit code 0

四、日志處理器

​上面例子中設置的收集器都是輸出到控制臺,除此我們還可以輸出到文件中。

​Handlers(處理器)的作用就是將logger發過來的信息進行準確地分配,送往正確的地方。比如,送往控制臺、文件或者是兩者。它決定了每個日志收集器的行為,是創建收集器之后需要配置的重點區域。每個Handler同樣有一個日志級別,一個logger可以擁有多個handler也就是說logger可以根據不同的日志級別將日志傳遞給不同的handler。當然也可以相同的級別傳遞給多個handler,這就根據需求來靈活的配置了。

​下面實例中設置了兩個handler,一個是輸出到控制臺,一個是輸出到文件中。關鍵代碼:

logging.StreamHandler:輸出到控制臺的處理器 logging.FileHandler:輸出到文件的處理器 addHandler:添加處理器 removeHandler:移除處理器

import loggingmy_logger = logging.getLogger(’my_logger’)my_logger.setLevel(’INFO’)# 創建一個輸出到控制臺的處理器sh = logging.StreamHandler()sh.setLevel('ERROR') # 設置處理器的輸出等級my_logger.addHandler(sh) # 將處理器綁定到日志收集器上# 創建一個輸出到文件的處理器fh = logging.FileHandler('logs.logs', encoding='utf8')fh.setLevel('INFO')my_logger.addHandler(fh)# my_logger.removeHandler(fh)# 移除處理器a = 100my_logger.debug(a)my_logger.info(’這是INFO等級的信息’)my_logger.warning(’這是WARNING等級的信息’)my_logger.error(’這是ERROR等級的信息’)my_logger.critical(’這是CRITICAL等級的信息’)

運行結果:

C:softwarepythonpython.exe D:/learn/test.py

這是ERROR等級的信息

這是CRITICAL等級的信息

Process finished with exit code 0

如何理解python接口自動化之logging日志模塊

五、日志過濾器

​Filters可以實現比level更復雜的過濾功能,限制只有滿足過濾規則的日志才會被輸出。比如我們定義了filter = logging.Filter(’A.B’),并將這個Filter添加到了一個Handler上,則使用該Handler的Logger中只有名字帶A.B前綴的Logger才能輸出其日志。下面是一個簡單實例:

import logging# 這是logger1my_logger = logging.getLogger(’A.C,B’)my_logger.setLevel(’INFO’)# 這是logger2my_logger2 = logging.getLogger(’A.B’)my_logger2.setLevel(’INFO’)# 創建一個處理器,兩個logger都使用這個處理器sh = logging.StreamHandler()sh.setLevel('ERROR')my_logger.addHandler(sh)my_logger2.addHandler(sh)# 創建一個過濾器綁到處理器上my_filter = logging.Filter(name=’A.B’)sh.addFilter(my_filter) # 把過濾器添加到處理器上# sh2.removeFilter(my_filter) # 移除過濾器my_logger.debug(’這是logger1-DEBUG等級的信息’)my_logger.info(’這是logger1-INFO等級的信息’)my_logger.warning(’這是logger1-WARNING等級的信息’)my_logger.error(’這是logger1-ERROR等級的信息’)my_logger.critical(’這是logger1-CRITICAL等級的信息’)my_logger2.debug(’這是logger2-DEBUG等級的信息’)my_logger2.info(’這是logger2-INFO等級的信息’)my_logger2.warning(’這是logger2-WARNING等級的信息’)my_logger2.error(’這是logger2-ERROR等級的信息’)my_logger2.critical(’這是logger2-CRITICAL等級的信息’)

​因為只有logger2滿足過濾器的條件,因此只會輸出logger2的日志,運行結果如下:

C:softwarepythonpython.exe D:/learn/test.py

這是logger2-ERROR等級的信息

這是logger2-CRITICAL等級的信息

Process finished with exit code 0

​filter方法用于具體控制傳遞的record記錄是否能通過過濾,如果該方法返回值為0表示不能通過過濾,非0表示可以通過過濾。

六、日志格式器

​顧名思義,對日志進行格式化,因為常規的日志輸出并不直觀美觀,通過美化日志的輸出格式,可以讓我們閱讀起來更加舒服。

​format常用格式如下:

%(name)s: 打印收集器名稱 %(levelno)s: 打印日志級別的數值 %(levelname)s: 打印日志級別名稱 %(pathname)s: 打印當前執行程序的路徑,其實就是sys.argv[0] %(filename)s: 打印當前執行程序名 %(funcName)s: 打印日志的當前函數 %(lineno)d: 打印日志的當前行號 %(asctime)s: 打印日志的時間 %(thread)d: 打印線程ID %(threadName)s: 打印線程名稱 %(process)d: 打印進程ID %(message)s: 打印日志信息

import loggingmy_logger = logging.getLogger(’A.C,B’)my_logger.setLevel(’INFO’)# 創建一個處理器sh = logging.StreamHandler()sh.setLevel('ERROR')my_logger.addHandler(sh)# 設置一個格式,并設置到處理器上formatter = logging.Formatter(’%(asctime)s - [%(filename)s-->line:%(lineno)d] - %(levelname)s: %(message)s’)sh.setFormatter(formatter)my_logger.debug(’這是logger1-DEBUG等級的信息’)my_logger.info(’這是logger1-INFO等級的信息’)my_logger.warning(’這是logger1-WARNING等級的信息’)my_logger.error(’這是logger1-ERROR等級的信息’)my_logger.critical(’這是logger1-CRITICAL等級的信息’)

​運行結果:

C:softwarepythonpython.exe D:/learn/test.py

2020-08-01 18:28:43,645 - [test.py-->line:17] - ERROR: 這是logger1-ERROR等級的信息

2020-08-01 18:28:43,645 - [test.py-->line:18] - CRITICAL: 這是logger1-CRITICAL等級的信息

Process finished with exit code 0

七、日志滾動

​如果你用 FileHandler 存儲日志,文件的大小會隨著時間推移而不斷增大,最終有一天它會占滿你所有的磁盤空間。Python 的 logging 模塊提供了兩個支持日志滾動的 FileHandler 類,分別是 RotatingFileHandler 和 TimedRotatingFileHandler,它就可以解決這個尷尬的問題。

RotatingFileHandler 的滾動時刻是日志文件的大小達到一定值,當達到指定值的時候,RotatingFileHandler會將日志文件重命名存檔,然后打開一個新的日志文件。 TimedRotatingFileHandler 是當某個時刻到來時就進行滾動,同 RotatingFileHandler 一樣,當滾動時機來臨時,TimedRotatingFileHandler 會將日志文件重命名存檔,然后打開一個新的日志文件。

​在實際應用中,我們通常會根據時間進行滾動,以下實例也以時間滾動為例,按大小滾動的同理:

import loggingfrom logging.handlers import TimedRotatingFileHandlermy_logger = logging.getLogger(’A.C,B’)my_logger.setLevel(’INFO’)# 創建一個處理器,使用時間滾動的文件處理器log_file_handler = TimedRotatingFileHandler(filename=’log.log’, when=’D’, interval=1, backupCount=10)# log_file_handler.suffix = '%Y-%m-%d'# log_file_handler.extMatch = re.compile(r'^d{4}-d{2}-d{2}.log$')log_file_handler.setLevel('ERROR')my_logger.addHandler(log_file_handler)# 設置一個格式,并設置到處理器上formatter = logging.Formatter(’%(asctime)s - [%(filename)s-->line:%(lineno)d] - %(levelname)s: %(message)s’)log_file_handler.setFormatter(formatter)my_logger.debug(’這是logger1-DEBUG等級的信息’)my_logger.info(’這是logger1-INFO等級的信息’)my_logger.warning(’這是logger1-WARNING等級的信息’)my_logger.error(’這是logger1-ERROR等級的信息’)my_logger.critical(’這是logger1-CRITICAL等級的信息’)

​參數說明:

filename:日志文件名;

when:是一個字符串,用于描述滾動周期的基本單位,字符串的值及意義如下:

S - Seconds M - Minutes H - Hours D - Days midnight - roll over at midnight W{0-6} - roll over on a certain day; 0 - Monday

interval: 滾動周期,單位由when指定,比如:when=’D’,interval=1,表示每天產生一個日志文件;

backupCount: 表示日志文件的保留個數;

​除了上述參數之外,TimedRotatingFileHandler還有兩個比較重要的成員變量,它們分別是suffix和extMatch。suffix是指日志文件名的后綴,suffix中通常帶有格式化的時間字符串,filename和suffix由“.”連接構成文件名(例如:filename='test', suffix='%Y-%m-%d.log',生成的文件名為test.2020-08-01.log。extMatch是一個編譯好的正則表達式,用于匹配日志文件名的后綴,它必須和suffix是匹配的,如果suffix和extMatch匹配不上的話,過期的日志是不會被刪除的。比如,suffix=“%Y-%m-%d.log”, extMatch的只能是re.compile(r'^d{4}-d{2}-d{2}.log$')。默認情況下,在TimedRotatingFileHandler對象初始化時,suffxi和extMatch會根據when的值進行初始化:

S:suffix='%Y-%m-%d_%H-%M-%S',extMatch=r'^d{4}-d{2}-d{2}_d{2}-d{2}-d{2}';M:suffix='%Y-%m-%d_%H-%M',extMatch=r'^d{4}-d{2}-d{2}_d{2}-d{2}';H:suffix='%Y-%m-%d_%H',extMatch=r'^d{4}-d{2}-d{2}_d{2}';D:suffxi='%Y-%m-%d',extMatch=r'^d{4}-d{2}-d{2}';MIDNIGHT:'%Y-%m-%d',extMatch=r'^d{4}-d{2}-d{2}';W:'%Y-%m-%d',extMatch=r'^d{4}-d{2}-d{2}';

​如果對日志文件名沒有特殊要求的話,可以不用設置suffix和extMatch,如果需要,一定要讓它們匹配上。

八、模塊封裝

​一次封裝,一勞永逸,之后直接調用即可,封裝內容按需。

import loggingfrom logging.handlers import TimedRotatingFileHandlerclass MyLogger(object): @staticmethod def create_logger():my_logger = logging.getLogger('my_logger')my_logger.setLevel('DEBUG')# 控制臺處理器stream_handler = logging.StreamHandler()stream_handler.setLevel('ERROR')my_logger.addHandler(stream_handler)# 使用時間滾動的文件處理器log_file_handler = TimedRotatingFileHandler(filename=’log.log’, when=’D’, interval=1, backupCount=10)log_file_handler.setLevel('INFO')my_logger.addHandler(log_file_handler)formatter = logging.Formatter(’%(asctime)s - [%(filename)s-->line:%(lineno)d] - %(levelname)s: %(message)s’)stream_handler.setFormatter(formatter)log_file_handler.setFormatter(formatter)return my_logger

以上就是如何理解python接口自動化之logging日志模塊的詳細內容,更多關于python 接口自動化 logging日志模塊的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 福利网址 | 美女国产网站 | 综合网视频 | 91精品国产色综合久久不卡98口 | 男女激情网址 | 国产精品美女久久久久久久久久久 | 日韩一区二区三区在线 | 国产精品国产精品国产专区不卡 | 国产视频一区二区 | 91免费版在线观看 | 中文字幕欧美激情 | 亚洲一区日韩 | 久久久网 | 一呦二呦三呦国产精品 | 日韩中文字幕一区 | 欧美日本韩国一区二区 | 日韩视频中文字幕在线观看 | 欧洲亚洲精品久久久久 | 国产天天操 | 成人在线黄色 | 国产浪潮av色综合久久超碰 | 日韩成人小视频 | 荷兰欧美一级毛片 | 在线观看欧美一区 | 91精品国产一区二区 | www夜夜操com | 夜添久久精品亚洲国产精品 | 天天干天天操天天干 | 成人免费一区二区三区视频软件 | 久久人人爽人人爽人人片av不 | 亚洲国产精品久久 | 亚洲成人精品在线观看 | 午夜av电影 | 夜夜操导航 | 成人精品国产免费网站 | 欧美午夜一区二区三区免费大片 | 久久婷婷国产麻豆91天堂 | 亚洲国产一区二 | 福利在线看| 亚洲视频在线一区 | 国产精国产精品 | 天天操综合网 | 一级黄色片欧美 | 亚洲一区中文字幕 | 日韩国产在线观看 | 日韩久久影院 | 日韩欧美一级 | 久久久久一区二区三区 | 中文在线资源 | 日韩成人在线网站 | 天天拍天天操 | 国产精品无码永久免费888 | 久久99精品久久久久久青青日本 | 一区二区亚洲 | 日韩a级免费视频 | 精品久久一二三区 | 欧美日韩一区二区电影 | 国产午夜精品一区二区三区 | 午夜tv | 韩国久久精品 | 精品免费国产视频 | 最新国产视频 | 夜夜av| 午夜影院男女 | 久久久精品网站 | 久久a视频 | 亚洲一区二区在线 | 亚洲免费视频大全 | 午夜影皖 | 国产福利视频 | 成人免费视频网 | 久久中文字幕一区 | av毛片| 精品久久久久久久久久久久久久 | 久久综合久久综合久久 | 杏导航aⅴ福利网站 | 久久精品国产精品青草 | 波多野结衣先锋影音 | 黄色大片免费网址 | 日韩一区二区精品视频 | 午夜影院免费观看视频 | 免费成人在线网站 | 久久久国产精品入口麻豆 | 久久综合亚洲 | 成人免费网站在线观看 | 欧美美乳 | 亚洲一区二区三区视频免费观看 | 国产高清一级毛片在线不卡 | 青青久久网| 中文字幕欧美日韩一区 | 2019国产精品| 亚洲国产成人精品女人久久久 | 九色一区二区 | 亚洲精品中文字幕中文字幕 | 男人的天堂视频网站 | 午夜免费观看网站 | 日日想日日干 | 精品视频一区二区 | 欧美成人综合视频 | 日韩欧美一区二区三区久久婷婷 | 91午夜精品一区二区三区 | 在线观看亚洲精品 | 日韩精品在线播放 | 免费激情av | 国产精品成人一区二区三区 | 国产99久久久精品视频 | 久久99国产精品久久99大师 | 我要看黄色一级大片 | 蜜月va乱码一区二区三区 | 男女全黄一级一级高潮免费看 | 亚洲成人动漫在线观看 | 欧美一级二级三级视频 | 能免费看的av | 亚洲国产一区视频 | 天天干,夜夜操 | 蜜臀精品久久久久久蜜臀 | 亚洲成年人影院 | 日本黄色一级片免费看 | 国产欧美精品一区二区色综合 | av黄色一级片 | 国产精品永久 | 好姑娘影视在线观看高清 | a欧美| 91视频网址| 欧美久久成人 | 91免费视频观看 | 国产日韩欧美视频 | 视频1区2区 | 国产丝袜视频 | 免费看片国产 | 亚洲三级在线 | 中文字幕一区二区三区四区不卡 | 国产日韩精品一区二区 | 夜夜av| 国产成人高清精品免费5388 | 欧美日韩精品一区二区在线播放 | 在线成人www免费观看视频 | 天堂久久久久久 | 五月婷综合 | 久久久999精品视频 五月天婷婷在线视频 | 精品96久久久久久中文字幕无 | 亚洲视频一区在线 | 精品一区二区电影 | 欧美理论视频 | 97国产精品久久久 | 免费观看黄色大片 | 最新国产视频 | 国产成人jvid在线播放 | 蜜桃精品久久久久久久免费影院 | 太平公主一级艳史播放高清 | 精品一区二区在线播放 | 国产精久 | 国产毛片在线看 | 女人夜夜春 | 中文字幕免费在线 | 亚洲热妇 | 午夜日韩 | 婷婷免费在线观看 | 美国黄色毛片女人性生活片 | 91精品国产综合久久久久久漫画 | 视频一区二区中文字幕日韩 | k8久久久一区二区三区 | 成人av网站在线观看 | 一本一本久久a久久精品综合妖精 | 超碰人操 | 国产xxx护士爽免费看 | av在线免费网址 | 日本欧美久久久久免费播放网 | 91久久艹 | 蜜桃在线视频 | 做a视频在线观看 | 91av久久| 免费在线观看成年人视频 | 中文字幕av一区二区 | 毛片一区| 色综合久 | 国产成人精品999在线观看 | 亚洲欧洲综合av | 久久亚洲二区 | 欧美日本乱大交xxxxx | 免费在线a | 午夜影晥 | 国产成人亚洲综合 | 国产欧美精品一区二区三区 | 亚洲精品中文视频 | 91精品久久久久久久久中文字幕 | 女男羞羞视频网站免费 | 日韩一区久久 | 国产精品亚洲一区二区三区在线 | 国产黄色大片免费观看 | 免费观看一区二区三区 | 一级毛片免费高清 | 国产乱淫av片 | 成人性大片免费观看网站 | 日韩大尺度电影在线观看 | 精品欧美乱码久久久久久1区2区 | 国产成人av一区 | 天天操妹子 | 欧美99 | 亚洲欧美另类久久久精品2019 | 操操操操操操操操操操操操操操 | 国产区在线 | 亚洲人视频 | 天天操天天干天天干 | 亚洲成a人v欧美综合天堂麻豆 | 中文字幕亚洲欧美日韩在线不卡 | 欧美一区二区在线视频 | 久久国产精品视频 | 涩涩操 | 国产亚洲精品美女久久久久久久久久 | 欧美成人免费在线视频 | 国产精品一区亚洲二区日本三区 | 国产成人综合av | 欧美一级二级三级 | 久久久.com | 欧美午夜一区二区三区 | 一区二区日韩 | 嫩草最新网址 | 羞羞网页 | 午夜视频在线播放 | 99精品网 | 亚洲麻豆精品 | 美女操网站 | 国产精品久久久久久久免费大片 | 一区二区三区免费在线观看 | 日本狠狠色 | 日韩久久久久 | 国产黄色大片 | 久久99精品久久久 | 国产精品久久久久久久久免费 | 日韩一区二区中文字幕 | 久久国产精品免费一区二区三区 | 天堂中文资源在线 | 老牛影视av一区二区在线观看 | 超碰美女| 毛片免费看 | 成人免费高清视频 | 亚洲毛片在线观看 | www.亚洲| 国产精品45p | 免费观看一级毛片 | 久久久久久久久久久久91 | 亚洲色图在线播放 | 国产一区二区在线看 | 一级激情片 | 激情欧美日韩一区二区 | 91免费看网站 | 久草视频网 | 精品成人免费视频 | 精品久久久久久久久久久久久久 | 精品久久伊人 | 欧美精品在线观看 | 亚洲 欧美 精品 | 欧洲成人午夜免费大片 | 色婷婷一区二区三区四区 | 日韩国产在线 | 在线观看欧美一区 | 色播久久久 | 欧美天天| a成人在线 | 国产亚洲欧美在线 | 亚洲精品在线视频 | 999久久久国产精品 欧美成人h版在线观看 | 国产中文字幕一区 | 久久精品国产一区 | 日韩欧美在线一区二区 | 中文字幕在线视频网站 | 夜夜草av| xnxx 日本19| 色婷婷久久久swag精品 | 国产日韩精品一区二区 | 国产中文字幕在线 | 黄色a视频| 精品久久久久久国产 | 欧洲尺码日本国产精品 | 亚洲视频在线一区 | 美女精品视频在线 | 免费v片 | www.一区二区 | 久久久www成人免费精品 | 国产精品乱码一区二区三区 | 在线成人av| 嫩草视频在线观看免费 | 国产一区免费视频 | 国产日韩精品视频 | 蜜桃免费视频 | 在线久 | 老司机精品福利视频 | 国产精品日韩欧美一区二区三区 | 久久成人免费视频 | 久久一区视频 | 欧美一区二区在线免费观看 | 亚洲欧美中文日韩在线v日本 | 中文字幕一二三 | 成人一级片在线观看 | 国产精品粉嫩白浆在线观看 | 91视频免费观看网址 | 成人免费看黄 | 国产一区二区视频免费 | 天天久 | 成人综合区| 亚洲免费婷婷 | 永久精品 | 午夜成人免费影院 | av在线播放网站 | av下一页 | 欧美视频在线一区 | 久久国产精品影视 | 国产精品一区二区三区在线播放 | 蜜桃视频一区二区三区 | 成人欧美一区二区三区黑人孕妇 | 久久久成人精品 | 久久久精品免费观看 | 欧美三级在线 | 欧美日韩一区精品 | 久久久蜜桃 | 乱轮一区 | 在线中文字幕视频 | 成人看片在线观看 | 99这里只有精品 | 亚洲美女在线视频 | 国产精品综合视频 | 特级淫片日本高清视频免费 | 亚洲综合在线视频 | 97超碰站| www.国产在线| 亚洲一区二区在线播放 | 日韩免费 | 久久人人爽人人爽人人片av高清 | 在线观看国产一级片 | 免费av一区二区三区 | 免费毛片一区二区三区久久久 | 新疆少妇videos高潮 | 久久精品亚洲 | 国产69精品99久久久久久宅男 | 久久精品一 | 亚洲精品久久久一区二区三区 | 国产免费看| 午夜专区 | 亚洲一区二区三区四区在线 | 国产成人免费 | 在线观看三级av | 天天舔天天干 | 日韩国产欧美 | 成人一区二区av | 亚洲视频在线观看免费 | 国产美女自拍视频 | 日韩大尺度电影在线观看 | www国产在线观看 | 久综合网 | 亚洲国产高清视频 | 精品一区二区三区免费看 | 国产日韩精品一区二区 | 亚洲a精品| 一级免费毛片 | 成人精品一区二区三区中文字幕 | 日日干夜夜骑 | 中文字幕第一页在线 | 一级电影院 | 国产精品日韩欧美 | 国产中文字幕在线播放 | 欧美激情综合五月色丁香小说 | 一级黄色片日本 | 国产51人人成人人人人爽色哟哟 | 日韩欧美成人一区二区三区 | www日本视频 | 久久视频一区 | 久久伊人草 | 99久久精品一区二区 | 国产91一区 | 欧美综合国产精品久久丁香 | 日韩中文字幕一区二区高清99 | 黄色网在线看 | 久久小视频 | 日韩欧美手机在线 | 久久99这里只有精品 | 色偷偷888欧美精品久久久 | 羞羞视频免费观看 | 亚洲国产精品一区二区三区 | 黑人巨大精品欧美一区二区小视频 | 2019中文字幕视频 | 日日干夜夜操 | 中文字幕在线看第二 | 亚洲欧美日韩另类精品一区二区三区 | 日干夜操 | www.99久| 久久久久网站 | 成人在线国产 | 欧美精品网 | 精品国产一区二区三区久久影院 | 亚洲成人日韩 | 亚洲一区二区三区在线视频 | 一区二区三区高清不卡 | 久久叉 | 国产精品国产精品国产专区不片 | 国产色播av在线 | 久久久精 | 精品久久一区二区 | 久久91精品国产 | 一级日批片 | 曰韩毛片 | 老牛嫩草一区二区三区眼镜 | 毛片网站在线观看 | 免费av在线播放 | 亚洲伦理一区 | 中文字字幕一区二区三区四区五区 | 狠狠干av| 欧美一级二级视频 | 久久久久久亚洲 | 国产精品精品视频一区二区三区 | 日本不卡免费新一二三区 | 日本在线免费 | av片免费 | 成人午夜在线观看 | 日日夜夜精品 | 中文字幕在线看第二 | 成年人视频免费在线看 | 精品国产三级a在线观看 | 国产成人久久 | 亚洲国产成人久久综合一区,久久久国产99 | 国产精品久久久久一区二区三区共 | 91国内视频在线观看 | av网站免费观看 | 中文字幕在线免费看 | www.色综合| 午夜精品久久久久久久久久久久 | 国产伦精品一区二区三区高清 | 午夜久久久久 | 中文无码久久精品 | 精品国产乱码久久久久久1区2区 | www.操.com| 国产麻豆乱码精品一区二区三区 | 日韩欧美国产精品综合嫩v 国产高清av在线一区二区三区 | 99热日本| 日操 | 久草热8精品视频在线观看 黄色片网站视频 | 国产精品一区二区在线观看 | 亚洲精品成人网 | 国产欧美精品一区二区三区四区 | 国产福利一区二区三区四区 | 91精品视频在线播放 | 久久99国产精品久久99大师 | 亚洲第1页 | 国产亚洲一区二区精品 | 天天射影院 | 亚洲天堂久久 | 亚洲精品乱码久久久久久9色 | 久久电影一区 | 日韩欧美综合 | 欧美日韩中文字幕 | 亚洲一区 中文字幕 | 久久mm | 九九99九九| 伊人二区 | 久久国产精品久久 | 农村妇女毛片精品久久久 | 亚州成人| 99re在线观看 | 四虎成人永久 | 久久精品免费看 | 天堂中文视频在线观看 | 日韩在线观看一区二区 | 久草精品视频 | 欧美一级高潮片免费的 | 精品91| 日本末发育嫩小xxxx | 国产在线精品二区 | 日本三级做a全过程在线观看 | 国产在线不卡 | 日本黄色一级电影 | 亚洲一区在线视频 | 91夜夜| 在线观看91 | 国产一区二精品区在线 | 日本黄色毛片 | 久久999| 日韩免费在线观看视频 | 日韩视频一区二区三区 | 一级片网| 久久久久亚洲av毛片大全 | 亚洲91| 最新日韩精品在线观看 | 91高清视频在线观看 | 成人羞羞网站 | 欧美精品一区二区蜜臀亚洲 | 精品国产一区二区三区免费 | av免费观看网站 | 久久国产亚洲精品 | 最新午夜 | 在线日韩视频 | 精品一区二区在线观看 | 91视频免费观看 | 日本妇人成熟免费视频 | 欧美一区二区三区在线看 | 国产精品亚洲一区二区三区 | 亚洲一区二区三区中文字幕 | 中文字幕一区二区三区四区不卡 | 欧美一区二区三区 | 亚洲 中文 欧美 日韩 在线观看 | 日韩福利视频网 | 欧美成人在线免费观看 | 日韩一区二区免费视频 | 久久白虎| 欧美自拍网站 | 亚洲第一成年免费网站 | 日韩福利视频 | 日韩欧美在线视频观看 | 福利视频网 | 国产在线资源 | 国产一区二区三区在线免费观看 | 四虎视频 | 99久久精品一区二区成人 | 99久久夜色精品国产网站 | 成人a在线视频 | 超碰首页 | 亚洲精品乱码久久久久久蜜桃不卡 | 亚洲国产精品一区二区久久,亚洲午夜 | 免费黄色片在线观看 | 国精产品一区二区三区黑人免费看 | 精品国产精品三级精品av网址 | 国产区视频在线观看 | 中文字幕亚洲字幕一区二区 | 欧美日韩综合精品 | 中文视频在线 | 日韩久久久久 | 国产亚洲精品久久久久久久久 | 精品一区二区三区久久久 | 久久精品伊人 | 日本不卡高字幕在线2019 | 久草视 | 欧美成人精品一区二区男人看 | 在线观看欧美日韩视频 | 三级av在线 | 一区二区三区欧美在线 | 欧美一级片在线观看 | 精品视频网 | 在线免费观看色视频 | 国产精品欧美久久久久一区二区 | 日韩精品一区二 | 中文字幕 亚洲一区 | 一级毛片aaaaaa免费看 | 国产一级免费在线观看 | 国产成人精品一区二 | 中文字幕在线视频第一页 | 精品一区二区久久久久久久网站 | 五月在线视频 | 激情综合色综合久久综合 | 日日摸天天爽天天爽视频 | 久久国产成人 | 精品亚洲一区二区三区 | 麻豆av在线播放 | 成人福利 | 精品日韩欧美一区二区在线播放 | 成人在线免费视频 | 国产高清久久久 | www中文字幕| 国产精品毛片 | 91av导航| 噜噜噜天天躁狠狠躁夜夜精品 | 中文字幕亚洲一区 | 久久99精品久久久久婷婷暖91 | 97国产精品视频人人做人人爱 | 日韩色在线 | 色婷婷综合在线 | 国产偷国产偷精品高清尤物 | 香蕉大人久久国产成人av | 一区在线视频观看 | 成人练习生 | 亚洲第一视频网站 | 国产精品成人一区二区 | 伦理自拍 | 欧美国产视频一区 | 国产视频h| 久久亚洲精品中文字幕 | 99免费精品 | 欧洲一区二区三区 | 亚洲男人天堂2023 | 国产综合久久久久久鬼色 | 美女视频久久 | 久在线视频 | 亚洲日韩中文字幕一区 | 亚洲成人在线网站 | 黄色高清视频在线观看 | 一区二区三区回区在观看免费视频 | 欧美a在线| 国产一区二区三区四区视频 | 色综合久久天天综合网 | 中文字幕亚洲欧美日韩在线不卡 | 国产精品无码久久久久 | 一级黄色录像视频 | 中文字幕国产一区 | 毛片网站大全 | 国产18av| 精品视频在线观看一区二区三区 | 精品国产黄a∨片高清在线 99热婷婷 | 99爱视频 | 成人av一区二区三区 | 国产精品一区二区三区四区 | 91在线国产观看 | 日韩福利在线 | 最新中文字幕在线资源 | 国产成人在线视频 | 国产精品伊人 | 黄色片网站在线观看 | 草久在线视频 | 国产在线1| 国产精品女教师av久久 | 亚洲精品视 | av毛片| 久草视频免费在线播放 | 欧美日韩一区二区中文字幕 | 日本精品在线播放 | 91久久久久久久久 | 5060毛片 | 亚洲国产精品一区 |