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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

TCP 协议如何解决粘包、半包问题

發布時間:2024/4/18 编程问答 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 TCP 协议如何解决粘包、半包问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?TCP 協議是流式協議

很多讀者從接觸網絡知識以來,應該聽說過這句話:TCP 協議是流式協議。那么這句話到底是什么意思呢?所謂流式協議,即協議的內容是像流水一樣的字節流,內容與內容之間沒有明確的分界標志,需要我們人為地去給這些協議劃分邊界。

舉個例子,A 與 B 進行 TCP 通信,A 先后給 B 發送了一個 100 字節和 200 字節的數據包,那么 B 是如何收到呢?B 可能先收到 100 字節,再收到 200 字節;也可能先收到 50 字節,再收到 250 字節;或者先收到 100 字節,再收到 100 字節,再收到 200 字節;或者先收到 20 字節,再收到 20 字節,再收到 60 字節,再收到 100 字節,再收到 50 字節,再收到 50 字節……

不知道讀者看出規律沒有?規律就是 A 一共給 B 發送了 300 字節,B 可能以一次或者多次任意形式的總數為 300 字節收到。假設 A 給 B 發送的 100 字節和 200 字節分別都是一個數據包,對于發送端 A 來說,這個是可以區分的,但是對于 B 來說,如果不人為規定多長為一個數據包,B 每次是不知道應該把收到的數據中多少字節作為一個有效的數據包的。而規定每次把多少數據當成一個包就是協議格式規范的內容之一。

經常會有新手寫出類似下面這樣的代碼:

發送端:

//...省略創建socket,建立連接等部分不相關的邏輯... char buf[] = "the quick brown fox jumps over a lazy dog."; int n = send(socket, buf, strlen(buf), 0); //...省略出錯處理邏輯...

接收端:

//省略創建socket,建立連接等部分不相關的邏輯... char recvBuf[50] = { 0 }; int n = recv(socket, recvBuf, 50, 0); //省略出錯處理邏輯... printf("recvBuf: %s", recvBuf);

為了專注問題本身的討論,我這里省略掉了建立連接和部分錯誤處理的邏輯。上述代碼中發送端給接收端發送了一串字符”the quick brown fox jumps over a lazy dog.“,接收端收到后將其打印出來。

類似這樣的代碼在本機一般會工作的很好,接收端也如期打印出來預料的字符串,但是一放到局域網或者公網環境就出問題了,即接收端可能打印出來字符串并不完整;如果發送端連續多次發送字符串,接收端會打印出來的字符串不完整或出現亂碼。不完整的原因很好理解,即對端某次收到的數據小于完整字符串的長度,recvBuf 數組開始被清空成 0,收到部分字符串后,該字符串的末尾仍然是 0,printf 函數尋找以 0 為結束標志的字符結束輸出;亂碼的原因是如果某次收入的數據不僅包含一個完整的字符串,還包含下一個字符串部分內容,那么 recvBuf 數組將會被填滿,printf 函數輸出時仍然會尋找以 0 為結束標志的字符結束輸出,這樣讀取的內存就越界了,一直找到為止,而越界后的內存可能是一些不可讀字符,顯示出來后就亂碼了。

我舉這個例子希望你明白 能對TCP 協議是流式協議有一個直觀的認識。正因為如此,所以我們需要人為地在發送端和接收端規定每一次的字節流邊界,以便接收端知道從什么位置取出多少字節來當成一個數據包去解析,這就是我們設計網絡通信協議格式的要做的工作之一。

二 如何解決粘包問題

網絡通信程序實際開發中,或者技術面試時,面試官通常會問的比較多的一個問題是:網絡通信時,如何解決粘包?

有的面試官可能會這么問:網絡通信時,如何解決粘包、丟包或者包亂序問題?這個問題其實是面試官在考察面試者的網絡基礎知識,如果是 TCP 協議,在大多數場景下,是不存在丟包和包亂序問題的,TCP 通信是可靠通信方式,TCP 協議棧通過序列號和包重傳確認機制保證數據包的有序和一定被正確發到目的地;如果是 UDP 協議,如果不能接受少量丟包,那就要自己在 UDP 的基礎上實現類似 TCP 這種有序和可靠傳輸機制了(例如 RTP協議、RUDP 協議)。所以,問題拆解后,只剩下如何解決粘包的問題。

先來解釋一下什么是粘包,所謂粘包就是連續給對端發送兩個或者兩個以上的數據包,對端在一次收取中可能收到的數據包大于 1 個,大于 1 個,可能是幾個(包括一個)包加上某個包的部分,或者干脆就是幾個完整的包在一起。當然,也可能收到的數據只是一個包的部分,這種情況一般也叫半包

無論是半包還是粘包問題,其根源是上文介紹中 TCP 協議是流式數據格式。解決問題的思路還是想辦法從收到的數據中把包與包的邊界給區分出來。那么如何區分呢?目前主要有三種方法:

固定包長的數據包

顧名思義,即每個協議包的長度都是固定的。舉個例子,例如我們可以規定每個協議包的大小是 64 個字節,每次收滿 64 個字節,就取出來解析(如果不夠,就先存起來)。

這種通信協議的格式簡單但靈活性差。如果包內容不足指定的字節數,剩余的空間需要填充特殊的信息,如 \0(如果不填充特殊內容,如何區分包里面的正常內容與填充信息呢?);如果包內容超過指定字節數,又得分包分片,需要增加額外處理邏輯——在發送端進行分包分片,在接收端重新組裝包片(分包和分片內容在接下來會詳細介紹)。

以指定字符(串)為包的結束標志

這種協議包比較常見,即字節流中遇到特殊的符號值時就認為到一個包的末尾了。例如,我們熟悉的 FTP協議,發郵件的 SMTP 協議,一個命令或者一段數據后面加上"\r\n"(即所謂的?CRLF)表示一個包的結束。對端收到后,每遇到一個”\r\n“就把之前的數據當做一個數據包。

