亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

php采集神器cURL使用方法詳解

2020-03-22 17:27:31
字體:
來源:轉載
供稿:網友
對于做過數據采集的人來說,cURL一定不會陌生。雖然在PHP中有file_get_contents函數可以獲取html' target='_blank'>遠程鏈接的數據,但是它的可控制性太差了,對于各種復雜情況的采集情景,file_get_contents顯得有點無能為力。因此,本文將為你介紹采集神器cURL的使用。先給大家補充一下file_get_contents函數可以獲取遠程鏈接數據的方法。$url = "http://git.oschina.net/yunluo/API/raw/master/notice.txt";$ch = curl_init();curl_setopt($ch, CURLOPT_URL, $url);curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10);$notice = curl_exec($ch);echo $notice;這段代碼會直接使用curl顯示文件內容,但是問題來了,因為curl是php的擴展,有的主機為了安全會金庸curl的,寧外php本地調試的時候也是關閉curl的,所以會發生報錯,所以這段代碼是不可取的,所以云落對他重新改寫了 if (function_exists('curl_init')) { $url = "http://git.oschina.net/yunluo/API/raw/master/notice.txt"; $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10); $dxycontent = curl_exec($ch); echo $dxycontent; } else { echo '汗!貌似您的服務器尚未開啟curl擴展,無法收到來自云落的通知,請聯系您的主機商開啟,本地調試請無視';修改后的版本是對curl擴展做一個判斷,看看服務器到底有木有打開curl擴展,如果打開了,就直接顯示文件,如果沒打開就顯示一段提示文字。
雖然修復了問題,但是又有一個問題來了,我只是顯示一段文字而已,我也不是是用什么做什么大事的,所以我為什么要寫那么多的代碼呢??
經過一些瞎掰的檢測,發現file_get_contents獲取遠程文件內容的速度不比curl慢,在一些文件較少的情況下可能還比curl擴展要快得多,所以我又重寫了代碼 php echo file_get_contents( "http://git.oschina.net/yunluo/API/raw/master/notice.txt" ); 工具
火狐瀏覽器(FireFox) + Firebug
“工欲善其事,必先利其器?!?在分析案例之前,先讓我們學習一下如何利用神器Firebug獲取我們必要的信息。
使用F12打開Firebug,我們可以得到如圖(一)界面:
1、箭頭圖標是“元素選擇”工具,單擊一次會高亮圖標,同時,鼠標在頁面內的移動會同時在HTML菜單中選定相應的內容,此時單擊內容則表示選定了該元素,圖標高亮取消。如圖(二)所示:
Firebug查看元素2、控制臺
JS里面的console.log系列函數的打印就是在這里輸出。
3、HTML
HTML內容,注意這里看到的不一定是采集要解析的內容,采集時候對內容的分析,一律以查看源碼(Ctrl+U)為準,這里只是能快速定位元素的結構,然后再選擇一個比較特殊的參照,在源碼中定位相應的位置。
比如,你在HTML里面看到一個標簽是 div id="demo" Demo /div ,但是你查看源碼時候看到的內容可能是 div id="demo" Demo /div ,如果你對采集內容按照前者去做正則匹配,那么你會得不到結果。
4、CSS
這里是CSS文件內容
5、腳本
這里是Javascript文件內容
6、DOM
Dom節點內容
7、網絡
每一個請求鏈接的數據,這里是我們采集要關注和分析的地方,它能夠顯示每一個請求的參數、請求頭、Cookie數據等。在頁面提交會刷新的情況下,需要使用保持,使得頁面請求內容在刷新后仍然留著控制臺中,如圖(三)所示:

