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

Python項目實戰篇—常用驗證碼標注&識別(CNN神經網絡模型訓練/測試/部署)

開發 后端
今天給大家分享的實戰項目是常用驗證碼標注&識別,前面三篇文章講解了文章的創作靈感、需求分析和實現思路、數據采集/預處理/字符圖切割等知識、高效率數據標注等知識。

[[424693]]

大家好,我是Snowball。

一、前言

今天給大家分享的實戰項目是常用驗證碼標注&識別,前面三篇文章講解了文章的創作靈感、需求分析和實現思路、數據采集/預處理/字符圖切割等知識、高效率數據標注等知識,分別是以下文章:

  • Python項目實戰篇——常用驗證碼標注和識別(需求分析和實現思路)
  • Python項目實戰篇——常用驗證碼標注&識別(數據采集/預處理/字符圖切割)
  • Python項目實戰篇——常用驗證碼標注&識別(前端+后端實現高效率數據標注)

這篇文章引入機器學習,給大家講解下基于該項目的CNN神經網絡模型訓練/測試/部署。

二、背景知識

按照學習的好習慣,先搜索網上資源,再腦洞一下,先思考啥是神經網絡,啥是卷積,CNN神經網絡為啥能提取圖片特征,這些問題筆者剛開始全部都遇到過,一臉蒙蔽有沒有。不要急,有問題有時候是好事,說明你知道自己那些不知道,等到自己了解和懂得多了,有些問題就迎刃而解。

筆者剛開始在上面的OpenCV知識學習過程中,就嘗試用過傳統的SIFT算法進行提取圖片特征可以進行圖片相似度匹配,但是效果都比較差,這里面用的是多維向量特征描述。而神經網絡在機器學習的領域為啥這么牛皮,這里面是有數學方面的理論支撐,也有現在計算力和數據量的支持,而卷積神經網絡專門用來處理圖片特征提取。