這種協議一般用于一些包含各種命令控制的應用中,其不足之處就是如果協議數據包內容部分需要使用包結束標志字符,就需要對這些字符做轉碼或者轉義操作,以免被接收方錯誤地當成包結束標志而誤解析。

包頭 + 包體格式

這種格式的包一般分為兩部分,即包頭和包體,包頭是固定大小的,且包頭中必須含有一個字段來說明接下來的包體有多大。

例如:

struct msg_header {int32_t bodySize;int32_t cmd; };

這就是一個典型的包頭格式,bodySize 指定了這個包的包體是多大。由于包頭大小是固定的(這里是 size(int32_t) + sizeof(int32_t) = 8 字節),對端先收取包頭大小字節數目(當然,如果不夠還是先緩存起來,直到收夠為止),然后解析包頭,根據包頭中指定的包體大小來收取包體,等包體收夠了,就組裝成一個完整的包來處理。在有些實現中,包頭中的 bodySize可能被另外一個叫 packageSize 的字段代替,這個字段的含義是整個包的大小,這個時候,我們只要用 packageSize 減去包頭大小(這里是 sizeof(msg_header))就能算出包體的大小,原理同上。

在使用大多數網絡庫時,通常你需要根據協議格式自己給數據包分界和解析,一般的網絡庫不提供這種功能是出于需要支持不同的協議,由于協議的不確定性,因此沒法預先提供具體解包代碼。當然,這不是絕對的,也有一些網絡庫提供了這種功能。在 Java Netty 網絡框架中,提供了FixedLengthFrameDecoder 類去處理長度是定長的協議包,提供了 DelimiterBasedFrameDecoder 類去處理按特殊字符作為結束符的協議包,提供 ByteToMessageDecoder 去處理自定義格式的協議包(可用來處理包頭 + 包體 這種格式的數據包),然而在繼承 ByteToMessageDecoder 子類中你需要根據你的協議具體格式重寫 decode() 方法來對數據包解包。

這三種包格式,希望讀者能在理解其原理和優缺點的基礎上深入掌握。

三 解包與處理

在理解了前面介紹的數據包的三種格式后,我們來介紹一下針對上述三種格式的數據包技術上應該如何處理。其處理流程都是一樣的,這里我們以包頭 + 包體?這種格式的數據包來說明。處理流程如下:

假設我們的包頭格式如下:

//強制一字節對齊 #pragma pack(push, 1) //協議頭 struct msg { int32_t bodysize; //包體大小 }; #pragma pack(pop)

那么上面的流程實現代碼如下:

//包最大字節數限制為10M #define MAX_PACKAGE_SIZE 10 * 1024 * 1024void ChatSession::OnRead(const std::shared_ptr<TcpConnection>& conn, Buffer* pBuffer, Timestamp receivTime) {while (true){//不夠一個包頭大小if (pBuffer->readableBytes() < (size_t)sizeof(msg)){//LOGI << "buffer is not enough for a package header, pBuffer->readableBytes()=" << pBuffer->readableBytes() << ", sizeof(msg)=" << sizeof(msg);return;}//取包頭信息msg header;memcpy(&header, pBuffer->peek(), sizeof(msg));//包頭有錯誤,立即關閉連接if (header.bodysize <= 0 || header.bodysize > MAX_PACKAGE_SIZE){//客戶端發非法數據包,服務器主動關閉之LOGE("Illegal package, bodysize: %lld, close TcpConnection, client: %s", header.bodysize, conn->peerAddress().toIpPort().c_str());conn->forceClose();return;}//收到的數據不夠一個完整的包if (pBuffer->readableBytes() < (size_t)header.bodysize + sizeof(msg))return;pBuffer->retrieve(sizeof(msg));//inbuf用來存放當前要處理的包std::string inbuf;inbuf.append(pBuffer->peek(), header.bodysize);pBuffer->retrieve(header.bodysize); //解包和業務處理if (!Process(conn, inbuf.c_str(), inbuf.length())){//客戶端發非法數據包,服務器主動關閉之LOGE("Process package error, close TcpConnection, client: %s", conn->peerAddress().toIpPort().c_str());conn->forceClose();return;} }// end while-loop }

上述流程代碼的處理過程和流程圖中是一致的,pBuffer 這里是一個自定義的接收緩沖區,這里的代碼,已經將收到的數據放入了這個緩沖區,所以判斷當前已收取的字節數目只需要使用這個對象的相應方法即可。上述代碼有些細節我需要強調一下:

  • 取包頭時,你應該拷貝一份數據包頭大小的數據出來,而不是從緩沖區 pBuffer 中直接將數據取出來(即取出來的數據從 pBuffer 中移除),這是因為倘若接下來根據包頭中的字段得到包體大小時,如果剩余數據不夠一個包體大小,你又得把這個包頭數據放回緩沖區。為了避免這種不必要的操作,只有緩沖區數據大小夠整個包的大小(代碼中:header.bodysize + sizeof(msg))你才需要把整個包大小的數據從緩沖區移除,這也是這里的 pBuffer->peek() 方法 peek 單詞的含義(中文可以翻譯成“瞟一眼”或者“偷窺”)。
  • 通過包頭得到包體大小時,你一定要對 bodysize 的數值進行校驗,我這里要求 bodysize 必須大于 0 且不大于 10?1024?1024(即 10 M)。當然,實際開發中,你可以根據你自己的需求要決定 bodysize 的上下限(包體大小是 0 字節的包在某些業務場景下是允許的)。記住,一定要判斷這個上下限,因為假設這是一個非法的客戶端發來的數據,其 bodysize 設置了一個比較大的數值,例如 1?1024?1024 * 1024(即 1 G),你的邏輯會讓你一直緩存該客戶端發來的數據,那么很快你的服務器內存將會被耗盡,操作系統在檢測到你的進程占用內存達到一定閾值時會殺死你的進程,導致服務不能再正常對外服務。如果你檢測了 bodysize 字段的是否滿足你設置的上下限,對于非法的 bodysize,直接關閉這路連接即可。這也是服務的一種自我保護措施,避免因為非法數據包帶來的損失。
  • 不知道你有沒有注意到整個判斷包頭、包體以及處理包的邏輯放在一個 while 循環里面,這是必要的。如果沒有這個 while 循環,當你一次性收到多個包時,你只會處理一個,下次接著處理就需要等到新一批數據來臨時再次觸發這個邏輯。這樣造成的結果就是,對端給你發送了多個請求,你最多只能應答一個,后面的應答得等到對端再次給你發送數據時。這就是對粘包邏輯的正確處理。