另外,火狐還有一款 Tamper data 擴展也能得到請求數據,必要時可以安裝使用。
8、Cookies
Cookie數據在圖(一)中還看到下面有很多可選的小菜單項,其中保持是我們要關注的,當選擇它的時候,即使提交表單刷新了頁面,下面內容區域的數據還是會保留,這個對于分析提交數據特別關鍵??偨Y
我們在分析采集請求的時候,主要關心“網絡”菜單里的請求數據,必要時候使用“保持”以查看刷新頁面的請求數據,請求前可以使用“清除”先清除下面的內容。案例解析
一、簡單的采集
這里所指的簡單采集,是指一個單一頁面GET請求的采集,它簡單得即使通過file_get_contents函數也能輕松獲得頁面返回結果。代碼片段之file_get_contents
$url = 'http://demo.zjmainstay.cn/php/curl/simple.html'; $content = file_get_contents($url); echo $content;代碼片段之cURL
$url = 'http://demo.zjmainstay.cn/php/curl/simple.html'; $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //返回數據不直接輸出 $content = curl_exec($ch); //執行并存儲結果 curl_close($ch); echo $content;二、需要參數的采集
這種情況,頁面請求需要傳入一些參數,可以是GET請求,也可以是POST請求。這種情況的采集,使用file_get_contents外帶一些參數還是可以實現的,但是這里我們將不再展示。代碼片段之cURL GET
這種請求,我們可以選擇搜索引擎作為演示,比如我百度搜索一個詞語“PHP cURL”,在輸入回車后,我們會得到一個類似http://www.baidu.com/s ie=utf-8&f=8&rsv_bp=1&ch=&tn=baidu&bar=&wd=PHP%20cURL的鏈接,注意這里的鏈接可能不同瀏覽器、不同入口方式訪問得到不一樣結果,因此不必介意鏈接是否一樣。通過輸入多個關鍵詞并觀察鏈接,我們可以確定 wd 參數就是我們要傳入的動態參數,而其他參數則可以不變,因此得到我們下面的采集代碼。
$keyword = 'PHP cURL'; $url = 'http://www.baidu.com/s ie=utf-8&f=8&rsv_bp=1&ch=&tn=baidu&bar=&wd=' . urlencode($keyword); $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //返回數據不直接輸出 $content = curl_exec($ch); //執行并存儲結果 curl_close($ch); echo $content;有些時候,一些參數并不是必須的,這時候我們可以刪掉它,比如上面的鏈接可以只保留http://www.baidu.com/s ie=utf-8&wd=PHP%20cURL,ie=utf-8 這個參數可能影響結果的編碼,所以暫且留著它。就這樣簡單的代碼,我們就可以采集到百度搜索的結果了。代碼片段之cURL POST
對于POST類型的請求,我們平時并不少見,比如有些搜索就是使用POST方式提交,這時候我們就需要使用POST類型來提交參數了。這個在PHP cURL里面有相應的參數:CURLOPT_POST 和 CURLOPT_POSTFIELDS , CURLOPT_POST 的設置可以指定當前提交是否為POST方式,CURLOPT_POSTFIELDS則用于設定提交的參數,可以是參數串,也可以是參數數組,比如:
curl_setopt($ch, CURLOPT_POSTFIELDS, 'ie=utf-8&wd=PHP%20cURL');curl_setopt($ch, CURLOPT_POSTFIELDS, array( 'ie' = 'utf-8', 'wd' = 'PHP%20cURL',下面是我做的一個POST模擬搜索PHP POST 搜索,后端是使用了前面的百度關鍵詞搜索,基本原理就是,客戶端提交一個關鍵詞到我服務器,我服務器使用該關鍵詞請求百度的搜索,然后得到結果,返回到客戶端。
如圖(四)是利用Firebug對請求數據的分析,得到我們需要提交的請求鏈接和請求參數:
然后下面是我們的代碼: $keyword = 'PHP cURL'; //參數方法一 // $post = 'wd=' . urlencode($keyword); //參數方法二 $post = array( 'wd' = urlencode($keyword), $url = 'http://demo.zjmainstay.cn/php/curl/search.php'; $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //返回數據不直接輸出 curl_setopt($ch, CURLOPT_POST, 1); //發送POST類型數據 curl_setopt($ch, CURLOPT_POSTFIELDS, $post); //POST數據,$post可以是數組,也可以是拼接 $content = curl_exec($ch); //執行并存儲結果 curl_close($ch); var_dump($content);三、需要Referer的采集
對于一些程序,它可能判斷來源網址,如果發現referer不是自己的網站,則拒絕訪問,這時候,我們就需要添加CURLOPT_REFERER參數,模擬來路,使得程序能夠正常采集。 $keyword = 'PHP cURL'; //參數方法一 // $post = 'wd=' . urlencode($keyword); //參數方法二 $post = array( 'wd' = urlencode($keyword), $url = 'http://demo.zjmainstay.cn/php/curl/search_refer.php'; $refer = 'http://demo.zjmainstay.cn/'; //來路地址 $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //返回數據不直接輸出 curl_setopt($ch, CURLOPT_REFERER, $refer); //來路模擬 curl_setopt($ch, CURLOPT_POST, 1); //發送POST類型數據 curl_setopt($ch, CURLOPT_POSTFIELDS, $post); //POST數據,$post可以是數組,也可以是拼接 $content = curl_exec($ch); //執行并存儲結果 curl_close($ch); var_dump($content);search_refer.php的源碼如下,做了簡單的Referer判斷攔截: if(empty($_POST['wd'])) { exit('Deny empty params.'); //Referer判斷 if(stripos($_SERVER['HTTP_REFERER'], $_SERVER['HTTP_HOST']) === false) { exit('Deny'); $keyword = addslashes(trim(strip_tags($_POST['wd']))); $url = 'http://www.baidu.com/s ie=utf-8&wd=' . urlencode($keyword); $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //返回數據不直接輸出 $content = curl_exec($ch); //執行并存儲結果 curl_close($ch); echo $content; 四、需要cookie支持的采集
對于模擬登錄的應用,單單提交參數和模擬來路并不能解決問題,這時候我們就需要保存或者提交相應的Cookie參數,這個在PHP cURL里面也提供了相應的參數:
CURLOPT_COOKIE: 直接使用字符串方式提交cookie參數
CURLOPT_COOKIEFILE: 使用文件方式提交cookie參數
CURLOPT_COOKIEJAR: 保存提交后反饋的cookie數據下面是PHP100的模擬登錄示例: php header("content-Type: text/html; charset=UTF-8");$cookie_file = tempnam('./temp', 'cookie');$login_url="http://bbs.php100.com/login.php";$post_fields="cktime=36000&step=2&pwuser=username&pwpwd=password";//提交登錄表單請求$ch=curl_init($login_url);curl_setopt($ch,CURLOPT_HEADER,0);curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);curl_setopt($ch,CURLOPT_POST,1);curl_setopt($ch,CURLOPT_POSTFIELDS,$post_fields);curl_setopt($ch,CURLOPT_COOKIEJAR,$cookie_file); //存儲提交后得到的cookie數據curl_exec($ch);curl_close($ch);//登錄成功后,獲取bbs首頁數據$url="http://bbs.php100.com/index.php";$ch=curl_init($url);curl_setopt($ch,CURLOPT_HEADER,0);curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);curl_setopt($ch,CURLOPT_COOKIEFILE,$cookie_file); //使用提交后得到的cookie數據做參數$contents=curl_exec($ch);curl_close($ch);//轉碼顯示echo iconv('gbk', 'UTF-8', $contents);五、壓縮網頁采集(gzip)
有些沒有接觸過壓縮頁面的朋友估計會在這里被坑死,因為他們會發現采集回來的內容是亂碼,并且無論使用iconv還是強大的mb_convert_encoding都無法還原數據,然后又沒有概念,各種抓狂卻找不到方法,哈哈,我曾經也是這樣~
如圖(五)是亂碼表現形式:
還好最后功夫不負有心人,還是找到了,它就是CURLOPT_ENCODING參數。
比如,采集搜狐的新聞時候就遇到gzip壓縮問題,下面是示例: $url = 'http://news.sohu.com/'; $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //返回數據不直接輸出 curl_setopt($ch, CURLOPT_ENCODING, "gzip"); //指定gzip壓縮 $content = curl_exec($ch); //執行并存儲結果 curl_close($ch); echo $content;手冊說明:支持的編碼有"identity","deflate"和"gzip"。如果為空字符串"",請求頭會發送所有支持的編碼類型。
后面一句表明,使用curl_setopt($ch, CURLOPT_ENCODING, "");也是可以的,但是不能不加這個參數。六、SSL鏈接的采集
有些請求鏈接是https類型的,這時候使用cURL采集可能會失敗,這時候,我們可以使用 var_dump(curl_error($ch));的方法打印錯誤提示,然后根據錯誤提示查找相應的解決方案。比如SSL錯誤常見提示:SSL certificate problem: unable to get local issuer certificate,這時候,我們就需要利用參數:CURLOPT_SSL_VERIFYPEER 和 CURLOPT_SSL_VERIFYHOST 來禁用SSL證書的驗證,我嘗試過只使用CURLOPT_SSL_VERIFYPEER參數禁用失敗,所以大家最好同時使用兩個參數。
下面是代碼示例: $searchStr = 'RC376981638HK'; $post = 'accion=LocalizaUno&numero='.$searchStr.'&ecorreo=&numeros='; $url = 'http://aplicacionesweb.correos.es/localizadorenvios/track.asp'; $ch = curl_init($url); //初始化curl curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //返回數據不直接輸出 curl_setopt($ch, CURLOPT_POST, 1); //發送POST類型數據 curl_setopt($ch, CURLOPT_POSTFIELDS, $post); //POST數據,$post可以是數組,也可以是拼接參數串 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); //SSL 報錯時使用 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); //SSL 報錯時使用 $contents = curl_exec($ch); //執行并存儲結果 // var_dump(curl_error($ch)); //獲取失敗是使用(采集錯誤提示) curl_close($ch); echo $contents;七、代理采集
大家都知道,國內存在萬惡的墻,所以,假如我們需要獲取某些被墻數據時,就需要用到國外代理服務器;又或者我們需要采集大量數據時,需要不斷切換IP,也會用到代理。
使用代理在PHP cURL里面有幾個相對應的參數:CURLOPT_PROXY、CURLOPT_PROXYPORT 和 CURLOPT_PROXYUSERPWD,還有另外幾個,這里不列舉。
CURLOPT_PROXY 指定代理IP參數
CURLOPT_PROXYPORT 指定代理端口參數
CURLOPT_PROXYUSERPWD 指定需要驗證的代理的賬號密碼,"[username]:[password]"格式的字符串關于代理賬號獲取,大家自己發揮,我這里提供網上搜索到的一個列表:cURL 高匿代理下面是代理采集示例: $url = 'http://demo.zjmainstay.cn/php/curl/dump_ip.php t=' . time(); echo "本地IP:" . file_get_contents($url) . "/n偽造IP:"; $ip = '183.224.1.116'; $port = '80'; //偽造請求頭參數,如果是高匿代理這里不需要提供 $header = array( 'X-FORWARDED-FOR: ' . $ip, 'CLIENT-IP: ' . $ip, $ch = curl_init($url); //初始化curl curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_PROXY, $ip); curl_setopt($ch, CURLOPT_PROXYPORT, $port); $content = curl_exec($ch); //執行并存儲結果 curl_close($ch); echo $content;八、 多線程采集
對于大量采集工作,為了提高采集效率,使用PHP cURL提供的多線程采集是必不可少的。手冊上提供的多線程采集例子好像都不太好用,我剛開始也從里面測試了幾個例子,但是發現都是執行卡死,根本無法執行完成,前幾天突然又測試了一下,然后發現curl_multi_info_read函數下面的Example #1是可以執行的,它的內容在$res上,但是沒有打印出來,而且雅虎的請求比較慢,會卡住,前面兩個鏈接都能正常返回。
不過,還好當時的例子不好用,然后我經過搜索找到了一個很厲害的項目,CurlMulti ,它對PHP cURL Multi 進行了一個良性擴展的封裝,能夠很好地提供采集支持。
關于CurlMulti的使用我就不多介紹,網址上面提供了demo,使用過程有技術難題可以直接加入Q群討論,作者@Ares 和其他的采集大牛都會提供技術解答幫助。
下面是PHP cURL Multi的一個簡單示例:$urls = array( "http://demo.zjmainstay.cn/php/curl/curl_multi_1.php", "http://demo.zjmainstay.cn/php/curl/curl_multi_2.php",$mh = curl_multi_init();foreach ($urls as $i = $url) { $conn[$i] = curl_init($url); curl_setopt($conn[$i], CURLOPT_RETURNTRANSFER, 1); //不直接輸出結果 curl_multi_add_handle($mh, $conn[$i]);$active = null;$res = array(); $status = curl_multi_exec($mh, $active); $info = curl_multi_info_read($mh); if (false !== $info) { //采集信息處理 $res[] = array( 'content' = curl_multi_getcontent($info['handle']), 'info' = $info, curl_close($info['handle']);} while ($status === CURLM_CALL_MULTI_PERFORM || $active);curl_multi_close($mh);var_dump($res);九、302跳轉(301跳轉)
對于一些應用,比如模擬登錄,如果遇上302跳轉,會導致cookie丟失而使得模擬登錄失敗,請求現象如圖(六)所示:這個時候,可以使用:curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);關于CURLOPT_FOLLOWLOCATION,手冊說明是:啟用時會將服務器服務器返回的"Location: "放在header中遞歸的返回給服務器,使用CURLOPT_MAXREDIRS可以限定遞歸返回的數量。
我個人理解,通俗點講就是后面的跳轉會繼續跟蹤訪問,而且cookie在header里面被保留了下來。十、模擬上傳文件
在PHP手冊的curl_setopt函數中,關于CURLOPT_POSTFIELDS有如下描述:全部數據使用HTTP協議中的"POST"操作來發送。要發送文件,在文件名前面加上@前綴并使用完整路徑。這個參數可以通過urlencoded后的字符串類似'para1=val1¶2=val2&...'或使用一個以字段名為鍵值,字段數據為值的數組。如果value是一個數組,Content-Type頭將會被設置成multipart/form-data。對于上傳文件,這句話包含兩個信息:1. 要上傳文件,post的數據參數必須使用數組,使得Content-Type頭將會被設置成multipart/form-data。
2. 要上傳文件,在文件名前面加上@前綴并使用完整路徑。
因此,模擬文件上傳可以按照如下實現://上傳D盤下的test.jpg文件,文件必須存在,否則curl處理失敗且沒有任何提示$data = array('name' = 'Foo', 'file' = '@d:/test.jpg');$ch = curl_init('http://localhost/upload.php');curl_setopt($ch, CURLOPT_POST, 1);curl_setopt($ch, CURLOPT_POSTFIELDS, $data);curl_exec($ch);本地測試的時候,在upload.php文件中打印出//(_POST和/$_FILES即可驗證是否上傳成功,如下: ``` php print_r(/)_POST);
print_r($_FILES);輸出結果類似:
Array ( [name] = Foo ) Array ( [file] = Array ( [name] = test.jpg [type] = application/octet-stream [tmp_name] = D:/xampp/tmp/php2EA0.tmp [error] = 0 [size] = 139999 ) )關于CURLOPT_POSTFIELDS的賦值,另外補充一句描述:
傳遞一個數組到CURLOPT_POSTFIELDS,cURL會把數據編碼成 multipart/form-data,而然傳遞一個URL-encoded字符串時,數據會被編碼成 application/x-www-form-urlencoded。即:
curl_setopt(/(ch, CURLOPT_POSTFIELDS, 'param1=val1¶m2=val2 和 curl_setopt(/)ch, CURLOPT_POSTFIELDS, array('param1' = 'val1', 'param2' = 'val2', ...));這樣一個功能強大的采集神器cURL的使用方法為大家介紹到這,希望對大家的學習有所幫助。PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
不卡毛片在线看| 亚洲激情第一页| 疯狂欧美牲乱大交777| 在线视频国产日韩| 久久影视电视剧凤归四时歌| 91美女福利视频高清| 成人伊人精品色xxxx视频| 97国产精品免费视频| 精品国偷自产在线视频| 91精品国产91久久久久久最新| 日韩欧美成人免费视频| 国产不卡一区二区在线播放| 欧美精品在线播放| 日韩激情视频在线播放| 国产一区二区丝袜高跟鞋图片| 欧美色xxxx| 国产精品久久久久久久久久久久| 久久69精品久久久久久国产越南| 国产精品精品久久久久久| 久久久国产精品视频| 亚洲自拍偷拍网址| 国产精品91久久久| 日韩在线观看免费| 国内精品一区二区三区| 国内精品中文字幕| 色yeye香蕉凹凸一区二区av| 亚洲老司机av| 97超级碰碰碰久久久| 91欧美精品午夜性色福利在线| 亚洲国产91色在线| 91成人在线观看国产| 亚洲品质视频自拍网| 91久久综合亚洲鲁鲁五月天| 色樱桃影院亚洲精品影院| 亚洲成人精品视频在线观看| 成人在线中文字幕| 欧美性视频在线| 久久久国产视频91| 成人福利网站在线观看11| 欧美成人中文字幕| 国产精品无av码在线观看| 色综久久综合桃花网| 国产亚洲精品综合一区91| 2019av中文字幕| 国产精品久久久久久久一区探花| 韩国精品久久久999| 亚洲男人7777| 国产午夜精品视频免费不卡69堂| 6080yy精品一区二区三区| 中文字幕精品国产| 国产精品高潮在线| 国产91网红主播在线观看| 精品视频中文字幕| 久久理论片午夜琪琪电影网| 久久精品国产成人| 97香蕉久久夜色精品国产| 亚洲综合视频1区| 国产精品久久久久久久久男| 欧美精品电影在线| 国产亚洲aⅴaaaaaa毛片| 97精品久久久中文字幕免费| 久久久999国产| 日韩免费在线看| 国产精品精品一区二区三区午夜版| 欧美成人黄色小视频| 26uuu另类亚洲欧美日本老年| 日韩美女激情视频| 国产主播在线一区| 亚洲乱码国产乱码精品精| 国产精品白丝jk喷水视频一区| 午夜精品理论片| 亚洲精品v天堂中文字幕| 国产日韩精品入口| 精品欧美国产一区二区三区| 亚洲精品suv精品一区二区| 丝袜情趣国产精品| 不用播放器成人网| 国产精品久久色| 欧亚精品在线观看| 国内偷自视频区视频综合| 97在线视频免费| 亚洲第一福利网站| 亚洲а∨天堂久久精品9966| 亚洲风情亚aⅴ在线发布| 久久这里有精品视频| 国产精品美女久久久久av超清| 亚洲人成五月天| 91免费精品视频| 欧美激情视频一区二区三区不卡| 在线视频欧美日韩精品| 中日韩午夜理伦电影免费| 欧美日本中文字幕| 永久免费看mv网站入口亚洲| 欧美日韩成人免费| 精品亚洲夜色av98在线观看| 亚洲天堂成人在线| 欧美猛交免费看| 国产精品综合网站| 欧美精品一本久久男人的天堂| 亚洲成人av在线| 国产欧美一区二区| 久久精品福利视频| 国产中文日韩欧美| 亚洲国产欧美一区二区三区同亚洲| 亚洲精品久久久久久久久久久| 欧美午夜电影在线| 91免费国产视频| 欧美日韩国产成人| 欧美性xxxx极品hd满灌| 91亚洲精品一区二区| 亚洲福利视频免费观看| 亚洲人成电影在线播放| 亚洲国产私拍精品国模在线观看| 久久精品一区中文字幕| 亚洲毛片在线免费观看| 91精品国产91久久久久福利| 国产精品视频男人的天堂| 亚洲精品日韩激情在线电影| 欧美理论电影在线播放| 神马国产精品影院av| 国产精品福利在线观看| 欧美性xxxxxxx| 色一情一乱一区二区| 久久视频在线观看免费| 97精品国产97久久久久久免费| 在线观看精品国产视频| 国产精品一区二区久久国产| 日韩中文字幕亚洲| 欧美一区三区三区高中清蜜桃| 久久的精品视频| 视频在线观看一区二区| 日韩精品免费在线观看| 成人性教育视频在线观看| 亚洲精品乱码久久久久久按摩观| 亚洲精品视频在线观看视频| 一本色道久久88精品综合| 在线观看日韩专区| 日韩欧美在线字幕| 欧美成人一区在线| 欧美一级电影久久| 欧美区在线播放| 一夜七次郎国产精品亚洲| 97在线视频免费播放| 国产亚洲视频在线| 91精品国产自产在线观看永久| 午夜精品一区二区三区在线视频| 91精品视频免费| 国产精品久久久久久搜索| 91精品视频在线播放| 91精品视频在线播放| 久久人人爽人人爽人人片av高请| 亚洲精品97久久| 国产成人av在线播放| 裸体女人亚洲精品一区| 日韩精品中文字幕有码专区| 国产精品高潮呻吟视频| 欧美精品www在线观看| 久久国产精品99国产精| 美日韩在线视频| 欧美日韩国产精品一区| 亚洲精品不卡在线| 国产97在线观看| 日韩中文字幕在线视频| 欧美一级电影免费在线观看|