剛開始,筆者對這方面的理論知識了解甚少,于是充分利用搜索工具和網上資源,這里分享一下自己學習過程中的文章鏈接和視頻鏈接,可以保證讀者看完基本可以加深對神經網絡訓練的實戰了解,可上手進行項目功能調整。好的,讓我們開始學習(卷)起來,以下就是所有內容的鏈接,沒有基礎的朋友可以補一補,有基礎的可以直接跳過:

  1. **數學基礎** 
  2. [微積分](https://www.bilibili.com/video/BV1Eb411u7Fw) 
  3.  
  4. [線性代數](https://www.bilibili.com/video/BV1aW411Q7x1) 
  5.  
  6. [概率論](https://www.bilibili.com/video/BV1ot411y7mU) 
  7.  
  8. [計算機數學基礎](https://www.bilibili.com/video/BV1AB4y1K7kM) 
  9.  
  10.  
  11. **OpenCV** 
  12. [OpenCV文章專欄](https://blog.csdn.net/yukinoai/category_9283880.html) 
  13.  
  14. [OpenCV-Python視頻](https://www.bilibili.com/video/BV1tb4y1C7j7) 
  15.  
  16.  
  17. **神經網絡** 
  18. [理解卷積意義](https://www.bilibili.com/video/BV1VV411478E) 
  19.  
  20. [前饋神經網絡](https://www.bilibili.com/video/BV1Tt411s7fK) 
  21.  
  22. [神經網絡學習理解](https://space.bilibili.com/504715181?spm_id_from=333.788.b_765f7570696e666f.1) 
  23.  
  24.  
  25. **Python框架使用** 
  26. [Numpy中文教程](https://www.runoob.com/numpy/numpy-tutorial.html) 
  27.  
  28. [PyTorch中文教程](https://pytorch.panchuang.net/SecondSection/neural_networks/) 
  29.  
  30. [PyTorch視頻](https://www.bilibili.com/video/BV1t64y1t7V8) 

以上就是筆者這次項目開發幾個月來搜索的優質學習文章和視頻資源了,有基礎的朋友可以選擇性相關知識學習,沒有基礎而時間充裕的可以惡補基礎再動手實戰,所謂磨刀不誤砍柴工。想快速動手的小伙伴可以快速學習,把對應項目需要的知識點看明白即可。筆者建議的學習方式是確定自己的任務主線,然后邊學邊練邊思考,在項目實戰中學習總結是成長最快的方式。

好的,在上面前置知識學習了解的差不多后,相信大家都已經知道CNN神經網絡的理論知識了,接下來我們動手進行CNN模型的實戰訓練過程。

在開始,確定模型訓練基本過程

  1. 準備訓練數據集、測試數據集、預測數據集
  2. CNN模型編碼
  3. 模型訓練、測試
  4. 模型預測、部署

三、CNN神經網絡模型訓練

1.準備數據

通過實現思路第1-2步,可以得到相關圖片驗證碼字符數據,筆者這里準備訓練集500多張(這里得感謝我妹子花時間幫我在標注系統上手動標注的初始數據集~~),測試集30多張,預測5張。讀者在python項目拉取下來后,對應的文件夾下面已有全部數據,對應路徑如下:

src_img:訓練數據集

test_src_img:測試數據集

usage_src_img:預測數據集

在準備好圖片驗證碼數據后,本次案例需要先進行字符切割預處理(其他常用驗證碼需要讀者自己調整),對應文件image_split,以下是main方法代碼。

  1. if __name__ == '__main__'
  2.     split_image_dir(SRC_IMG_DIR) 
  3.      
  4.     split_test_image() 

執行字符切割后,對應的訓練集字母分類在letter_template目錄下,測試集字母分類在letter_test目錄下。

數據集類:net_data.py,下面是主要代碼。

  1. labels = [] 
  2. #2-9 
  3. for i in range(8): 
  4.     labels.append(50 + i) 
  5. #A-Z     
  6. for i in range(26): 
  7.     labels.append(65 + i) 
  8.  
  9. class VerCodeDataset(Dataset): 
  10.     def __init__(self, image_dir="./letter_template/"): 
  11.         l = os.listdir(image_dir) 
  12.         self.data = [] 
  13.         self.label = [] 
  14.         for d in l: 
  15.             fs = os.listdir("{}{}".format(image_dir, d)) 
  16.             for f in fs: 
  17.                 fup = "{}{}/{}".format(image_dir, d, f) 
  18.                 #圖片numpy轉tensor 
  19.                 t = torch.from_numpy(io.imread(fup)).float() / 255 
  20.                 #將二維值標準化 
  21.                 norl = transforms.Normalize(t.mean(), t.std()) 
  22.                 self.data.append(norl(t.reshape(1, 40, 40))) 
  23.                 #添加字符對應標簽序號 
  24.                 self.label.append(labels.index(ord(d))) 

數據集值制作描述可參考該文章鏈接:

  1. [數據集制作參考文章](https://zhuanlan.zhihu.com/p/358671390) 

2.CNN模型編碼

本文驗證碼的識別與MNIST的識別相當類似,模型這塊采用簡單的前饋神經網絡,它接收輸入,讓輸入一個接著一個的通過一些層,最后給出輸出。下面是minst網絡結構圖:

  1. [PyTorch 神經網絡 - PyTorch官方教程中文版](https://link.zhihu.com/?target=http%3A//pytorch.panchuang.net/SecondSection/neural_networks/) 

一個典型的神經網絡訓練過程包括以下幾點:

1.定義一個包含可訓練參數的神經網絡

2.迭代整個輸入

3.通過神經網絡處理輸入

4.計算損失(loss)

5.反向傳播梯度到神經網絡的參數

6.更新網絡的參數,典型的用一個簡單的更新方法:weight = weight - learning_rate *gradient

定義神經網絡(net_train.py):

  1. class Net(nn.Module): 
  2.     def __init__(self, dropout=0.1): 
  3.         super(Net, self).__init__() 
  4.         self.dropout = nn.Dropout(dropout) 
  5.          #第一層,卷積核個數從6改成10 
  6.         self.conv1 = nn.Conv2d(1, 10, 5) 
  7.         #第二層,卷積核個數從10改成25 
  8.         self.conv2 = nn.Conv2d(10, 25, 5) 
  9.          
  10.         #全連接層1,40*40的字符圖經過2層卷積+2層池化變成7*7 
  11.         self.fc1 = nn.Linear(1 * 25 * 7 * 7, 120) 
  12.         #全連接層2 
  13.         self.fc2 = nn.Linear(120, 84) 
  14.         #最后全連接3層為輸出層,本案例驗證碼分類一共34類,[2-9,A-Z],改為34。 
  15.         self.fc3 = nn.Linear(84, 34) 
  16.  
  17.     def forward(self, x): 
  18.         # 池化出來大小直接除2 
  19.         x = F.max_pool2d(F.relu(self.conv1(x)), (2, 2)) 
  20.         #防止過擬合 
  21.         x = self.dropout(x) 
  22.         x = F.max_pool2d(F.relu(self.conv2(x)), (2, 2)) 
  23.         x = self.dropout(x) 
  24.         x = x.view(-1, self.num_flat_features(x)) 
  25.         #神經元relu激活函數 
  26.         x = F.relu(self.fc1(x)) 
  27.         x = F.relu(self.fc2(x)) 
  28.         x = self.fc3(x) 
  29.         return x 
  30.  
  31.     def num_flat_features(self, x): 
  32.         size = x.size()[1:]  # all dimensions except the batch dimension 
  33.         num_features = 1 
  34.         for s in size
  35.             num_features *= s 
  36.         return num_features 

下方代碼中:

  1. self.fc1 = nn.Linear(1 * 25 * 7 * 7, 120) 

全連接層第一個參數的大小:

[40,40]經過[5,5]卷積核->[35,35]

[35,35]經過[2,2]池化->[18,18]

[18,18]經過[5,5]卷積核->[13,13]

[13,13]經過[2,2]池化->[7,7]

上層卷積層一共25個卷積核,因此這里的大小為1(通道數)*25*7*7= 1225,至于后面全連接的84可以隨便改,和下層全連接層保持一致即可。

以上就是模型定義的代碼了,讀者有興趣的也可以自行用其他模型訓練。

四、CNN神經網絡模型測試

net_train.py文件提供的訓練代碼支持GPU訓練,在沒有NVDIA顯卡和安裝pytorch對應版本的CUDA庫,默認是使用CPU訓練,筆者對二種訓練方式都進行了嘗試,下面是訓練對比情況:

  1. 數據量:2286張 40*40 單通道字符圖片 
  2. batch_size: 50 
  3. epoch: 200 
  4.  
  5. 設備          時間 
  6. GTX 1070TI      25s 
  7. AMD R7 4750U PRO  4min 

總結,數據量大,有條件上GTX顯卡就用顯卡訓練,訓練效率高出CPU數量級

  1. [cuda安裝文章鏈接](https://www.cnblogs.com/yang520ming/p/10677110.html) 

這里是cuda安裝注意事項:

  1. 1.更新nvida顯卡驅動程序,然后看cuda版本 
  2. 2.找pytorch對應cuda的版本安裝 

train方法代碼如下:

  1. def train_gpu(): 
  2.     use_cuda = torch.cuda.is_available() 
  3.     if(use_cuda): 
  4.         print("use gpu cuda"
  5.     else
  6.         print("use cpu"
  7.  
  8.     device = torch.device("cuda:0" if use_cuda else "cpu"
  9.     net = Net() 
  10.     net.to(device) 
  11.    
  12.   #隨機梯度下降 
  13.     opt = optim.SGD(net.parameters(), lr=0.01) 
  14.     #迭代數據200次 
  15.     epoch = 200 
  16.     #單批次數據為50個 
  17.     batch_size = 50 
  18.      
  19.     trainloader = data.trainloader(batch_size) 
  20.     st = datetime.datetime.now() 
  21.     loss = 0 
  22.  
  23.     for e in range(epoch): 
  24.         for step, d in enumerate(trainloader): 
  25.             data_cuda =  d["data"].to(device) 
  26.             label_cuda = d["label"].to(device) 
  27.             #每次反向傳播后,梯度清零 
  28.             opt.zero_grad() 
  29.             #前向傳播 
  30.             out = net(data_cuda) 
  31.             #分類問題選用交叉熵損失函數 
  32.             lf = nn.CrossEntropyLoss() 
  33.             #計算損失 
  34.             loss = lf(out, label_cuda) 
  35.             #反向傳播修改神經元參數 
  36.             loss.backward() 
  37.             opt.step() 
  38.  
  39.       #每迭代50次或第一個批次步驟數據輸出損失值 
  40.             if (e % 50 == 0 or step == 1): 
  41.                 print("e : {} , step : {}, loss : {}".format(e, step, loss)) 
  42.  
  43.     print("loss : {}".format(loss)) 
  44.     #輸出訓練時間 
  45.     print("cost time:",datetime.datetime.now() - st) 
  46.     #保存模型 
  47.     saveModel(net, opt) 

描述見上面代碼注釋,對概念理解有問題建議可以再看下這個up主的視頻,筆者覺得講得非常不錯:

  1. [神經網絡學習理解](https://space.bilibili.com/504715181?spm_id_from=333.788.b_765f7570696e666f.1) 

下面給出訓練、測試過程中的效果圖:

GPU模型-訓練集訓練:

CPU模型-訓練集訓練:

可以看到迭代200次,花費4分鐘的訓練,模型趨于擬合效果,次數越往后梯度下降越慢。其實在迭代100次之后就接近穩定來回振蕩,損失值減少越慢,最后的損失值為0.0016,擬合效果還不錯,如果增加訓練數據量、迭代次數、優化部分字符串的切割,可以讓模型效果更好,讀者可自行實踐。

CPU模型-測試集測試:

代碼見net_test.py

可以看到152個字符,97%的準確率,部分字符切割問題會導致準確率下降,不過問題不大,基本達到個人項目可用程度,Nice~~

五、CNN神經網絡模型預測和部署

經過1,2,3步循環過程后,可以用一個相對擬合穩定的模型進行預測集預測,因為過擬合的問題,可能有些模型在測試集表現較好,在測試時效果就不太好,這里需要對訓練數據,模型參數進行排

CPU模型-預測集測試:

代碼見net_usage.py

上圖可以看到,5張驗證碼的字符全部預測正確。

CPU模型-部署:

使用python的web框架Flask API,編寫圖片驗證碼識別POST接口,傳入文件路徑,啟動web應用,以下是通過本機文件路徑識別接口代碼,詳細代碼見net_flask.py

  1. @app.route('/recognize/path', methods=['POST']) 
  2. def recognize_path(): 
  3.     filePathList = request.json['filePathList'
  4.     code = CODE_SUCCESS 
  5.     msg = MSG_SUCCESS 
  6.     data = [] 
  7.     for filePath in filePathList: 
  8.         if not os.path.exists(filePath): 
  9.             # code = CODE_FAIL 
  10.             # msg = "文件不存在" 
  11.             print("文件不存在:", filePath) 
  12.             data.append(""
  13.             continue 
  14.         else
  15.             labels = usage_model.usage(filePath) 
  16.             data.append(''.join(labels)) 
  17.     result = {'code': code, "msg": msg, "data": data} 
  18.     return jsonify(result) 

模型-Flask Web App啟動效果:

Postman接口測試效果:

Web頁面批量請求-預測:

好的,以上就是筆者圖片驗證碼識別案例中的卷積神經網絡模型訓練、測試、部署的全部內容了,總的來說,從結果看模型預測效果還是非常不錯的,首先利用標注系統進行人工標注初始數據集、下載數據集,然后再進行數據集的準備,接著進行模型的編碼、訓練和測試,然后利用訓練出來的模型進行數據預測,通過人工判斷修正再把加入到訓練集中,從而低時間成本、高效率增加訓練數據量。

六、總結

大家好,我是Snowball。這幾篇文章,整個過程下來,讀者就會熟悉到CNN神經網絡在圖片特征提取的魅力之處,其原理還是利用概率論、機器學習知識,在多層CNN模型下,通過多層感知機的激活函數、隨機梯度下降法、損失函數、反向傳播等機制進行復雜非線性模型參數的調節,使得訓練處理的模型概率分布盡可能接近人腦中標注數據的概率模型。

當然,讀者看到這里覺得這里面還有很多疑問和問題,請不要氣餒,整個機器學習、神經網絡的知識體系是非常龐大的,從數學理論到計算機算法,再到工程框架,細節一步步被隱藏,請保持好奇心和思考,持續了解和學習,未來可能等知識積累到一定程度,那么很多問題就會明白和理解。說的東西有點多了,哈哈,總之還是,信息時代合理利用互聯網上的資源。

 

責任編輯:姜華 來源: Python爬蟲與數據挖掘
相關推薦

2021-09-09 08:55:50

Python項目驗證碼

2021-09-16 07:52:18

Python項目實戰

2021-09-11 09:07:17

Python驗證碼標注

2022-02-17 10:34:21

神經網絡識別驗證碼

2013-06-19 10:19:59

2017-05-04 18:30:34

大數據卷積神經網絡

2017-08-28 21:31:37

TensorFlow深度學習神經網絡

2017-04-26 09:30:53

卷積神經網絡實戰

2024-01-29 08:32:10

Python驗證碼識別

2020-12-29 05:33:03

Serverless驗證碼架構

2016-11-08 19:19:06

2016-11-03 13:33:31

2023-10-27 08:53:13

Python驗證碼圖片識別

2017-12-22 08:47:41

神經網絡AND運算

2022-10-17 15:43:14

深度學習回歸模型函數

2022-10-11 23:35:28

神經網絡VGGNetAlexNet

2022-05-11 07:41:31

Python驗證碼

2021-02-04 10:08:34

騰訊云驗證碼醫療影像

2021-04-29 09:40:32

測試IDEAirtest
點贊
收藏

51CTO技術棧公眾號

日韩精品乱码免费| 999精品视频在线观看| 97国产一区二区| 欧美专区在线播放| 91大神福利视频| 伊人久久大香| 亚洲成av人片| 色噜噜一区二区| 亚洲精品网站在线| 日日夜夜一区二区| 色综合91久久精品中文字幕| 北岛玲一区二区| 日韩色性视频| 狠狠综合久久av一区二区小说| 欧美亚洲精品日韩| 亚洲精品免费在线观看视频| 青青草97国产精品免费观看无弹窗版| 久久成人人人人精品欧| 在线免费观看日韩av| 国色天香久久精品国产一区| 日韩欧美成人区| 黄色网络在线观看| av电影在线播放高清免费观看| 国产精品一区二区你懂的| 日本午夜人人精品| 久久综合激情网| 99热国内精品| 亚洲午夜久久久久久久| 欧美日韩一区二区三区四区五区六区 | 日本视频在线一区| 992tv在线成人免费观看| 国产尤物在线播放| 日韩电影免费网站| 亚洲欧美日韩另类| 国产婷婷在线观看| 99精品国产一区二区三区2021 | 在线视频亚洲专区| 亚洲国产成人精品一区二区| 在线免费看v片| 久久婷婷五月综合色丁香| 亚洲图片一区二区| 激情五月婷婷六月| 手机av免费在线| 亚洲欧洲精品一区二区三区不卡| 亚洲国产综合自拍| 蜜芽tv福利在线视频| 93久久精品日日躁夜夜躁欧美| 成人免费看片网站| 99视频国产精品免费观看a| 久久99精品久久久久久久久久久久| 国产成人欧美在线观看| 久久久久久无码精品大片| 西西裸体人体做爰大胆久久久| 91国产视频在线播放| 日韩成人免费在线视频| 中文亚洲字幕| 日本精品一区二区三区在线播放视频 | 韩国av中国字幕| **精品中文字幕一区二区三区| 欧美精选一区二区| 亚洲一二三av| 精品视频一区二区三区| 日韩免费视频一区二区| 99久久久无码国产精品性波多| 亚洲图色一区二区三区| 亚洲国产成人91精品| 成人免费网站黄| 精品久久精品| 久久精品久久久久电影| 一区二区视频免费看| 亚洲香蕉av| 久久97久久97精品免视看| 国产极品在线播放| 久久视频一区| 国产在线视频91| 亚洲国产精品成人久久蜜臀| 成人丝袜18视频在线观看| 久久久久资源| 中文字幕在线免费| 亚洲影院在线观看| 97国产精东麻豆人妻电影| 色成人免费网站| 51精品久久久久久久蜜臀| 五月天丁香社区| 欧美日韩激情| 色综合久久精品亚洲国产 | 国产在线高清视频| 午夜一区二区三区视频| 日本成人中文字幕在线| 欧美电影院免费观看| 亚洲精品电影网站| 极品尤物一区二区| 激情综合电影网| 国产精品久久久久7777婷婷| av 一区二区三区| 91视频在线观看免费| 一级全黄肉体裸体全过程| 精精国产xxx在线视频app| 欧美日韩国产精选| 国产精品第七页| 午夜久久免费观看| 日本精品va在线观看| 国产精品毛片一区二区在线看舒淇| 不卡av在线网| 成人短视频在线看| 蜜臀国产一区| 精品va天堂亚洲国产| 美国美女黄色片| 中文日韩在线| 99re视频在线| 午夜在线视频| 一本色道久久综合亚洲91| 4438x全国最大成人| 精品国产乱码久久久| 欧美大秀在线观看| 天天干天天色综合| 福利电影一区二区| 亚洲 国产 日韩 综合一区| yellow字幕网在线| 日韩午夜在线播放| 国产精品1区2区3区4区| 国产日韩欧美一区| 99视频免费观看| 永久免费av片在线观看全网站| 欧美色视频日本版| 日批免费观看视频| 午夜精品视频一区二区三区在线看| 欧美在线中文字幕| 亚洲第一视频在线| 国产精品成人免费在线| 精品久久久久av| 精品成人自拍视频| 欧美成人免费在线视频| 国产精品乱码久久久| 国产视频一区二区三区在线观看| 日本免费黄视频| 51vv免费精品视频一区二区| 久久天天躁日日躁| 亚洲在线免费观看视频| 国产日韩欧美麻豆| 国产精品少妇在线视频| 韩国av在线免费观看| 色呦呦久久久| 色八戒一区二区三区| 国产在线观看无码免费视频| 一区二区三区国产在线| 国产一区二区自拍| 理论片午夜视频在线观看| 亚洲国产小视频| 久草手机在线观看| 久久女同互慰一区二区三区| 成人在线看视频| 精品一区欧美| 国产精品精品视频一区二区三区| 成人亚洲性情网站www在线观看| 91福利国产精品| 成年人视频软件| 国产一区欧美二区| 欧美视频在线第一页| 国产精品久久久久av蜜臀| 97超级碰碰人国产在线观看| 污视频网站在线播放| 欧美日韩国产在线播放| 少妇久久久久久久久久| 免费成人av资源网| 亚洲免费视频播放| 麻豆精品久久| 午夜精品福利在线观看| 色中色在线视频| 色呦呦日韩精品| 蜜桃av免费在线观看| 国产在线精品视频| 日本精品久久久久久久久久| 欧美挤奶吃奶水xxxxx| 国产mv久久久| 超碰最新在线| 深夜成人影院| 精品亚洲国产视频| 亚洲av无码不卡| 综合亚洲深深色噜噜狠狠网站| 亚洲五月激情网| 亚洲精品乱码| 日韩视频精品| 欧美激情啪啪| 久久久久久久久电影| 日本不卡视频一区二区| 欧美日韩一区二区三区在线 | 伊人色综合久久天天人手人婷| 亚洲精品鲁一鲁一区二区三区| 亚洲二区在线| 亚洲日本欧美在线| 国产成人一二片| 国产精品免费久久久久久| 日本视频在线免费观看| 亚洲国产欧美一区二区三区同亚洲 | 中日韩精品一区二区三区| 日本亚洲最大的色成网站www| 国产激情片在线观看| 蜜桃一区二区| 97人人模人人爽人人喊38tv| 欧亚一区二区| 国模私拍一区二区三区| 黄色在线播放| 亚洲国产一区二区三区在线观看| 中文字幕乱码视频| 黑人精品xxx一区一二区| www.av成人| 久久九九国产精品| 天堂www中文在线资源| 国内外成人在线视频| 日本三区在线观看| 在线观看日韩av电影| 国产又黄又爽免费视频| 狠狠色丁香婷婷综合影院| 国产一区二区三区无遮挡 | 天天看片中文字幕| 国产拍揄自揄精品视频麻豆 | 国产精品国产三级国产三级人妇| 性欧美丰满熟妇xxxx性久久久| 国产在线精品不卡| 中文字幕天天干| 天堂久久久久va久久久久| 国产69精品久久久久999小说| 一区二区影视| 国产在线拍揄自揄拍无码| 天堂а√在线资源在线| 欧美一级二区| 老司机午夜网站| 久久一区二区三区电影| 日韩精品另类天天更新| 亚洲品质自拍| 鲁鲁狠狠狠7777一区二区| 国产极品模特精品一二| 99精品在线直播| 精品一区二区三区中文字幕在线 | www久久久com| 51精品秘密在线观看| 国产精品人妻一区二区三区| 欧美在线观看禁18| 高潮毛片又色又爽免费 | 国产精品美女久久久久高潮| 亚洲国产天堂av| 久久精品夜夜夜夜久久| 爱爱免费小视频| 久久色视频免费观看| aaaaa一级片| 久久一夜天堂av一区二区三区| 添女人荫蒂视频| 91网站在线观看视频| 北岛玲一区二区| 久久无码av三级| 青娱乐国产视频| 国产精品乱码人人做人人爱| 青青青视频在线免费观看| 日韩一区欧美小说| 欧美精品99久久久| 午夜精品久久久久| 国产精品自拍99| 91传媒视频在线播放| 在线观看中文字幕2021| 91精品欧美一区二区三区综合在 | 亚洲精品一区二区网址| 蜜桃视频在线观看网站| 尤物九九久久国产精品的特点 | 国产欧美91| 欧美视频第三页| 日韩av中文字幕一区二区| 91亚洲免费视频| 国产精品99久久久久| 人妻体内射精一区二区三区| 久久午夜国产精品| 国产精品夜夜夜爽阿娇| 一区二区高清免费观看影视大全| 国产91av视频| 欧美性色黄大片手机版| 国产精品毛片一区视频播 | 欧美日韩免费观看一区三区| 999精品国产| 亚洲精品国产精品乱码不99按摩 | 日本美女高潮视频| 国内精品伊人久久久久av影院| 性活交片大全免费看| 久久久噜噜噜久噜久久综合| 韩国一级黄色录像| 福利微拍一区二区| 亚洲中文字幕在线观看| 亚洲福利精品在线| 国产黄色在线播放| 久久99精品久久久久久青青91| 欧美激情网站| 成人信息集中地欧美| 香蕉一区二区| 特级黄色录像片| 久久久久久久欧美精品| 佐山爱在线视频| 国产片一区二区| 日本在线观看视频网站| 欧美日韩不卡在线| 五月婷婷久久久| 久久久精品国产亚洲| 偷拍精品精品一区二区三区| 亚洲xxxxx| 精品久久久久久久| 加勒比成人在线| 久久 天天综合| 在线免费看黄视频| 亚洲图片欧美色图| 国产免费久久久| 尤物九九久久国产精品的分类| 人成在线免费网站| 成人a在线视频| 国产一区二区三区四区五区传媒| 欧美人成在线观看| 国产毛片精品国产一区二区三区| 国产全是老熟女太爽了| 亚洲午夜久久久久中文字幕久| 亚洲图片中文字幕| 亚洲香蕉av在线一区二区三区| 91精品国产黑色瑜伽裤| 亚洲一区二区三区香蕉| 成人午夜国产| 日本新janpanese乱熟| 99久久精品免费看国产 | 91激情在线视频| 香蕉av在线播放| 久久久久久12| 美女精品久久| 欧美日韩午夜影院| 精品视频站长推荐| 亚洲乱码国产乱码精品精的特点| 精品一区二三区| 亚洲人成电影网站色…| 日韩伦理在线一区| 精品国产一区二区三区麻豆小说| 国产精品红桃| 亚洲欧洲日韩综合| 一区二区三区在线看| 国产色在线视频| 久久天天躁狠狠躁夜夜躁| www.久久草.com| 天天干天天色天天爽| 激情成人午夜视频| 伊人在线视频观看| 欧美一区二区福利视频| 最爽无遮挡行房视频在线| 91深夜福利视频| 伊人久久大香线| 国产精久久久久| 婷婷开心久久网| 性插视频在线观看| 热久久免费国产视频| av中文字幕一区二区| 浓精h攵女乱爱av| 国产精品九色蝌蚪自拍| 国产精品久久久久毛片| 欧美精品午夜视频| 成人av激情人伦小说| 欧美日韩成人免费视频| 96av麻豆蜜桃一区二区| 亚洲精品毛片一区二区三区| 国产一区二区三区在线观看网站| 成人1区2区| 777久久精品一区二区三区无码 | 成人午夜视屏| 日韩偷拍一区二区| 韩国女主播成人在线观看| 男女羞羞免费视频| 亚洲精品videossex少妇| 电影一区二区三区| 午夜老司机精品| 国产一区二三区好的| 国产精品二区一区二区aⅴ| 亚洲男人天堂久| 免费成人毛片| 久久久性生活视频| 国产午夜精品一区二区三区视频| 国产美女主播在线观看| 97视频在线观看成人| 欧美日韩亚洲在线观看| 欧美人与性动交α欧美精品| 午夜精品一区在线观看| 91精品专区| 国产不卡一区二区三区在线观看| 亚洲一区成人| 欧美成人777| 亚洲九九九在线观看| 欧美网站免费| 青青青免费在线| 国产精品久久久久久久久免费桃花| 亚洲AV无码一区二区三区性| 青青青国产精品一区二区| 91精品在线观看国产| 久久久久国产精品区片区无码| 欧美精品久久99久久在免费线| 51av在线| 黄色影视在线观看| 久久精品亚洲麻豆av一区二区| 精品人妻aV中文字幕乱码色欲 | 美女精品久久| 美女网站免费观看视频|