以上邏輯和代碼是最基本的粘包和半包處理機制,也就是所謂的技術上的解包處理邏輯(業務上的解包處理邏輯后面章節再介紹)。希望讀者能理解他們,在理解了他們的基礎之上,我們可以給解包拓展很多功能,例如,我們再給我們的協議包增加一個支持壓縮的功能,我們的包頭變成下面這個樣子:

#pragma pack(push, 1) //協議頭 struct msg {char compressflag; //壓縮標志,如果為1,則啟用壓縮,反之不啟用壓縮int32_t originsize; //包體壓縮前大小int32_t compresssize; //包體壓縮后大小char reserved[16]; //保留字段,用于將來拓展 }; #pragma pack(pop)

修改后的代碼如下:

void ChatSession::OnRead(const std::shared_ptr<TcpConnection>& conn, Buffer* pBuffer, Timestamp receivTime) {while (true){//不夠一個包頭大小if (pBuffer->readableBytes() < (size_t)sizeof(msg)){//LOGI << "buffer is not enough for a package header, pBuffer->readableBytes()=" << pBuffer->readableBytes() << ", sizeof(msg)=" << sizeof(msg);return;}//取包頭信息msg header;memcpy(&header, pBuffer->peek(), sizeof(msg));//數據包壓縮過if (header.compressflag == PACKAGE_COMPRESSED){//包頭有錯誤,立即關閉連接if (header.compresssize <= 0 || header.compresssize > MAX_PACKAGE_SIZE ||header.originsize <= 0 || header.originsize > MAX_PACKAGE_SIZE){//客戶端發非法數據包,服務器主動關閉之LOGE("Illegal package, compresssize: %lld, originsize: %lld, close TcpConnection, client: %s", header.compresssize, header.originsize, conn->peerAddress().toIpPort().c_str());conn->forceClose();return;}//收到的數據不夠一個完整的包if (pBuffer->readableBytes() < (size_t)header.compresssize + sizeof(msg))return;pBuffer->retrieve(sizeof(msg));std::string inbuf;inbuf.append(pBuffer->peek(), header.compresssize);pBuffer->retrieve(header.compresssize);std::string destbuf;if (!ZlibUtil::UncompressBuf(inbuf, destbuf, header.originsize)){LOGE("uncompress error, client: %s", conn->peerAddress().toIpPort().c_str());conn->forceClose();return;}//業務邏輯處理if (!Process(conn, destbuf.c_str(), destbuf.length())){//客戶端發非法數據包,服務器主動關閉之LOGE("Process error, close TcpConnection, client: %s", conn->peerAddress().toIpPort().c_str());conn->forceClose();return;}}//數據包未壓縮else{//包頭有錯誤,立即關閉連接if (header.originsize <= 0 || header.originsize > MAX_PACKAGE_SIZE){//客戶端發非法數據包,服務器主動關閉之LOGE("Illegal package, compresssize: %lld, originsize: %lld, close TcpConnection, client: %s", header.compresssize, header.originsize, conn->peerAddress().toIpPort().c_str());conn->forceClose();return;}//收到的數據不夠一個完整的包if (pBuffer->readableBytes() < (size_t)header.originsize + sizeof(msg))return;pBuffer->retrieve(sizeof(msg));std::string inbuf;inbuf.append(pBuffer->peek(), header.originsize);pBuffer->retrieve(header.originsize);//業務邏輯處理if (!Process(conn, inbuf.c_str(), inbuf.length())){//客戶端發非法數據包,服務器主動關閉之LOGE("Process error, close TcpConnection, client: %s", conn->peerAddress().toIpPort().c_str());conn->forceClose();return;}}// end else}// end while-loop }

這段代碼先根據包頭的壓縮標志字段判斷包體是否有壓縮,如果有壓縮,則取出包體大小去解壓,解壓后的數據才是真正的業務數據。整個程序執行流程圖如下:

?

?

總結

以上是生活随笔為你收集整理的TCP 协议如何解决粘包、半包问题的全部內容,希望文章能夠幫你解決所遇到的問題。

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

天天综合网在线观看 | 成人动漫一区二区 | www.狠狠操.com | 中文在线免费视频 | 天天色天天色 | 免费在线播放 | 高清一区二区三区av | 日韩最新av在线 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 午夜av电影院 | 成人黄色一级视频 | 91视频在线网址 | 色国产精品一区在线观看 | 国产精品久久久久久麻豆一区 | 深夜免费网站 | 色开心| 免费视频一级片 | 91麻豆精品 | 天天综合91 | 黄污网 | 人人爽人人做 | 欧美日韩亚洲第一页 | 久久国产精品二国产精品中国洋人 | 精品国产乱码一区二 | 婷婷亚洲综合五月天小说 | 欧美日韩在线观看视频 | 久草在线免| 中文字幕国产 | 国产精品久久嫩一区二区免费 | 国产精品久久久一区二区三区网站 | 国产精品美乳一区二区免费 | 五月天六月婷婷 | 在线观看国产中文字幕 | 91精品导航| 久章草在线观看 | 手机看片中文字幕 | 开心色激情网 | 久久激情小视频 | 91视频最新网址 | 激情电影影院 | 日韩城人在线 | 国产中文字幕视频在线观看 | 亚洲视频免费视频 | 久久久久久久久久毛片 | 亚洲欧洲在线视频 | 日韩免费在线观看网站 | 亚洲视屏 | 99视频偷窥在线精品国自产拍 | 亚洲精品美女久久17c | 亚洲男男gaygayxxxgv | 天天操导航 | 超级碰碰碰视频 | 丁香婷婷综合激情五月色 | 亚洲综合色视频在线观看 | 狠狠色丁香久久婷婷综合五月 | 成人精品影视 | 日日干日日 | 欧美日韩在线网站 | 处女av在线 | 99精品国产aⅴ | 免费看的黄色录像 | 麻豆视频在线免费观看 | 六月丁香激情综合色啪小说 | 久久综合久久鬼 | 国产成人在线网站 | 国产我不卡 | 精品伦理一区二区三区 | 免费精品久久久 | 国产麻豆视频免费观看 | 精品国产自在精品国产精野外直播 | 精品1区2区 | 久久久久看片 | 国产91av视频在线观看 | 人人看看人人 | 在线精品亚洲 | 深夜免费福利视频 | 亚洲精品乱码久久久久久蜜桃91 | 免费又黄又爽视频 | 在线视频 亚洲 | 97成人在线免费视频 | 精品国产一区二区三区av性色 | 久久午夜免费视频 | 美女精品久久久 | 色视频在线看 | 欧美孕妇与黑人孕交 | 视频在线亚洲 | 精品国产欧美一区二区 | 国产色视频123区 | 日韩午夜视频在线观看 | 玖玖视频精品 | 日本精品va在线观看 | 国产亚洲成av人片在线观看桃 | 91麻豆产精品久久久久久 | 国产一级二级在线播放 | 免费黄a大片 | 午夜av片 | 久久99热这里只有精品 | 97在线视频免费 | 亚洲四虎在线 | 黄色亚洲大片免费在线观看 | 久久精品亚洲综合专区 | 97成人超碰| 最近免费观看的电影完整版 | 成人性生交大片免费观看网站 | 婷婷色5月| 日韩黄色一区 | 欧美色综合久久 | 色资源在线 | 亚洲欧美日韩精品久久奇米一区 | 天天射天天干天天 | 一区二区三区影院 | 黄污视频网站 | 免费看三片 | 国产日产精品一区二区三区四区的观看方式 | 狠狠的日日 | 操操日日| 久久新视频| 在线观看视频在线观看 | 天操夜夜操 | 色狠狠久久av五月综合 | av在线收看 | 国产一区二区免费在线观看 | 久久99久久99精品免视看婷婷 | 九色琪琪久久综合网天天 | 国产又粗又猛又爽又黄的视频免费 | 国产黑丝袜在线 | 免费成人av网站 | 国产小视频免费观看 | 国产专区欧美专区 | 中文字幕在线播放一区二区 | 三级小视频在线观看 | 91视频高清免费 | 国产视频一区在线 | 日韩在线一区二区免费 | 亚洲精品国久久99热 | 17婷婷久久www | 九九涩涩av台湾日本热热 | 日韩在线视频免费播放 | 国产亚洲小视频 | 美女在线国产 | 欧美日韩另类在线观看 | 天天精品视频 | 三级av免费 | 九九三级毛片 | av成人在线播放 | 丁香激情五月婷婷 | 97人人模人人爽人人喊网 | 天天操天天舔天天爽 | 久久a v视频 | 日本特黄特色aaa大片免费 | 久久爱www. | 岛国大片免费视频 | 午夜精品一二三区 | 444av| 91亚洲精品久久久 | 91亚洲网 | 欧美人人 | 色多多视频在线观看 | 亚洲作爱| 黄色aaa毛片 | 在线国产视频一区 | 波多野结衣一区二区 | 欧美日韩一二三四区 | 亚洲精品456在线播放乱码 | 一区二区中文字幕在线播放 | 97成人精品视频在线观看 | av观看免费在线 | 亚洲天堂网在线视频观看 | 激情av资源 | 久久久免费 | 国产精品美乳一区二区免费 | 91视频免费国产 | 超碰在线网 | 麻豆精品视频在线观看免费 | 一区二区视频在线播放 | 伊人成人激情 | 在线观看免费一级片 | 91福利小视频 | 亚洲综合视频在线 | 日批网站在线观看 | www.人人草 | 人人看人人 | 久草在线手机观看 | 五月婷婷激情六月 | 久久精品日本啪啪涩涩 | 五月婷婷综合久久 | 欧美大片在线观看一区 | 中文字幕精品一区 | 色婷婷狠狠 | 国产色视频网站2 | 四虎影视8848dvd| 久久综合在线 | 四虎5151久久欧美毛片 | 九九在线精品视频 | 美女久久99 | 国产精品 中文字幕 亚洲 欧美 | 久久久久亚洲精品男人的天堂 | www免费网站在线观看 | 亚洲精品福利在线观看 | 亚洲一区久久久 | 中文字幕一区二区三区乱码不卡 | 又长又大又黑又粗欧美 | 99久久精品国产一区二区三区 | av不卡在线看 | 国产中文字幕亚洲 | 国产成人久久av免费高清密臂 | 久久香蕉国产精品麻豆粉嫩av | 中文字幕在线字幕中文 | 亚洲国产高清视频 | 超碰97免费在线 | 国产精品久久久久久久毛片 | 国产精品久久久久久久久久免费 | 国产精品久久久久免费观看 | 欧美性粗大hdvideo | 91正在播放 | 综合网天天射 | 九九日韩 | 在线视频第一页 | 天天操夜操 | 最新中文字幕在线观看视频 | 九色精品免费永久在线 | 少妇bbw搡bbbb搡bbb | 综合久色| 日韩精品视频免费看 | 91精品啪在线观看国产 | 国产精品网在线观看 | 开心色婷婷 | 免费在线观看成人小视频 | 91精品国产综合久久久久久久 | 亚洲综合色丁香婷婷六月图片 | 手机看片福利 | 国产综合视频在线观看 | 中文字幕超清在线免费 | 国产精品高潮呻吟久久久久 | 91精品天码美女少妇 | 在线视频一二三 | 2019中文最近的2019中文在线 | 欧美一区视频 | 久久久久亚洲精品男人的天堂 | 亚洲区色 | 九九热免费精品视频 | 91精品蜜桃| 在线观看的黄色 | 国产精品麻豆欧美日韩ww | 黄色在线观看免费网站 | 在线影视 一区 二区 三区 | 天天干一干 | 亚洲视频免费在线观看 | 激情五月激情综合网 | 日韩精品1区2区 | 五月天激情视频 | 91精品国产自产在线观看 | 久久久免费看视频 | 国产一区二区手机在线观看 | 91成人免费在线 | 日韩在线不卡视频 | 国产精品入口传媒 | 日本久久久久久久久久久 | 久久999久久| 日韩欧美视频一区二区 | 亚洲一级国产 | www.久久久com| 久久精品精品电影网 | 91视频免费网站 | 日韩精品字幕 | 欧美性视频网站 | 日本性生活免费看 | 成人h电影在线观看 | 国产一级性生活视频 | 国产成人三级在线观看 | 日操操 | 麻豆91精品91久久久 | 首页中文字幕 | 人人射| 大胆欧美gogo免费视频一二区 | 992tv在线观看网站 | 日韩中文字幕免费在线观看 | 日韩精品久久一区二区三区 | 久久天天躁夜夜躁狠狠85麻豆 | 久久伊人综合 | 久久久久久久久久久高潮一区二区 | 久久久福利 | 久久看看 | 亚洲精品久久久久中文字幕m男 | 免费观看视频的网站 | a在线v | 久久视频| 日韩| 成人av一二三区 | 97视频在线看 | 成人免费视频网 | 黄色一级免费 | 一区二区视频免费在线观看 | 亚洲成人一区 | 亚洲国产久 | 在线不卡视频 | 99性视频 | 在线看中文字幕 | 综合久久久久久久久 | 狠狠操操操| 91视频免费网址 | 不卡中文字幕在线 | 四季av综合网站 | 久久久久国产精品厨房 | 女女av在线 | 亚洲精品欧美精品 | 国产高清专区 | 日韩免费视频播放 | 国产精品在线看 | 最近日本韩国中文字幕 | 天天爽夜夜爽精品视频婷婷 | 天天干,天天射,天天操,天天摸 | 国模视频一区二区 | 日韩欧美在线高清 | www久久国产 | 一级性视频 | 麻豆91在线| 成人久久久久 | av在线成人 | 国产一区免费 | 欧美极品少妇xbxb性爽爽视频 | 国产一区视频在线播放 | 久久人人爽人人片av | 欧美大片第1页 | 另类五月激情 | 中文av免费 | 欧美在线99 | 国产成人黄色片 | 97超碰精品 | 色av婷婷| 久久久91精品国产一区二区三区 | 波多野结衣在线视频免费观看 | 久久久久国产精品www | 日日摸日日添夜夜爽97 | av一区在线播放 | 97视频亚洲 | 丝袜美腿亚洲 | 午夜资源站 | 国产精品一二 | www.com操 | 亚洲热视频 | 丝袜美腿av | 欧美性视频网站 | 欧美在线视频日韩 | 狠狠综合久久 | 日本中文字幕在线一区 | 欧美一区二区在线看 | 亚洲欧洲日韩在线观看 | 亚洲精品小视频 | 亚洲精品久久久久58 | 欧美巨乳波霸 | 国产一区在线免费观看 | 午夜精品一二区 | 亚州精品国产 | 久久精品视频在线观看免费 | 国内精品久久久久国产 | 亚洲三级性片 | 国产亚洲精品成人 | 成年人免费看 | www日韩在线观看 | 国产精品原创在线 | 91成品视频| 日韩欧美视频免费看 | japanese黑人亚洲人4k | 一级理论片在线观看 | 国产区第一页 | 99自拍视频在线观看 | 欧美在线观看视频一区二区 | 久久精品8 | 亚洲国产中文字幕在线视频综合 | 在线 国产 日韩 | 精品一区二区av | 天天操夜夜操 | 99自拍视频在线观看 | 激情av一区二区 | 国产你懂的在线 | www.福利| 一区二区三区日韩视频在线观看 | 国产精品女人久久久 | 精品国产一区二区三区在线观看 | 色综合久久久久久久 | 麻豆视频在线观看免费 | www九九热| 黄色资源网站 | 久草9视频 | 夜夜骑日日| 久久99免费观看 | 人交video另类hd | 精品久久久久久亚洲 | 日韩欧美不卡 | 丁香六月天婷婷 | 免费av网站观看 | 亚洲视频分类 | 久久精品超碰 | 久久精品久久精品久久39 | 天天操天天摸天天干 | 中文字幕一区二区三区久久蜜桃 | 国产精品一区二区62 | 日韩欧美精品免费 | 国产精品午夜在线 | 日韩一级黄色大片 | 久久国语露脸国产精品电影 | 成人免费在线视频观看 | 人人爽人人爽人人爽学生一级 | 97视频总站 | 欧美极品久久 | 中文字幕日韩一区二区三区不卡 | 国产精品一码二码三码在线 | 91精品秘密在线观看 | 夜夜操天天干 | 国产99久久九九精品免费 | 四虎最新域名 | 91中文字幕一区 | 国产九九精品视频 | 亚洲激色 | 久久在线观看视频 | 98久9在线 | 免费 | 麻豆网站免费观看 | 婷婷在线网| 色噜噜在线观看视频 | 日韩精品一区二区电影 | 狠狠88综合久久久久综合网 | 亚洲一级免费电影 | 97国产精品一区二区 | 91热精品| 天天天天天天操 | 在线免费观看羞羞视频 | 在线免费观看黄 | 免费午夜视频在线观看 | 亚洲欧美日韩精品久久久 | 四虎成人网 | 久久精品免费观看 | 精品国产一区在线观看 | 欧美9999| 九九九九色 | 在线观看91久久久久久 | 婷婷色吧 | 亚洲黄色成人网 | 国内综合精品午夜久久资源 | 在线观看国产高清视频 | 久久精品国产免费看久久精品 | 97人人视频 | 成人h电影 | 亚洲精品乱码久久久久久蜜桃欧美 | 又爽又黄又无遮挡网站动态图 | 久久国产欧美日韩精品 | 久操视频在线 | 亚洲黄色av网址 | 亚洲资源在线 | 97视频在线观看免费 | 精品国产免费久久 | 日韩欧美国产免费播放 | 97超碰人人模人人人爽人人爱 | 91亚洲精品国偷拍自产在线观看 | 国产最新视频在线 | 国内精品久久久久久久久久久久 | 久精品视频在线观看 | 欧美日韩视频精品 | 91日韩在线播放 | 狠狠干网 | 亚洲最新av网站 | 免费亚洲视频在线观看 | 国产成a人亚洲精v品在线观看 | 视频国产区 | 亚洲福利精品 | 蜜臀久久99静品久久久久久 | 500部大龄熟乱视频使用方法 | 人人澡超碰碰 | 欧美老女人xx | 久久久影院| 少妇bbw揉bbb欧美 | 麻豆传媒视频在线播放 | 青青久草在线视频 | 9999精品视频 | 亚洲人久久 | 欧美日韩午夜 | 久久精品123 | 一级特黄aaa大片在线观看 | 欧美韩国日本在线 | 亚洲精品综合在线 | 久久久国产一区二区 | 久久国产高清视频 | 成人三级av | 91污污| 亚洲第一久久久 | 青春草国产视频 | 日批视频国产 | 亚洲www天堂com | 日韩精品在线免费观看 | 超薄丝袜一二三区 | 国产小视频国产精品 | 国产精品精品久久久 | 日韩色区| 色偷偷人人澡久久超碰69 | 4p变态网欧美系列 | 黄色三级网站在线观看 | 99精品久久久久 | 色先锋资源网 | 天堂资源在线观看视频 | 欧美一级欧美一级 | 91综合视频在线观看 | 国产黄色免费看 | 少妇bbb| 麻豆91精品91久久久 | 国产字幕在线看 | 色欧美成人精品a∨在线观看 | 国产精品资源 | 亚洲成色 | 美女视频久久黄 | 欧美极品一区二区三区 | 日韩中文在线播放 | 天天干天天干天天色 | 最新91在线视频 | 久草在线费播放视频 | 国外av在线 | 国产91在线观 | 香蕉网站在线观看 | 五月激情电影 | 国产一区电影在线观看 | 日韩一区正在播放 | 91夫妻视频 | 国产一区二区成人 | 日韩精品一区二区三区第95 | 黄色毛片电影 | 色综久久 | 精品福利在线观看 | 国外av在线| 久久国产精品影片 | 午夜美女wwww | 国产在线一区二区 | 精品美女视频 | 中文字幕在线观看免费观看 | 国产精品久久久久久久久久久不卡 | 日韩午夜在线观看 | 99免费观看视频 | aaa毛片视频 | 国产主播大尺度精品福利免费 | 在线观看免费日韩 | 色婷婷伊人 | 色婷婷成人| 国产99久 | 91日韩免费 | 伊人色**天天综合婷婷 | 国产免费人成xvideos视频 | 久久av伊人 | 久久99免费 | 亚洲精品小区久久久久久 | 免费国产一区二区视频 | 在线三级av| 国产一性一爱一乱一交 | 天天做天天爱天天综合网 | 日日爽天天 | 99久久激情视频 | 国产91精品看黄网站在线观看动漫 | 视频一区二区在线 | av亚洲产国偷v产偷v自拍小说 | 日韩激情久久 | av在线一二三区 | 一区二区三区四区五区六区 | 国产精品video爽爽爽爽 | 中文网丁香综合网 | 色网站免费在线看 | 男女拍拍免费视频 | 日韩视频免费在线观看 | 国产一区久久久 | 韩日电影在线观看 | 在线精品播放 | 天天色天天操天天爽 | 99视频免费看 | 国产伦理一区二区三区 | 欧美一区二区精品在线 | 国产日韩在线观看一区 | 国产美女在线精品免费观看 | 精品久久久久久亚洲综合网站 | 在线成人观看 | 亚洲电影院 | 精品久久久999 | 久久久国际精品 | 亚洲视频大全 | 开心色停停 | 国产xxxx性hd极品 | 中文字幕视频免费观看 | 中文视频在线看 | 男女视频国产 | 日韩xxxx视频 | 亚洲.www | 国产在线播放一区二区三区 | 国产高清av | 成年人电影免费看 | 国产精品精品国产婷婷这里av | 一区二区三区影院 | 国产一区二区三区 在线 | 亚洲视频 一区 | 成人午夜影院 | 国产精品99精品久久免费 | 色婷婷色 | 免费日韩一级片 | 欧美另类xxxxx| 黄色成人在线观看 | 五月综合在线观看 | 久久综合久久综合这里只有精品 | 成人a级网站 | 月丁香婷婷 | 亚洲另类在线视频 | 久久久久亚洲精品男人的天堂 | 激情久久综合网 | 久久视影 | 日本护士撒尿xxxx18 | 伊人国产视频 | av免费看网站 | a黄色片 | 在线精品视频免费观看 | 香蕉久草在线 | 亚洲精品国产拍在线 | 在线观看视频h | av丝袜天堂 | 啪啪凸凸 | 综合色综合色 | 国产99区 | 91精品久久久久久 | 欧美热久久 | 亚洲黄色在线播放 | 欧美xxxxx在线视频 | 99久e精品热线免费 99国产精品久久久久久久久久 | 国产自产高清不卡 | 91私密保健 | 最新成人av | 亚洲情感电影大片 | 九九热99视频 | 综合久久久久久 | 天天操天天干天天操天天干 | 亚洲国产美女精品久久久久∴ | 午夜少妇av | 色综合天天在线 | 色婷婷97 | 国产精品观看视频 | 久久这里有 | 国产麻豆剧果冻传媒视频播放量 | 91精品老司机久久一区啪 | 免费色av| 在线天堂中文在线资源网 | 黄色网在线播放 | 狠狠躁18三区二区一区ai明星 | 91丨精品丨蝌蚪丨白丝jk | 国产精品久久久久久久久久ktv | 久久精品香蕉视频 | 午夜黄色| 99精品国产亚洲 | 久久久18| 精品久久国产一区 | 91精品在线免费视频 | 久久视频在线观看免费 | 91久久精品一区二区二区 | 91视频久久 | www.五月婷婷 | 日韩黄色中文字幕 | 欧美日韩免费网站 | 国产日韩中文在线 | 美女网站视频一区 | 中文资源在线播放 | 色偷偷888欧美精品久久久 | 久久99视频 | 日韩三区在线 | 永久免费视频国产 | 中文字幕中文字幕在线中文字幕三区 | 干av在线 | bbbbb女女女女女bbbbb国产 | 国产精品乱码在线 | 外国av网 | 视频在线观看一区 | 在线中文字幕一区二区 | 国产h在线播放 | 成年人在线电影 | 日韩精品第1页 | 免费黄色网止 | 成全在线视频免费观看 | 98久久 | 91九色网站| 天天干,天天射,天天操,天天摸 | 极品美女被弄高潮视频网站 | 国产一区高清在线观看 | 精品高清美女精品国产区 | 国产精久久久久久妇女av | 亚洲免费av观看 | 日本中文字幕在线电影 | 欧美91片| 免费观看全黄做爰大片国产 | 亚洲国产中文在线 | 69亚洲乱 | 久操免费视频 | 一区二区三区日韩在线观看 | 久久视频免费观看 | 成人小视频在线播放 | 亚洲精品视频一 | 天天操天天干天天操天天干 | 超薄丝袜一二三区 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | avove黑丝| 亚洲最大av在线播放 | 久草资源在线观看 | 国产一区二区三区高清播放 | 亚洲综合网 | 国产91精品在线播放 | 三级av网站 | 欧美精品999 | 青青河边草免费直播 | 91亚洲精品久久久蜜桃 | 日韩成人精品一区二区三区 | 黄色片免费电影 | 麻豆94tv免费版 | 人人爽人人爽人人片av | 三级av免费观看 | 黄色成人影院 | 中文字幕日韩伦理 | 91香蕉视频 | www.99热精品 | 亚洲综合情 | 玖玖精品在线 | 欧美福利久久 | 欧美一级大片在线观看 | 最近中文字幕大全 | 五月婷婷在线观看视频 | 欧美日韩国产一区二区在线观看 | 天天在线操| 免费v片| 国产成人在线播放 | 婷婷在线观看视频 | 欧美日韩在线看 | 欧美做受高潮电影o | 久久电影中文字幕视频 | 在线观看国产日韩 | 国产精品一区二区三区四区在线观看 | 久久免费公开视频 | 伊人久久五月天 | 色婷婷天天干 | 国产欧美精品一区二区三区 | 久久精品国产亚洲aⅴ | 中文字幕乱码电影 | 亚洲午夜精品久久久 | 四虎国产精品永久在线国在线 | 久久久久久久99精品免费观看 | 97成人免费视频 | 九九热在线视频免费观看 | 国精产品999国精产 久久久久 | 亚洲综合在线一区二区三区 | 精品久久久久久亚洲综合网 | 日本黄色免费播放 | 久久视频网 | 久久久免费观看完整版 | 亚洲人人网 | 国产涩涩在线观看 | 美女免费黄网站 | av在线之家电影网站 | 免费成人av网站 | 91九色视频在线观看 | 日韩精品aaa | 永久免费av在线播放 | 欧美激情精品一区 | 中午字幕在线观看 | 欧美色操 | 成av在线 | 999热线在线观看 | 综合久久网站 | www.久久久.cum | 国产黄色高清 | 四虎成人在线 | 在线观看理论 | 在线视频 精品 | 99热这里| 黄色网www| 欧美成人aa| 在线a人片免费观看视频 | 韩国av一区二区三区在线观看 | 麻豆成人网 | 国产在线国偷精品产拍免费yy | 国产成人久久精品77777 | av综合站 | 久久久国产99久久国产一 | 在线国产一区 | 最新国产视频 | 黄色亚洲片 | 欧美性做爰猛烈叫床潮 | 国产一级淫片在线观看 | 激情深爱.com | 一级黄色大片 | 欧美色888 | 亚洲作爱 | 91一区二区三区在线观看 | 免费黄色一区 | japanesefreesexvideo高潮 | av一级片网站| 久草在线观 | 99精品视频免费看 | 国产在线 一区二区三区 | 亚洲成人av影片 | 国产69久久精品成人看 | 亚洲电影自拍 | a√天堂资源| 亚洲免费a| av网站有哪些 | 色先锋av资源中文字幕 | 四虎影视成人永久免费观看亚洲欧美 | 久久精品欧美一区 | 欧美人体xx | 亚洲国产影院av久久久久 | 精品久久久久久久久久久久久久久久 | 国产91影院| 亚洲最快最全在线视频 | 干狠狠 | 精品国精品自拍自在线 | 92av视频 | 日韩欧美大片免费观看 | 成人av影院在线观看 | 亚洲国内精品 | 国产丝袜制服在线 | 不卡电影免费在线播放一区 | 成年人免费看片网站 | 九九在线精品视频 | 亚洲国产精品久久久久婷婷884 | 97视频免费在线看 | 婷婷久久久 | 色综合久久久久综合99 | 色婷婷激情 | 久久一级片 | 久久视频精品在线观看 | 91成人小视频| 欧美性生活一级片 | 成人av动漫在线 | 午夜电影中文字幕 | 亚洲精品av在线 | 视频在线91 | 中文字幕在线视频一区二区 | 久草资源在线 | 成年人免费在线观看网站 | 91国内在线视频 | 91精品国产乱码在线观看 | 日韩精品视频在线观看免费 | 香蕉视频国产在线观看 | 亚洲精品视频久久 | 国产精品理论片在线观看 | www久久国产 | 五月亚洲婷婷 | 亚洲精品一区二区三区高潮 | 免费看成人av | 999成人免费视频 | 日本不卡一区二区三区在线观看 | 狠狠色婷婷丁香六月 | 日韩小视频 | 久久国产精品99国产 | 狠狠操在线 | 国产在线小视频 | 天天操狠狠干 | 成人免费影院 | 国产精品九九久久久久久久 | 9在线观看免费高清完整版在线观看明 | 在线观看免费一级片 | 美女视频免费精品 | 欧美精品一区二区三区四区在线 | 国产亚洲婷婷 | 一区二区精品在线 | 亚洲人成在线观看 | 97久久精品午夜一区二区 | 中文在线免费一区三区 | 久久手机免费观看 | 精品久久久久久久久久国产 | 91麻豆视频网站 | 九九热只有这里有精品 | 91中文字幕网 | 亚洲特级片 | 美女网站色在线观看 | 伊人婷婷久久 | 国产成人在线看 | 国产91成人在在线播放 | 不卡视频在线看 | 国产成年免费视频 | 国产在线视频一区二区 | 成人一级免费视频 | 中文字幕一区二区三区在线视频 | 在线成人免费电影 | 亚洲精品99久久久久中文字幕 | 国产v在线播放 | 免费一级片久久 | 免费精品人在线二线三线 | 五月天六月婷 | 日韩理论影院 | 狠狠操电影网 | www久久精品 | 国产午夜三级一二三区 | 国产黄网站在线观看 | 成人小视频在线观看免费 | 成人欧美日韩国产 | 亚洲国产精品成人综合 | 日韩美av在线 | 欧美成人在线免费 | 国产日韩欧美自拍 | 在线视频日韩欧美 | 久久国产精品99久久久久久进口 | 国产亚洲永久域名 | 91精品一区二区三区久久久久久 | 国产亚洲一区 | 久久国产欧美日韩精品 | av播放在线 | 99热9| 美女免费视频观看网站 | 91亚色在线观看 | 在线观看91视频 | 天天天综合网 | av网站在线观看播放 | a午夜电影 | 国产精品麻豆免费版 | 久久久综合电影 | 国产欧美三级 | 免费av片在线 | 国产视频一二三 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 中文在线字幕免费观看 | 天天综合入口 | 欧美色噜噜噜 | 免费成人黄色片 | 亚洲综合爱| 丁香综合av | 欧美一级xxxx| 欧美一性一交一乱 | 天天鲁天天干天天射 | 日韩av资源站 | 在线观看视频福利 | 97视频免费看 | 天天操天天操天天爽 | 99视频在线免费 | 五月婷婷一区二区三区 | 亚洲精品免费在线播放 | 日韩精品五月天 | 国产精品视频全国免费观看 | 18做爰免费视频网站 | 久久久久久毛片精品免费不卡 | 天天操天天操天天 | 13日本xxxxxⅹxxx20| 中文字幕久久精品亚洲乱码 | 国产99在线播放 | 免费观看高清 | 日本激情动作片免费看 | 91亚洲精品久久久久图片蜜桃 | 夜夜高潮夜夜爽国产伦精品 | 亚洲高清av| 久久精品久久精品久久精品 | 国产日韩欧美在线播放 | 人人草在线视频 | 高清av免费一区中文字幕 | 日韩专区 在线 | 久久夜色精品国产欧美乱极品 | 日韩女同av | 亚洲理论在线观看电影 | 色综合小说 | 99精品一区| 免费观看版 | 国产精品久久久久999 | 国产精品入口66mio女同 | 99久久精品国产一区 | 国产精品乱码久久久久久1区2区 | 亚洲a资源 | 三级黄色在线观看 | 国产精品免费一区二区三区 | 国产精品一区二区 91 | 欧美乱大交 | 亚洲精品国产精品国 | 国产剧情在线一区 | 亚洲精品国偷拍自产在线观看蜜桃 | 大荫蒂欧美视频另类xxxx | 99色网站 | 色综合欧洲 | 久久精品视频免费播放 | 精品久久久久国产 | 亚洲综合色av | 天天操天天射天天爱 | 一区二区三高清 | 久久久久人人 | 国产亚洲欧美在线视频 | 午夜黄色一级片 | 免费看黄色91 | 日韩v欧美v日本v亚洲v国产v | 天天操天天色天天射 | 亚洲视频专区在线 | 久久影院中文字幕 | 视频在线日韩 | 精品国产伦一区二区三区观看体验 | 日本精品视频在线播放 | 国产亚洲激情视频在线 | 狠狠色噜噜狠狠狠合久 | 国产你懂的在线 | 亚洲精品乱码久久久久久久久久 | 国产在线一区二区 | 日韩精品一区二区三区高清免费 | 国产精品高清免费在线观看 | 在线看日韩| 亚洲精品国产自产拍在线观看 | 国产免费xvideos视频入口 | www.黄色片网站 | 在线高清av |