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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

TCP/IP协议栈之LwIP(四)---网络诊断与状态查询(ICMPv4 + ICMPv6)

發布時間:2024/3/7 编程问答 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 TCP/IP协议栈之LwIP(四)---网络诊断与状态查询(ICMPv4 + ICMPv6) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 一、ICMP協議簡介
    • 1.1 ICMPv4報文功能
    • 1.2 ICMPv6報文功能
  • 二、PC常用網絡命令
  • 三、ICMP協議實現
    • 3.1 ICMPv4數據報描述
    • 3.2 ICMPv4數據報操作函數
    • 3.3 ICMPv6數據報描述與操作
    • 3.4 如何發送ping命令
    • 3.5 ICMP洪水攻擊
  • 更多文章

一、ICMP協議簡介

架構IP網絡時需要特別注意兩點:確認網絡是否正常工作;遇到異常時進行問題診斷。例如,一個剛剛搭建好的網絡,需要驗證該網絡的設置是否正確,為了確保網絡能夠按照預期正常工作,一旦遇到什么問題需要立即制止問題的蔓延。IP協議雖然完成了數據報在各個主機之間的遞交,但它只提供了一種無連接不可靠的數據報交付服務,協議本身并不提供任何錯誤檢驗與恢復機制,這就需要另一種協議ICMP(Internet Control Message Protocol)提供相應的錯誤檢驗與狀態查詢機制。

ICMP協議的主要功能包括,確認IP包是否成功送達目標地址,通知在發送過程當中IP包被廢棄的具體原因,改善網絡設置等。有了這些功能后,就可以獲得網絡是否正常、設置是否有誤以及設備有何異常等信息,從而便于進行網絡上的問題診斷。

在IP通信中如果某個IP包因為某種原因未能到達目標地址,那么這個具體的原因將由ICMP負責通知。ICMP的這種通知消息會使用IP數據報進行發送,從這點看ICMP有點像上層傳輸層協議,但由于ICMP并不為應用程序提供傳輸服務,所以仍算作網絡層協議。ICMP報文封裝位置與格式如下圖示:

1.1 ICMPv4報文功能

從功能上劃分,ICMP消息報文大致可以分為兩類:一類是通知出錯原因的差錯報告報文;另一類是用于診斷的查詢消息報文。差錯報告報文主要用來向IP數據報源主機返回一個差錯報告信息,這個錯誤報告信息產生的原因是路由器或主機不能對當前數據報進行正常的處理,例如無法將數據報遞交給有效的上層協議、數據報因為生存時間TTL減為0而被刪除等。查詢報文用于一臺主機向另一臺主機查詢特定的信息,通常查詢報文都是成對出現的,即源主機發起一個查詢報文,在目的主機收到該報文后,會按照查詢報文約定的格式為源主機返回一個應答報文。兩大種類的ICMPv4報文及其常見類型如下表示:

目的站不可達:IP路由器無法將UO數據報發送到目的地址時,會給發送端主機返回一個目的不可達的ICMP消息報文,并在這個消息報文中顯示不可達的具體原因(前篇介紹的路徑MTU發現就是根據代碼4的分片位實現的),如下表示:

數據報超時:數據報超時可以用來防止數據報在網絡中被循環的路由,在IP包中有一個字段叫TTL(Time To Live,生存時間),它的值隨著每經過一次路由器就會減1,直到減到0時該IP包會被丟棄,IP路由器將會發送一個ICMP超時消息報文給發送端主機以通知該包已被丟棄(網絡上常用的traceroute命令就是充分利用ICMP超時消息實現的),超時原因主要有以下兩類:

源站抑制:為了給IP協議增加一種流量控制而設計,當路由器或主機因擁塞而丟棄數據報時,它可以向源站發送ICMP源站抑制報文,這個報文將告訴源站兩個消息:第一,你的數據報發得太快,我已經丟棄了;第二,路徑中出現了擁塞,請放慢你的數據報發送頻率。

重定向:如果路由器發現發送端主機使用了次優的路徑發送數據包,那么它會返回一個ICMP重定向消息報文告訴源主機改變它的路由表,這個消息報文中包含了最合適的路由信息和源數據,以提高數據報的遞交效率。

數據報參數錯誤:數據報在網絡中傳輸時,其首部中出現的任何二義性都可能會產生嚴重的問題,如果路由器或主機發現了這種二義性或者數據報中的某個字段丟失,路由器會直接丟棄數據報,并向源主機返回一個數據報參數錯誤報文。

回送請求或應答:用于進行通信的主機或路由器之間,判斷所發送的數據包是否已經成功到達對端的一種消息報文。可以向對端主機發送回送請求消息,也可以接收對端主機發回來的回送應答消息,網絡上最常用的ping命令就是利用這個消息報文實現的。

路由器詢問和通告:主要用于發現與自己相連網絡中的路由器,當一臺主機發出ICMP路由器請求時,路由器則返回相應的通告報文。

時間戳請求或回答:在互聯網中的兩臺主機能夠使用時間戳請求或回答報文來確定數據報在彼此之間往返所需要的時間。

地址掩碼請求或回答:主要用于主機或路由器想要了解子網掩碼的情況,可以向那些目標主機或路由器發送ICMP地址掩碼請求報文,然后通過接收ICMP地址掩碼應答報文獲取子網掩碼的信息。

1.2 ICMPv6報文功能

IPv4中ICMP僅作為一個輔助作用支持IPv4,即使沒有ICMP仍可以實現IP通信。然而在IPv6中,ICMP的作用被擴大了,如果沒有ICMPv6,IPv6就無法進行正常通信。比如在IPv6中從IP地址定位MAC地址的協議從ARP轉為ICMP的鄰居探索消息(Neighbor Discovery),這種鄰居探索消息融合了IPv4的ARP、ICMP重定向以及ICMP路由器選擇消息等功能于一體,甚至還提供自動設置IP地址的功能。

ICMPv6中將ICMP也大致分為兩類:一類是錯誤報告消息(類型0–127);另一類是信息查詢消息(類型128–255)。常用的消息類型如下表示:

上面的錯誤報告消息含義跟ICMPv4類似,其中的數據包過大是指數據包在傳遞過程中,其大小超過了鏈路的MTU值,路由器會向源節點發送此消息,此消息也被用于鏈路MTU發現協議。

上面的信息查詢報文多數也跟ICMPv4類似,下面主要介紹下多播監聽發現消息(Multicast Listener Discovery)、鄰居探索消息(Neighbor Discovery Protocol)、反鄰居探索消息等,更多信息可以參考博客:IPv6重臣之ICMPv6。

多播監聽發現:包括從類型130至類型132的消息,在多播通信中,用于確認是否有接收端,這里的MLD(Multicast Listener Discovery)可以實現IPv4中IGMP(Internet Group Management Protocol)的功能。其中多播監聽報告與結束消息用于通知多播路由器(需要支持多播路由協議,便于將組關系轉發給互聯網上其它的多播路由器)加入與退出多播組,多播監聽查詢消息用于周期性探尋本地局域網上主機是否還為多播組成員。

鄰居探索消息:ICMPv6中從類型133至類型137的消息叫做鄰居探索消息,其中鄰居請求消息用于查詢IPv6的地址與MAC地址的對應關系(與IPv4中的ARP協議功能類似),并由鄰居宣告消息得知MAC地址,鄰居請求消息利用IPv6的多播地址實現傳輸。

反鄰居探索消息:反向鄰居探索請求消息用于查詢MAC地址與IPv6地址的對應關系(與IPv4中的RARP協議功能類似),并由反向鄰居探索宣告消息得知IPv6地址,反向鄰居探索消息也利用了IPv6的多播地址實現傳輸。

由于在IPv6中實現了即插即用的功能,所以在沒有DHCP服務器的環境下也能實現IP地址的自動獲取。如果是一個沒有路由器的網絡,就使用MAC地址作為鏈路本地單播地址(前篇介紹過IPv6地址中的一種,網絡標識為FE80::/10,主機標識為64比特版的MAC地址EUI-64)。而在一個有路由器的網絡環境中,可以從路由器獲得IPv6地址的前面部分的網絡標識,后面部分的主機標識則由MAC地址進行設置(需要轉換為EUI-64),此時可以利用路由器請求與宣告消息進行設置。

二、PC常用網絡命令

前面介紹ICMP時已經提到了兩個常用的網絡命令ping與traceroute:ping命令利用ICMP的回送請求/應答消息報文檢查網絡的連通性與往返估計時間;traceroute命令利用ICMP超時消息報文顯示出由執行程序的源主機到達目的主機之前歷經多少路由器。下面分別看下這兩個命令的使用示例:


上面是在windows系統上運行命令截的圖,主要是考慮到windows上命令支持的參數排版解釋更詳細。這兩個命令也是在進行網絡錯誤監測時最常用到的命令,前面介紹的查看ARP緩存表,查看路由表,查看網卡接口信息,甚至后面將要介紹的查詢網絡端口連接信息都有相關的命令提供功能支持,下面列舉出linux常用的網絡命令如下:

Linux常用網絡命令命令功能描述
ifconfig可以手動啟動、查看、修改網絡接口的相關參數,可以修改的參數包括IP地址、子網掩碼、默認網關、MTU等;
iwlist
iwconfig
iwlist可以利用無線網卡進行無線AP的檢測并獲得相關數據;
iwconfig可以設置無線網卡的相關參數;
ip網絡參數綜合命令,除了可以設置一些基本的網絡參數外,還能執行額外的IP協議,包括多IP的設置,功能很強大;
arp查看IP地址與MAC地址對的緩存表信息;
route查看目的IP地址、子網掩碼、默認網關等路由狀態信息;
nslookup
host
查看主機名與IP地址的對應關系信息;
ping查看目的主機是否可以訪問到,并可獲知往返時間等信息;
traceroute跟蹤源主機到目的主機所通過的各個路由節點信息;
netstat查看網絡傳輸層各端口的連接狀態信息,比如目前有多少連接已建立或出現問題等;
telnet可用于遠程登錄并訪問目的主機;
ftp
lftp
可與遠程主機間進行文件傳送;
tcpdump
wireshark
可捕獲網絡數據包,用于分析數據包流向甚至監聽數據包內容;
其中tcpdump是命令接口式數據包分析軟件,wireshark是圖形接口數據包分析軟件;

上面的命令使用時可以直接查看命令幫助,如果只查看簡略的命令參數信息,可以使用–help(或-h)獲得簡略命令幫助信息,如果想查看詳細的幫助信息可以使用man,即在命令名前加man(全稱manual使用手冊的意思)。下面看看windows系統的常用網絡命令:

windows常用網絡命令命令功能描述
ipconfig查詢網絡接口信息,包括各網卡的MAC地址、IP地址/子網掩碼/默認網關,甚至DHCP/DNS服務器地址等信息;
netshNetwork Shell是一個 Windows 系統本身提供的網絡配置命令行工具;
arp查看或修改IP地址與MAC地址對的緩存表信息;
route查看或修改目的IP地址、子網掩碼、默認網關等路由狀態信息;
nslookup查看主機名與IP地址的對應關系信息;
ping查看目的主機是否可以訪問到,并可獲知往返時間等信息;
tracert跟蹤源主機到目的主機所通過的各個路由節點信息;
netstat查看網絡傳輸層各端口的連接狀態信息,比如目前有多少連接已建立或出現問題等;
net可以查看我們的管理網絡環境、服務、用戶、登陸等信息內容;
telnet可用于遠程登錄并訪問目的主機;
ftp可與遠程主機間進行文件傳送;
wireshark可捕獲網絡數據包,用于分析數據包流向甚至監聽數據包內容;

上面的命令依然可以直接查看幫助信息獲得所支持的參數及用法,在命令后加上"/?"即可獲得該命令的幫助信息。也可以在命令名前加help查詢該命令的用法,但這種方式支持的命令相對較少,如果想獲得更強大的命令交互支持,可以使用powershell。

三、ICMP協議實現

總結下LwIP中實現了ICMP協議的哪些功能?在數據報處理過程中,根據差錯情況的不同,能夠發送兩種類型的差錯報文:目的站不可達差錯報文和數據報超時差錯報文。此外,LwIP能夠響應一種查詢報文,即回送請求報文,協議棧會根據收到的回送請求報文產生一個回送應答報文。

3.1 ICMPv4數據報描述

ICMP的數據報格式前面介紹過,其中的首部剩余字節在差錯報文與查詢報文中有些不同,兩種報文的結構分別如下圖示:


ICMP報文相比IP報文簡單些,在LwIP中描述ICMP報文的數據結構如下:

// rt-thread\components\net\lwip-1.4.1\src\include\ipv4\lwip\icmp.h#define ICMP_ER 0 /* echo reply */ #define ICMP_DUR 3 /* destination unreachable */ #define ICMP_SQ 4 /* source quench */ #define ICMP_RD 5 /* redirect */ #define ICMP_ECHO 8 /* echo */ #define ICMP_TE 11 /* time exceeded */ #define ICMP_PP 12 /* parameter problem */ #define ICMP_TS 13 /* timestamp */ #define ICMP_TSR 14 /* timestamp reply */ #define ICMP_IRQ 15 /* information request */ #define ICMP_IR 16 /* information reply */enum icmp_dur_type {ICMP_DUR_NET = 0, /* net unreachable */ICMP_DUR_HOST = 1, /* host unreachable */ICMP_DUR_PROTO = 2, /* protocol unreachable */ICMP_DUR_PORT = 3, /* port unreachable */ICMP_DUR_FRAG = 4, /* fragmentation needed and DF set */ICMP_DUR_SR = 5 /* source route failed */ };enum icmp_te_type {ICMP_TE_TTL = 0, /* time to live exceeded in transit */ICMP_TE_FRAG = 1 /* fragment reassembly time exceeded */ };PACK_STRUCT_BEGIN struct icmp_echo_hdr {PACK_STRUCT_FIELD(u8_t type);PACK_STRUCT_FIELD(u8_t code);PACK_STRUCT_FIELD(u16_t chksum);PACK_STRUCT_FIELD(u16_t id);PACK_STRUCT_FIELD(u16_t seqno); } PACK_STRUCT_STRUCT; PACK_STRUCT_END#define ICMPH_TYPE(hdr) ((hdr)->type) #define ICMPH_CODE(hdr) ((hdr)->code)/** Combines type and code to an u16_t */ #define ICMPH_TYPE_SET(hdr, t) ((hdr)->type = (t)) #define ICMPH_CODE_SET(hdr, c) ((hdr)->code = (c))

上面這些宏及數據結構的定義相對簡單,前面的宏定義主要定義了ICMP的報文類型,接下來的枚舉類型定義了目的不可達和數據報超時的報文代碼。后面的結構體定義了ICMP回送報文首部(PACK_STRUCT_FIELD禁止編譯器自對齊),這個結構體也可以拿來描述其他類型的首部;最后的宏定義分別用于查詢、設置ICMP首部中的部分字段,其中宏變量hdr指向ICMP首部結構體指針。

3.2 ICMPv4數據報操作函數

在數據報不能遞交給任何一個上層協議時,函數icmp_dest_unreach會被調用,以發送一個目的不可達ICMP差錯報文給源主機,引起目的不可達的原因是協議不可達;在UDP層處理時還將看到如果UDP數據不能被遞交給任何一個應用程序,函數icmp_dest_unreach也會被調用,這里引起目的不可達的具體原因是端口不可達。另一種差錯報文是超時報文,發送超時報文的函數叫icmp_time_exceeded,在數據報轉發和分片重裝過程中,都可能調用該函數,引發超時的具體原因可能有兩種:一種是數據報TTL為0;另一種是分片重裝時間超時。下面來看看兩種差錯報文具體是怎么被發送的:

// rt-thread\components\net\lwip-1.4.1\src\core\ipv4\icmp.c/* The amount of data from the original packet to return in a dest-unreachable */ #define ICMP_DEST_UNREACH_DATASIZE 8/*** Send an icmp 'destination unreachable' packet, called from ip_input() if* the transport layer protocol is unknown and from udp_input() if the local* port is not bound.* @param p the input packet for which the 'unreachable' should be sent,* p->payload pointing to the IP header* @param t type of the 'unreachable' packet*/ void icmp_dest_unreach(struct pbuf *p, enum icmp_dur_type t) {icmp_send_response(p, ICMP_DUR, t); }#if IP_FORWARD || IP_REASSEMBLY /*** Send a 'time exceeded' packet, called from ip_forward() if TTL is 0.* @param p the input packet for which the 'time exceeded' should be sent,* p->payload pointing to the IP header* @param t type of the 'time exceeded' packet*/ void icmp_time_exceeded(struct pbuf *p, enum icmp_te_type t) {icmp_send_response(p, ICMP_TE, t); } #endif /* IP_FORWARD || IP_REASSEMBLY *//*** Send an icmp packet in response to an incoming packet.** @param p the input packet for which the 'unreachable' should be sent,* p->payload pointing to the IP header* @param type Type of the ICMP header* @param code Code of the ICMP header*/ static void icmp_send_response(struct pbuf *p, u8_t type, u8_t code) {struct pbuf *q;struct ip_hdr *iphdr;/* we can use the echo header here */struct icmp_echo_hdr *icmphdr;ip_addr_t iphdr_src;/* ICMP header + IP header + 8 bytes of data */q = pbuf_alloc(PBUF_IP, sizeof(struct icmp_echo_hdr) + IP_HLEN + ICMP_DEST_UNREACH_DATASIZE, PBUF_RAM);if (q == NULL) {return;}iphdr = (struct ip_hdr *)p->payload;icmphdr = (struct icmp_echo_hdr *)q->payload;icmphdr->type = type;icmphdr->code = code;icmphdr->id = 0;icmphdr->seqno = 0;/* copy fields from original packet */SMEMCPY((u8_t *)q->payload + sizeof(struct icmp_echo_hdr), (u8_t *)p->payload,IP_HLEN + ICMP_DEST_UNREACH_DATASIZE);/* calculate checksum */icmphdr->chksum = 0;icmphdr->chksum = inet_chksum(icmphdr, q->len);ip_addr_copy(iphdr_src, iphdr->src);ip_output(q, NULL, &iphdr_src, ICMP_TTL, 0, IP_PROTO_ICMP);pbuf_free(q); }

這里的重點是icmp_send_response函數,它為報文申請空間,然后根據報文類型和代碼字段值填寫數據,然后計算校驗和,最后通過函數ip_output將數據報發送出去。

IP層收到ICMP報文會調用icmp_input函數處理,該函數根據報文的不同類型做出不同處理。目前LwIP只支持ICMP回送請求報文的處理,而對其他類型的ICMP報文直接丟棄,不做任何響應,這在嵌入式產品中也夠用了。對于ICMP回送請求,icmp_input生成回送應答報文并返回源主機的處理過程如下:

// rt-thread\components\net\lwip-1.4.1\src\core\ipv4\icmp.c/*** Processes ICMP input packets, called from ip_input().** Currently only processes icmp echo requests and sends* out the echo response.* @param p the icmp echo request packet, p->payload pointing to the ip header* @param inp the netif on which this packet was received*/ void icmp_input(struct pbuf *p, struct netif *inp) {u8_t type;struct icmp_echo_hdr *iecho;struct ip_hdr *iphdr;s16_t hlen;iphdr = (struct ip_hdr *)p->payload;hlen = IPH_HL(iphdr) * 4;if (pbuf_header(p, -hlen) || (p->tot_len < sizeof(u16_t)*2)) {goto lenerr;}type = *((u8_t *)p->payload);switch (type) {case ICMP_ER:/* This is OK, echo reply might have been parsed by a raw PCB(as obviously, an echo request has been sent, too). */break; case ICMP_ECHO:{int accepted = 1;/* multicast destination address? */if (ip_addr_ismulticast(&current_iphdr_dest)) {accepted = 0;}/* broadcast destination address? */if (ip_addr_isbroadcast(&current_iphdr_dest, inp)) {accepted = 0;}/* broadcast or multicast destination address not acceptd? */if (!accepted) {pbuf_free(p);return;}}if (p->tot_len < sizeof(struct icmp_echo_hdr)) {goto lenerr;}if (inet_chksum_pbuf(p) != 0) {pbuf_free(p);return;}/* At this point, all checks are OK. *//* We generate an answer by switching the dest and src ip addresses,* setting the icmp type to ECHO_RESPONSE and updating the checksum. */iecho = (struct icmp_echo_hdr *)p->payload;ip_addr_copy(iphdr->src, *ip_current_dest_addr());ip_addr_copy(iphdr->dest, *ip_current_src_addr());ICMPH_TYPE_SET(iecho, ICMP_ER);/* adjust the checksum */if (iecho->chksum >= PP_HTONS(0xffffU - (ICMP_ECHO << 8))) {iecho->chksum += PP_HTONS(ICMP_ECHO << 8) + 1;} else {iecho->chksum += PP_HTONS(ICMP_ECHO << 8);}/* Set the correct TTL and recalculate the header checksum. */IPH_TTL_SET(iphdr, ICMP_TTL);IPH_CHKSUM_SET(iphdr, 0);IPH_CHKSUM_SET(iphdr, inet_chksum(iphdr, IP_HLEN));if(pbuf_header(p, hlen)) {LWIP_ASSERT("Can't move over header in packet", 0);} else {err_t ret;/* send an ICMP packet, src addr is the dest addr of the curren packet */ret = ip_output_if(p, ip_current_dest_addr(), IP_HDRINCL,ICMP_TTL, 0, IP_PROTO_ICMP, inp);}break;default:break;}pbuf_free(p);return; lenerr:pbuf_free(p);return; }

上面的函數為了便于理解,去掉了部分不重要的編譯選項,對于傳進來的數據報pbuf,首先檢查將payload指針調整到ICMP首部并判斷首部長度是否不小于4字節,若滿足最小長度要求繼續處理。接下來根據ICMP首部不同類型做出不同處理,若為回送應答則可直接忽略,對于回送請求報文則需判斷目的地址是否合法(目的地址為多播與廣播地址的請求報文不做處理),再檢查報文長度和校驗和是否正確。當所有校驗工作成功后,就可以產生一個應答報文,應答報文不需要另開辟新的內存空間,直接重復利用請求報文空間即可,它們二者只有報文類型字段有差異,修改ICMP報文類型字段并重新計算校驗和(因只變更一個字段,有簡易算式減少計算量),交換目的IP與源IP后就可以將生成的回送應答報文通過ip_output_if函數發送出去了。

3.3 ICMPv6數據報描述與操作

LwIP 1.4.1版本中對IPv6的支持有限,并沒有實現鄰居發現和多播監聽發現功能。在最新版的LwIP 2.1.2版本中增強了對IPv6的支持,實現了ICMPv6的鄰居發現和多播監聽發現功能。這里主要以LwIP 1.4.1版本為例分析TCP/IP協議棧原理與實現代碼,鄰居發現與多播監聽發現的實現代碼在這里就暫略了,報文跟ICMPv4類似,LwIP也只實現了目的不可達、超時、回送請求/應答報文,不同的是ICMPv6三種報文分別用三個數據結構來描述了,代碼如下:

// rt-thread\components\net\lwip-1.4.1\src\include\ipv6\lwip\icmp.h#define ICMP6_DUR 1 #define ICMP6_TE 3 #define ICMP6_ECHO 128 /* echo */ #define ICMP6_ER 129 /* echo reply */enum icmp_dur_type {ICMP_DUR_NET = 0, /* net unreachable */ICMP_DUR_HOST = 1, /* host unreachable */ICMP_DUR_PROTO = 2, /* protocol unreachable */ICMP_DUR_PORT = 3, /* port unreachable */ICMP_DUR_FRAG = 4, /* fragmentation needed and DF set */ICMP_DUR_SR = 5 /* source route failed */ };enum icmp_te_type {ICMP_TE_TTL = 0, /* time to live exceeded in transit */ICMP_TE_FRAG = 1 /* fragment reassembly time exceeded */ };struct icmp_echo_hdr {u8_t type;u8_t icode;u16_t chksum;u16_t id;u16_t seqno; };struct icmp_dur_hdr {u8_t type;u8_t icode;u16_t chksum;u32_t unused; };struct icmp_te_hdr {u8_t type;u8_t icode;u16_t chksum;u32_t unused; };

該版本協議棧在ICMPv6中實現的三種報文操作函數代碼如下:

// rt-thread\components\net\lwip-1.4.1\src\core\ipv6\icmp6.c#define SMEMCPY(dst,src,len) memcpy(dst,src,len)void icmp_input(struct pbuf *p, struct netif *inp) {u8_t type;struct icmp_echo_hdr *iecho;struct ip_hdr *iphdr;struct ip_addr tmpaddr;/* TODO: check length before accessing payload! */type = ((u8_t *)p->payload)[0];switch (type) {case ICMP6_ECHO:if (p->tot_len < sizeof(struct icmp_echo_hdr)) {pbuf_free(p);return;}iecho = p->payload;iphdr = (struct ip_hdr *)((u8_t *)p->payload - IP_HLEN);ip_addr_set(&tmpaddr, &(iphdr->src));ip_addr_set(&(iphdr->src), &(iphdr->dest));ip_addr_set(&(iphdr->dest), &tmpaddr);iecho->type = ICMP6_ER;/* adjust the checksum */if (iecho->chksum >= htons(0xffff - (ICMP6_ECHO << 8))) {iecho->chksum += htons(ICMP6_ECHO << 8) + 1;} else {iecho->chksum += htons(ICMP6_ECHO << 8);}ip_output_if (p, &(iphdr->src), IP_HDRINCL, iphdr->hoplim, IP_PROTO_ICMP, inp);break;default:break;}pbuf_free(p); }void icmp_dest_unreach(struct pbuf *p, enum icmp_dur_type t) {struct pbuf *q;struct ip_hdr *iphdr;struct icmp_dur_hdr *idur;/* @todo: can this be PBUF_LINK instead of PBUF_IP? */q = pbuf_alloc(PBUF_IP, 8 + IP_HLEN + 8, PBUF_RAM);/* ICMP header + IP header + 8 bytes of data */if (q == NULL) {pbuf_free(p);return;}iphdr = p->payload;idur = q->payload;idur->type = (u8_t)ICMP6_DUR;idur->icode = (u8_t)t;SMEMCPY((u8_t *)q->payload + 8, p->payload, IP_HLEN + 8);/* calculate checksum */idur->chksum = 0;idur->chksum = inet_chksum(idur, q->len);ip_output(q, NULL, (struct ip_addr *)&(iphdr->src), ICMP_TTL, IP_PROTO_ICMP);pbuf_free(q); }void icmp_time_exceeded(struct pbuf *p, enum icmp_te_type t) {struct pbuf *q;struct ip_hdr *iphdr;struct icmp_te_hdr *tehdr;/* @todo: can this be PBUF_LINK instead of PBUF_IP? */q = pbuf_alloc(PBUF_IP, 8 + IP_HLEN + 8, PBUF_RAM);/* ICMP header + IP header + 8 bytes of data */if (q == NULL) {pbuf_free(p);return;}iphdr = p->payload;tehdr = q->payload;tehdr->type = (u8_t)ICMP6_TE;tehdr->icode = (u8_t)t;/* copy fields from original packet */SMEMCPY((u8_t *)q->payload + 8, (u8_t *)p->payload, IP_HLEN + 8);/* calculate checksum */tehdr->chksum = 0;tehdr->chksum = inet_chksum(tehdr, q->len);ip_output(q, NULL, (struct ip_addr *)&(iphdr->src), ICMP_TTL, IP_PROTO_ICMP);pbuf_free(q); }

3.4 如何發送ping命令

前面介紹了如何發送ICMP目的不可達報文與超時報文,也介紹了對于接收到的ICMP回送請求報文如何回送應答報文,但ICMP回送請求報文是如何發送的呢?前面介紹的ping命令是根據ICMP回送請求/應答報文實現的,下面就以ping命令的實現過程為例,介紹ICMP回送請求報文如何發送。

在前篇介紹IP協議時,IP層輸入函數ip_input對于每個輸入的數據包都會調用raw_input進行處理,這是IP層為應用程序直接獲取IP數據包提供的一種機制,Socket編程中將這種機制稱為原始套接字,而在LwIP內核中,我們可以把它稱為原始協議控制塊raw_pcb,對raw_pcb的描述如下:

// rt-thread\components\net\lwip-1.4.1\src\include\ipv4\lwip\ip.h/* This is the common part of all PCB types. It needs to be at thebeginning of a PCB type definition. It is located here so thatchanges to this common part are made in one location instead ofhaving to change all PCB structs. */ #define IP_PCB \/* ip addresses in network byte order */ \ip_addr_t local_ip; \ip_addr_t remote_ip; \/* Socket options */ \u8_t so_options; \/* Type Of Service */ \u8_t tos; \/* Time To Live */ \u8_t ttlstruct ip_pcb { /* Common members of all PCB types */IP_PCB; };// rt-thread\components\net\lwip-1.4.1\src\include\lwip\raw.h/** Function prototype for raw pcb receive callback functions.* @param arg user supplied argument (raw_pcb.recv_arg)* @param pcb the raw_pcb which received data* @param p the packet buffer that was received* @param addr the remote IP address from which the packet was received* @return 1 if the packet was 'eaten' (aka. deleted),* 0 if the packet lives on* If returning 1, the callback is responsible for freeing the pbuf* if it's not used any more.*/ typedef u8_t (*raw_recv_fn)(void *arg, struct raw_pcb *pcb, struct pbuf *p,ip_addr_t *addr);struct raw_pcb {/* Common members of all PCB types */IP_PCB;struct raw_pcb *next;u8_t protocol;/** receive callback function */raw_recv_fn recv;/* user-supplied argument for the recv callback */void *recv_arg; };

原始協議控制塊raw_pcb如上所示,每一個控制塊raw_pcb可定制一個特定協議類型的IP數據包,如ICMP包、TCP包、UDP包等。當IP層收到一個數據包后,如果該包首部中的IP地址和協議字段與某個raw_pcb吻合,則數據包會被遞交給這個raw_pcb處理。raw_pcb對數據包的處理過程很簡單,直接調用raw_pcb上注冊的recv回調函數,用戶根據自己的需要編寫這個回調函數,從而完成對該IP包的特定處理。內核中可能同時存在多個raw_pcb,它們各自定制不同連接上的不同協議包,因此內核利用next字段將所有raw_pcb組織在一個名為raw_pcbs的鏈表上,方便對各個原始協議控制塊進行遍歷操作。下面看看前篇提到的ip_input函數內調用的raw_input函數是如何工作的:

// rt-thread\components\net\lwip-1.4.1\src\core\raw.c/*** Determine if in incoming IP packet is covered by a RAW PCB* and if so, pass it to a user-provided receive callback function.* Given an incoming IP datagram (as a chain of pbufs) this function* finds a corresponding RAW PCB and calls the corresponding receive* callback function.* @param p pbuf to be demultiplexed to a RAW PCB.* @param inp network interface on which the datagram was received.* @return - 1 if the packet has been eaten by a RAW PCB receive* callback function. The caller MAY NOT not reference the* packet any longer, and MAY NOT call pbuf_free().* @return - 0 if packet is not eaten (pbuf is still referenced by the* caller).*/ u8_t raw_input(struct pbuf *p, struct netif *inp) {struct raw_pcb *pcb, *prev;struct ip_hdr *iphdr;s16_t proto;u8_t eaten = 0;iphdr = (struct ip_hdr *)p->payload;proto = IPH_PROTO(iphdr);prev = NULL;pcb = raw_pcbs;/* loop through all raw pcbs until the packet is eaten by one *//* this allows multiple pcbs to match against the packet by design */while ((eaten == 0) && (pcb != NULL)) {if ((pcb->protocol == proto) &&(ip_addr_isany(&pcb->local_ip) ||ip_addr_cmp(&(pcb->local_ip), &current_iphdr_dest))) {/* receive callback function available? */if (pcb->recv != NULL) {/* the receive callback function did not eat the packet? */if (pcb->recv(pcb->recv_arg, pcb, p, ip_current_src_addr()) != 0) {/* receive function ate the packet */p = NULL;eaten = 1;if (prev != NULL) {/* move the pcb to the front of raw_pcbs so that isfound faster next time */prev->next = pcb->next;pcb->next = raw_pcbs;raw_pcbs = pcb;}}}/* no receive callback function was set for this raw PCB */}/* drop the packet */prev = pcb;pcb = pcb->next;}return eaten; }

可見,raw_input的處理過程就是一個循環查找的過程,它為IP數據包查找一個協議字段和IP地址都吻合的原始協議控制塊,并調用該控制塊注冊的回調函數recv處理數據包。其余的raw_pcb的操作函數見下表:

raw_pcb操作函數函數功能描述
struct raw_pcb * raw_new(u8_t proto)創建一個raw_pcb并插入raw_pcbs鏈表首部,
以proto作為協議類型初始化該控制塊;
void raw_remove(struct raw_pcb *pcb)從raw_pcbs鏈表中移除某raw_pcb并釋放其
內存空間;
err_t raw_bind(struct raw_pcb *pcb,
ip_addr_t *ipaddr)
將本地IP地址綁定到raw_pcb上(設置IP_PCB
中的local_ip);
err_t raw_connect(struct raw_pcb *pcb,
ip_addr_t *ipaddr)
將對端IP地址綁定到raw_pcb上(設置IP_PCB
中的remote_ip);
void raw_recv(struct raw_pcb *pcb,
raw_recv_fn recv, void *recv_arg)
向raw_pcb中注冊回調函數recv及其參數recv_arg;
err_t raw_sendto(struct raw_pcb *pcb,
struct pbuf *p, ip_addr_t *ipaddr)
將一個raw IP數據包發送到目的IP地址對應的主機,
raw IP數據包首部字段值由raw_pcb提供;
err_t raw_send(struct raw_pcb *pcb,
struct pbuf *p)
實際調用raw_sendto;

利用raw_pcb的結構體及其操作函數,我們可以注冊一個ICMP協議的原始協議控制塊,用來接收IP層的ping響應包,同時利用內核的定時機制,周期性地往對端IP地址構造并發送ping請求包,而在原始協議控制塊的recv回調函數中接收并處理ping響應。按照上述原理發送ping請求的實現代碼如下:

#define PING_DELAY 1000 #define PING_ID 0xAFAF #define PING_DATA_SIZE 32 /* ping variables */ static u16_t ping_seq_num; static u32_t ping_time; static struct raw_pcb *ping_pcb = NULL; static ip_addr_t ping_dst;/** Prepare a echo ICMP request */ static void ping_prepare_echo( struct icmp_echo_hdr *iecho, u16_t len) {size_t i;size_t data_len = len - sizeof(struct icmp_echo_hdr);ICMPH_TYPE_SET(iecho, ICMP_ECHO);ICMPH_CODE_SET(iecho, 0);iecho->chksum = 0;iecho->id = PING_ID;iecho->seqno = htons(++ping_seq_num);/* fill the additional data buffer with some data */for(i = 0; i < data_len; i++) {((char*)iecho)[sizeof(struct icmp_echo_hdr) + i] = (char)i;}iecho->chksum = inet_chksum(iecho, len); }/* Ping using the raw ip */ static u8_t ping_recv(void *arg, struct raw_pcb *pcb, struct pbuf *p, ip_addr_t *addr) {struct icmp_echo_hdr *iecho;//we can also check src ip here, but just egnore itif ((p->tot_len >= (PBUF_IP_HLEN + sizeof(struct icmp_echo_hdr)))){iecho = (struct icmp_echo_hdr *)((u8_t*)p->payload + PBUF_IP_HLEN);if ((iecho->type == ICMP_ER) && (iecho->id == PING_ID) && (iecho->seqno == htons(ping_seq_num))) { LWIP_DEBUGF( PING_DEBUG, ("ping: recv "));ip_addr_debug_print(PING_DEBUG, addr);LWIP_DEBUGF( PING_DEBUG, (" time=%"U32_F" ms\n", (sys_now()-ping_time)));pbuf_free(p);return 1; /* eat the packet */}}return 0; /* don't eat the packet */ }static void ping_send(struct raw_pcb *raw, ip_addr_t *addr) {struct pbuf *p;struct icmp_echo_hdr *iecho;size_t ping_size = sizeof(struct icmp_echo_hdr) + PING_DATA_SIZE;p = pbuf_alloc(PBUF_IP, (u16_t)ping_size, PBUF_RAM);if (!p) {return;}if ((p->len == p->tot_len) && (p->next == NULL)) {iecho = (struct icmp_echo_hdr *)p->payload;ping_prepare_echo(iecho, (u16_t)ping_size);raw_sendto(raw, p, addr);ping_time = sys_now();LWIP_DEBUGF(PING_DEBUG, ("ping:[%"U32_F"] send ", ping_seq_num));ip_addr_debug_print(PING_DEBUG, addr);LWIP_DEBUGF( PING_DEBUG, ("\n"));}pbuf_free(p); }static void ping_timeout(void *arg) {struct raw_pcb *pcb = (struct raw_pcb*)arg;ping_send(pcb, &ping_dst);sys_timeout(PING_DELAY, ping_timeout, pcb); }static void ping_raw_init(void) {ping_pcb = raw_new(IP_PROTO_ICMP);raw_recv(ping_pcb, ping_recv, NULL);raw_bind(ping_pcb, IP_ADDR_ANY);sys_timeout(PING_DELAY, ping_timeout, ping_pcb); }void ping_init(void) {IP4_ADDR(&ping_dst, 192,168,1,103);ping_raw_init(); }

上面的代碼主要功能有兩個:一是通過注冊到新建raw_pcb上的ping_recv函數,當接收到IP層的ping回送請求包時,通過串口打印ping響應信息;二是通過周期性函數ping_timeout不斷調用ping_send向對端IP地址發送ping請求包(由函數ping_prepare_echo構造),并通過串口打印ping請求包發送信息。

在contrib-1.4.1中有針對lwip-1.4.1版本協議棧的ping命令實現,該實現方式沒有使用raw接口,而是采用更上層的socket接口實現,其實現代碼如下:

// rt-thread\components\net\lwip-1.4.1\src\apps\ping\ping.c/* using the lwIP custom ping */ rt_err_t ping(char* target_name, rt_uint32_t times, rt_size_t size) { #if LWIP_VERSION_MAJOR >= 2Ustruct timeval timeout = { PING_RCV_TIMEO / RT_TICK_PER_SECOND, PING_RCV_TIMEO % RT_TICK_PER_SECOND }; #elseint timeout = PING_RCV_TIMEO * 1000UL / RT_TICK_PER_SECOND; #endifint s, ttl, recv_len;ip_addr_t target_addr;rt_uint32_t send_times;rt_tick_t recv_start_tick;struct addrinfo hint, *res = NULL;struct sockaddr_in *h = NULL;struct in_addr ina;send_times = 0;ping_seq_num = 0;if (size == 0){size = PING_DATA_SIZE;}memset(&hint, 0, sizeof(hint));/* convert URL to IP */if (lwip_getaddrinfo(target_name, NULL, &hint, &res) != 0){rt_kprintf("ping: unknown host %s\n", target_name);return -RT_ERROR;}memcpy(&h, &res->ai_addr, sizeof(struct sockaddr_in *));memcpy(&ina, &h->sin_addr, sizeof(ina));lwip_freeaddrinfo(res);if (inet_aton(inet_ntoa(ina), &target_addr) == 0){rt_kprintf("ping: unknown host %s\n", target_name);return -RT_ERROR;}/* new a socket */if ((s = lwip_socket(AF_INET, SOCK_RAW, IP_PROTO_ICMP)) < 0){rt_kprintf("ping: create socket failed\n");return -RT_ERROR;}lwip_setsockopt(s, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(timeout));while (1){int elapsed_time;if (lwip_ping_send(s, &target_addr, size) == ERR_OK){recv_start_tick = rt_tick_get();if ((recv_len = lwip_ping_recv(s, &ttl)) >= 0){elapsed_time = (rt_tick_get() - recv_start_tick) * 1000UL / RT_TICK_PER_SECOND;rt_kprintf("%d bytes from %s icmp_seq=%d ttl=%d time=%d ms\n", recv_len, inet_ntoa(ina), send_times,ttl, elapsed_time);}else{rt_kprintf("From %s icmp_seq=%d timeout\n", inet_ntoa(ina), send_times);}}else{rt_kprintf("Send %s - error\n", inet_ntoa(ina));}send_times++;if (send_times >= times){/* send ping times reached, stop */break;}rt_thread_delay(PING_DELAY); /* take a delay */}lwip_close(s);return RT_EOK; }/* Ping using the socket ip */ err_t lwip_ping_send(int s, ip_addr_t *addr, int size) {int err;struct icmp_echo_hdr *iecho;struct sockaddr_in to;int ping_size = sizeof(struct icmp_echo_hdr) + size;LWIP_ASSERT("ping_size is too big", ping_size <= 0xffff);iecho = rt_malloc(ping_size);if (iecho == RT_NULL){return ERR_MEM;}ping_prepare_echo(iecho, (u16_t) ping_size);to.sin_len = sizeof(to);to.sin_family = AF_INET; #if LWIP_IPV4 && LWIP_IPV6to.sin_addr.s_addr = addr->u_addr.ip4.addr; #elif LWIP_IPV4to.sin_addr.s_addr = addr->addr; #elif LWIP_IPV6 #error Not supported IPv6. #endiferr = lwip_sendto(s, iecho, ping_size, 0, (struct sockaddr*) &to, sizeof(to));rt_free(iecho);return (err == ping_size ? ERR_OK : ERR_VAL); }int lwip_ping_recv(int s, int *ttl) {char buf[64];int fromlen = sizeof(struct sockaddr_in), len;struct sockaddr_in from;struct ip_hdr *iphdr;struct icmp_echo_hdr *iecho;while ((len = lwip_recvfrom(s, buf, sizeof(buf), 0, (struct sockaddr*) &from, (socklen_t*) &fromlen)) > 0){if (len >= (int)(sizeof(struct ip_hdr) + sizeof(struct icmp_echo_hdr))){iphdr = (struct ip_hdr *) buf;iecho = (struct icmp_echo_hdr *) (buf + (IPH_HL(iphdr) * 4));if ((iecho->id == PING_ID) && (iecho->seqno == htons(ping_seq_num))){*ttl = iphdr->_ttl;return len;}}}return len; }/** Prepare a echo ICMP request */ static void ping_prepare_echo( struct icmp_echo_hdr *iecho, u16_t len) {size_t i;size_t data_len = len - sizeof(struct icmp_echo_hdr);ICMPH_TYPE_SET(iecho, ICMP_ECHO);ICMPH_CODE_SET(iecho, 0);iecho->chksum = 0;iecho->id = PING_ID;iecho->seqno = htons(++ping_seq_num);/* fill the additional data buffer with some data */for (i = 0; i < data_len; i++){((char*) iecho)[sizeof(struct icmp_echo_hdr) + i] = (char) i;}#ifdef RT_LWIP_USING_HW_CHECKSUMiecho->chksum = 0; #elseiecho->chksum = inet_chksum(iecho, len); #endif}

3.5 ICMP洪水攻擊

如果在執行ping命令時,加大ping數據包的大小(以太網MTU即1500 - IP首部大小20 - ICMP首部大小8 = ping數據包大小1472字節),我們的板子就ping不通了,如下圖所示:

由于在協議棧內部為數據報接收而預留的空間并不能放下如此大的一個ICMP數據報文,或者如此大的一個ICMP報文在分片重裝過程中超出了重裝條件的限制(如LwIP中的pbuf使用個數限制),協議棧會直接將報文丟棄,不做任何回應,將導致主機一直接收不到ICMP回送應答,這就是ICMP洪水攻擊的雛形。

ICMP洪水攻擊的原理可以看成是網絡黑客利用其能控制的多臺中間人計算機(傀儡主機,也稱之為肉雞)一起向目標主機發送大量看似合法的ICMP回送請求數據包,造成目標主機網絡阻塞或服務器資源耗盡而導致拒絕服務產生,無法對正常用戶提供網絡服務。另一方面,合法的網絡數據報被虛假的數據報淹沒而無法在網絡中被轉發,合法的用戶不能正常使用網絡。

對于ICMP洪水攻擊,可以采取兩種方法進行防范:第一種方法是在路由器上對ICMP數據包進行帶寬限制,將ICMP占用的帶寬控制在一定范圍內,這樣即使有ICMP攻擊,它所占用的帶寬也是非常有限的,對整個網絡的影響將會非常小;第二種方法是在主機上設置ICMP數據包的處理規則,如果允許,可以拒絕向所有的ICMP數據包服務。

更多文章

  • 《qemu-vexpress-a9 for LwIP stack》
  • 《TCP/IP協議棧之LwIP(三)—網際尋址與路由》
  • 《TCP/IP協議棧之LwIP(五)—網絡傳輸管理之UDP協議》

總結

以上是生活随笔為你收集整理的TCP/IP协议栈之LwIP(四)---网络诊断与状态查询(ICMPv4 + ICMPv6)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

亚洲精品视频网站在线观看 | a视频在线播放 | 黄色亚洲在线 | 欧美一级日韩三级 | 久久免费视频8 | 日韩中文在线播放 | 在线观看黄污 | 久久综合五月婷婷 | 成年人在线观看免费视频 | av片无限看 | 亚洲少妇天堂 | 久久99国产精品视频 | 91成人在线网站 | 精品国产人成亚洲区 | 成人黄色大片在线观看 | 亚洲电影一级黄 | 播五月婷婷 | 免费视频一二三区 | 久久五月情影视 | 激情久久久久久久久久久久久久久久 | 9992tv成人免费看片 | 9999精品| 国产手机免费视频 | 激情五月色播五月 | 在线香蕉视频 | www夜夜操com | 808电影 | 91激情 | 91在线网址 | 欧美做受69 | 2024av| 欧美午夜一区二区福利视频 | 在线天堂8√ | 亚洲va韩国va欧美va精四季 | 亚洲mv大片欧洲mv大片免费 | 国产中文字幕久久 | www黄在线 | 亚洲成av人片在线观看无 | 国产在线最新 | 午夜视频免费 | 久久久久久久国产精品 | 91大神视频网站 | 狠狠色丁香婷婷综合视频 | 国产精品久久久久久久久久ktv | 三级黄免费看 | 黄色av在| 国产一二三精品 | 在线观看视频中文字幕 | 麻豆视频国产 | 97高清视频 | a级片久久久| 免费99精品国产自在在线 | 精品免费在线视频 | 国内视频在线观看 | 99久久精| 日韩激情免费视频 | 九九九免费视频 | 国产伦理剧 | 91精品啪在线观看国产线免费 | 色视频网站在线 | 亚洲区另类春色综合小说校园片 | 免费试看一区 | 色视频成人在线观看免 | 欧洲成人av | 久久九九精品久久 | 成年人国产在线观看 | .国产精品成人自产拍在线观看6 | 天天天天色综合 | 亚洲精品在线观看中文字幕 | 久久99亚洲网美利坚合众国 | 成人啊 v| 伊人手机在线 | 国产精品一区二 | 欧美在线free | 国内精品久久久 | 最近中文字幕国语免费高清6 | 免费高清在线视频一区· | 亚洲国产精品女人久久久 | 国产一区久久 | 一本一道波多野毛片中文在线 | 中文字幕一区二区三区在线观看 | 亚洲精品毛片一级91精品 | 日韩免费视频一区二区 | 少妇性色午夜淫片aaaze | 国产中文字幕网 | www夜夜 | 日产乱码一二三区别在线 | 午夜国产在线 | 九九免费在线视频 | 狠狠激情中文字幕 | 色在线免费观看 | 精品国产乱码久久久久久三级人 | 在线免费视频a | 成人黄大片视频在线观看 | 亚洲a在线观看 | 久久九九久久九九 | 热久久国产精品 | 国产欧美最新羞羞视频在线观看 | 国产又粗又硬又爽视频 | 伊人婷婷综合 | 久久艹在线 | 国产99久久99热这里精品5 | 久久夜色精品国产欧美乱 | 可以免费看av | 亚洲va欧洲va国产va不卡 | 国产亚洲日本 | 99欧美视频| 久久久久久黄色 | 在线成人中文字幕 | 国产福利av | 国产手机在线观看视频 | 欧洲精品码一区二区三区免费看 | 日韩一级片大全 | 日韩午夜电影 | 成人啪啪18免费游戏链接 | 国产色视频一区二区三区qq号 | 激情综合色图 | 久久久久久久国产精品影院 | 亚洲专区在线视频 | 日韩va欧美va亚洲va久久 | 日本大尺码专区mv | 日韩免费三级 | 日韩高清在线看 | 成人av免费在线播放 | 免费精品久久久 | 超碰97免费观看 | 久久国产二区 | 精品亚洲成人 | 欧美精品首页 | 亚洲国产精品一区二区久久hs | 婷婷视频在线播放 | 中文字幕资源网在线观看 | 91福利区一区二区三区 | 天天爱天天射天天干天天 | 欧美精品久久人人躁人人爽 | 国产96视频 | 国产成人精品福利 | 在线免费观看黄色大片 | 韩国精品一区二区三区六区色诱 | 午夜丁香网| 日韩av成人在线 | 在线观影网站 | 欧美日韩中文国产一区发布 | 日韩69视频 | 久久精品影片 | 国产成人久久精品77777综合 | 五月婷香 | 亚洲无吗视频在线 | 日韩精品极品视频 | 网站在线观看你们懂的 | 男女免费av| 特级a老妇做爰全过程 | 免费网站污| 国产精品青草综合久久久久99 | 成人小电影在线看 | 青青河边草手机免费 | 欧美精品在线免费 | 国产破处在线播放 | 激情欧美一区二区三区 | 国产精品福利在线 | 亚欧日韩成人h片 | 久久久96 | 亚洲97在线 | 中文字幕高清有码 | 91传媒视频在线观看 | 久久人人爽人人片av | 成人一级黄色片 | 999久久久久久 | 在线视频专区 | 欧美人体xx | 国产中文字幕视频 | 国内精品久久久久 | 又黄又刺激 | 国产高清成人av | 日韩欧美一区二区三区视频 | 国产精品视频地址 | 中中文字幕av在线 | 美女视频久久 | a√天堂中文在线 | 久久综合婷婷 | 欧美一级高清片 | 狠狠黄 | 亚洲人成人天堂h久久 | 亚洲五月激情 | 特级西西人体444是什么意思 | 色婷婷综合久色 | 天天躁天天躁天天躁婷 | 日韩毛片久久久 | 99亚洲天堂 | 国产午夜精品久久久久久久久久 | 午夜影院日本 | 久久久久久久久久久久久9999 | 亚洲欧美国产精品久久久久 | 国产午夜精品在线 | 日韩精品一区二区三区免费观看 | 91av短视频| 日韩视频免费 | 久久成人国产精品免费软件 | 久久婷婷综合激情 | 精品国产精品久久一区免费式 | 国产美女在线精品免费观看 | 久久午夜网 | 欧美男同视频网站 | av黄色成人 | 99久久精品国产欧美主题曲 | 丁香综合激情 | 欧美日韩在线视频观看 | 日韩视频在线观看免费 | 色99导航 | 欧美久久久久久久久久久久 | 国产第一页在线播放 | 在线视频你懂 | 亚洲国产伊人 | 久久久免费精品 | 中文字幕第一页在线 | 亚洲情影院 | 97视频人人免费看 | 亚洲天堂网在线视频观看 | 亚洲精品国产精品国自产在线 | 久久天| 久久夜色精品国产亚洲aⅴ 91chinesexxx | 精品福利在线观看 | 久久精品99国产精品酒店日本 | 日韩精品久久一区二区 | 超碰在线9 | 日韩激情在线视频 | 久久综合久久综合久久综合 | 久久精品综合网 | 干亚洲少妇| 四虎影视www | 色噜噜日韩精品欧美一区二区 | 日韩伦理片hd | 在线国产一区 | 日日色综合 | 91精品视屏 | 日本最新高清不卡中文字幕 | 日韩欧美在线一区二区 | 婷婷深爱 | 国产自产在线视频 | 美女精品网站 | 成人免费毛片aaaaaa片 | 精品国自产在线观看 | 91在线精品视频 | 97超碰在线久草超碰在线观看 | 91福利区一区二区三区 | 久久综合五月 | 久久综合中文色婷婷 | 91av99| 五月婷婷激情综合 | 日韩av手机在线观看 | 亚洲成人黄色在线 | 97精品国自产拍在线观看 | 日本少妇高清做爰视频 | 免费亚洲婷婷 | 天天综合区| 久久成人精品视频 | 人人干人人添 | 99这里只有精品99 | 日本老少交 | 亚洲欧美在线视频免费 | 日日摸日日碰 | 精品一区二区在线免费观看 | 免费日韩 精品中文字幕视频在线 | 精品国产理论 | 成人av教育| 国产午夜精品免费一区二区三区视频 | 丰满少妇在线观看网站 | 激情久久小说 | av片一区 | 国产日韩欧美在线观看 | 久久精品国产免费 | 日韩丝袜 | 国产一区欧美二区 | 五月天天色 | 黄色小网站在线观看 | 婷婷精品国产一区二区三区日韩 | 五月婷婷黄色网 | 精品国产一区二区三区不卡 | 久影院 | 免费人成网 | 欧美另类xxxxx| 婷婷丁香花 | 一级a性色生活片久久毛片波多野 | 国产精品欧美久久 | 国产69精品久久99的直播节目 | 丰满少妇麻豆av | 91伊人影院 | 国产91精品在线观看 | av在线播放亚洲 | 免费在线黄色av | 成人av片免费看 | 久久久久久久久亚洲精品 | 97超碰色| 三级黄色在线观看 | 国产亚洲精品女人久久久久久 | 国产精品久久免费看 | 视频成人永久免费视频 | 亚洲黄色片| 国产精品四虎 | 国内精品美女在线观看 | 国内一级片在线观看 | 在线免费观看麻豆视频 | 久久免费黄色大片 | 啪啪动态视频 | 国产精品久久二区 | 91精品国产92久久久久 | 91九色精品 | 精品久久久久久久久久久院品网 | 久久综合九色九九 | av解说在线| 男女免费视频观看 | 黄色小说视频网站 | 亚洲 欧美 国产 va在线影院 | 一本色道久久精品 | 久久精品一二三区 | 最新av免费在线观看 | 成人欧美亚洲 | 91视频观看免费 | 色99色| 国产视频一区二区在线 | 91亚洲狠狠婷婷综合久久久 | 国产精品久久久久久久久毛片 | 午夜av一区二区三区 | 97在线看 | 国产乱码精品一区二区三区介绍 | 99视频国产精品 | 欧美日韩亚洲在线观看 | av色网站 | 成人资源在线播放 | 欧美日韩国产二区 | 国产不卡免费 | 伊人久在线 | av直接看 | 中文字幕在线观看日本 | 亚洲欧美在线视频免费 | 成年人视频在线免费 | 国产区精品区 | 天天射天天干天天爽 | 国产精品黑丝在线观看 | 国内精品久久久久影院男同志 | 久久九九精品久久 | 亚洲国产一二三 | 中文字幕在线观看完整版 | 久久久精品网站 | 美女国产网站 | 天天综合网天天综合色 | 久章操| 欧美天天射| 天天爱天天舔 | 亚洲区精品视频 | 成年人免费电影在线观看 | 国产精久久久久久妇女av | 欧美人zozo | 国产精品入口麻豆www | 欧美日韩伦理在线 | 欧美十八 | 99热在线这里只有精品 | 日韩精品免费在线 | 麻豆91在线| 久久久久久高清 | 国产精品白浆视频 | 九九爱免费视频在线观看 | 亚洲 欧美日韩 国产 中文 | 日韩中文在线字幕 | 精品国产伦一区二区三区观看体验 | 天天干,天天操,天天射 | 国产精品理论片在线播放 | 国产在线资源 | 免费亚洲一区二区 | 国产91精品高清一区二区三区 | 亚洲欧洲中文日韩久久av乱码 | 久久女同性恋中文字幕 | 欧美性生活免费看 | 91香蕉视频黄色 | 在线看成人av | 日韩激情中文字幕 | 国产日韩视频在线观看 | 成人精品久久 | 久久精品老司机 | 国产特级毛片aaaaaa高清 | 久热只有精品 | 久久精品亚洲国产 | 免费视频91| 成片视频免费观看 | 久久人人97超碰com | av综合av | 97国产一区| 在线成人性视频 | 久久久久久久看片 | 狠狠操夜夜| 天天色天天搞 | 美女在线国产 | 国产精品一区二区中文字幕 | 在线观看国产一区 | 二区三区在线视频 | 成人亚洲欧美 | 麻豆传媒在线免费看 | av中文天堂在线 | 在线观看亚洲免费视频 | 超碰97在线人人 | 国产成人久久精品一区二区三区 | 欧美一区二区三区在线观看 | 婷婷综合影院 | 依人成人综合网 | 国产精品高清av | 狠狠狠色丁香综合久久天下网 | a黄色一级 | 在线视频 影院 | 香蕉影院在线播放 | 中文字幕婷婷 | 一区二区三区四区影院 | 久久99国产综合精品 | 99精品久久只有精品 | 久久久视频在线 | 中文字幕有码在线观看 | 国产一区二区不卡视频 | 色在线亚洲 | 玖玖爱国产在线 | 波多野结衣理论片 | 亚洲精品视频在线播放 | 色多多视频在线 | 综合网婷婷 | 精品一区二区在线观看 | 国产一级一级国产 | 在线中文字幕一区二区 | 午夜精品久久久久久久99水蜜桃 | 久久亚洲精品国产亚洲老地址 | 日韩xxxbbb | a√天堂资源 | 91在线观看视频网站 | 91黄色在线观看 | 精品爱爱| 黄免费在线观看 | 日韩中文字幕免费电影 | 免费在线观看午夜视频 | 中文字幕在线网址 | 国产一级在线视频 | 国产91精品在线播放 | 国产精品99久久久久久久久久久久 | 亚洲播播 | 国产资源免费 | 久草在线免费看视频 | 91亚洲国产成人久久精品网站 | 美女视频黄的免费的 | 久久99热精品 | 免费视频一级片 | 亚洲一区视频在线播放 | 国产免费国产 | 97在线免费观看 | 免费观看v片在线观看 | 在线亚洲欧美视频 | 亚洲波多野结衣 | 在线观看福利网站 | 国产在线观看91 | 久草精品电影 | 日本久久综合视频 | 美女黄视频免费 | 婷婷久久五月天 | 成人av免费网站 | 激情婷婷综合网 | 日日干天天爽 | 国产精品你懂的在线观看 | 91精品久久久久久久久 | 美女视频永久黄网站免费观看国产 | 丝袜少妇在线 | 欧美日bb | 四虎成人在线 | 久久免费国产精品 | 欧美性生活免费 | 成人免费视频免费观看 | 综合精品久久久 | 丁香久久五月 | 欧亚日韩精品一区二区在线 | 中文字幕成人在线观看 | 国产美女网站视频 | 热久久免费视频 | av在线播放一区二区三区 | 日韩av线观看| 国产精品va在线 | 日本在线观看中文字幕无线观看 | 93久久精品日日躁夜夜躁欧美 | a黄色影院 | 婷婷综合久久 | 亚洲黄色免费在线 | 亚洲视频aaa| 欧美成人按摩 | 免费网址你懂的 | 成年人电影免费看 | 国产精品完整版 | 91理论片午午伦夜理片久久 | 国产精品综合av一区二区国产馆 | 久久精品视频在线观看 | 亚洲国产成人在线播放 | 国产精品一区二区视频 | 国产区精品在线观看 | 天天干天天射天天插 | 911亚洲精品第一 | 中文字幕久久精品亚洲乱码 | 97超碰免费在线观看 | 亚洲成a人片在线观看网站口工 | 天天射天天干天天插 | 亚洲精品美女久久17c | 久久国产精品免费一区二区三区 | 中文字幕视频在线播放 | 色婷婷啪啪免费在线电影观看 | 亚洲激情网站免费观看 | 日韩精品2区 | 国产精品一区二区三区四区在线观看 | 一区二区三区播放 | 在线欧美a| 欧美视频18 | 免费观看性生交 | 国产精品不卡在线观看 | 91亚洲精品久久久久图片蜜桃 | 免费观看视频黄 | 国产网站在线免费观看 | 91视频在线播放视频 | 久久精品国产一区二区电影 | 中文字幕4 | 五月婷婷在线视频观看 | 又黄又爽又色无遮挡免费 | 成人黄视频 | 久草在线中文888 | 激情 婷婷| 中文字幕一区二区在线播放 | 午夜精品久久久久久久99婷婷 | 亚洲高清久久久 | 热re99久久精品国产66热 | 亚洲成aⅴ人在线观看 | 国产成人三级在线观看 | 久碰视频在线观看 | av片在线观看 | 国产中文欧美日韩在线 | 一区二区电影在线观看 | 人人射av | 久草在线资源免费 | 国产中文字幕视频 | 精品伦理一区二区三区 | 另类老妇性bbwbbw高清 | 久久久久久久免费看 | 亚洲一级久久 | 色播六月天 | 99精品免费 | 国产成人av一区二区三区在线观看 | 九月婷婷人人澡人人添人人爽 | 干天天 | 久久精品国产精品 | 97在线观看免费高清 | 亚洲国产字幕 | a在线免费观看视频 | 成人黄色在线视频 | 久久avav| 中文在线www | 黄色片毛片 | 91麻豆高清视频 | 91av视频在线观看 | 欧美午夜久久 | 免费在线观看一区 | 国产在线观看黄 | 午夜精品视频免费在线观看 | 国产精品免费一区二区 | 欧美91精品久久久久国产性生爱 | 午夜国产一区二区三区四区 | 免费黄色网址大全 | 久久久www成人免费毛片麻豆 | 在线婷婷| av综合av | 一区二区三区中文字幕在线观看 | 国产日产精品久久久久快鸭 | 伊人日日干 | 精品爱爱 | 久久国产精品电影 | 亚洲天天干 | 九九久久在线看 | 国产一区自拍视频 | 亚洲 欧美 91 | 国产女人免费看a级丨片 | 国产精品久久电影观看 | 久久伊人八月婷婷综合激情 | 亚洲最大在线视频 | 国产一区二区手机在线观看 | 国内精品久久久久久久97牛牛 | 四虎影视8848aamm | 草久视频在线观看 | www.久久久.com | 永久黄网站色视频免费观看w | 色com网| 亚洲精品国产综合久久 | 就要干b| 在线欧美最极品的av | 日本性生活一级片 | 日韩有码在线播放 | 久久国产精品影视 | 天堂va在线观看 | 婷婷丁香综合 | 亚洲欧美视频 | 97日日碰人人模人人澡分享吧 | 99久久精品免费看国产免费软件 | 99精品久久久久久久 | 国产精品日韩在线 | 中文字幕在线专区 | 在线观看国产成人av片 | 天天操福利视频 | 欧美黑吊大战白妞欧美 | av超碰在线 | 欧美日韩伦理在线 | 久草视频在线免费看 | 狠狠狠狠狠狠天天爱 | 天天天天爱天天躁 | 精品免费久久 | 国产精品久久久久久久久免费 | 亚洲午夜精品福利 | 国产精品一区二区三区在线播放 | 日日夜夜国产 | 人成在线免费视频 | 黄色美女免费网站 | 国产一级精品视频 | 天天天操操操 | 深爱婷婷网 | 91九色在线视频观看 | 三级黄色片在线观看 | 久久a热6 | 黄色日视频 | 一区中文字幕在线观看 | 欧美a级片免费看 | 国产91成人在在线播放 | 日本中文字幕在线看 | 色综合a | 国产高清在线观看av | 国产麻豆果冻传媒在线观看 | 成人在线一区二区三区 | 黄色毛片一级 | 国产不卡视频 | 在线视频18在线视频4k | 激情综合狠狠 | 国产尤物在线观看 | 久久人人爽人人片av | 最近的中文字幕大全免费版 | 国产综合精品久久 | zzijzzij日本成熟少妇 | 欧美精彩视频 | 欧美日韩国产精品一区二区亚洲 | 久久精品99国产 | 狠狠狠狠狠狠天天爱 | 91视频免费| 久草视频在线免费播放 | 黄色在线看网站 | 97色视频在线 | av成年人电影 | 91精品国产乱码在线观看 | 国产免费一区二区三区最新6 | 久久久久久久久综合 | 国产精品一级在线 | av丝袜美腿| 国产传媒中文字幕 | 日韩欧美高清一区二区三区 | 日本精品久久久久久 | av超碰免费在线 | 精品久久1 | 射久久 | 欧美日韩国产一区 | 国产在线一区二区三区播放 | 1区2区3区在线观看 三级动图 | 成年人免费在线观看网站 | 日韩欧美专区 | 99久久精品国产一区 | 中文字幕人成乱码在线观看 | 国产小视频在线观看 | av电影在线免费 | 二区三区av | 91尤物国产尤物福利在线播放 | 国产免费作爱视频 | 最新色视频 | 综合伊人av | 中文日韩在线 | av黄色影院 | 免费视频一二三区 | 蜜臀av夜夜澡人人爽人人桃色 | 色视频成人在线观看免 | 一本一本久久a久久精品牛牛影视 | 欧美a√大片 | 日韩免费在线播放 | 视频一区二区精品 | 国产不卡视频 | 97人人超碰在线 | 午夜精品一区二区三区在线视频 | 97精品国自产拍在线观看 | 99在线精品视频 | www.久久色 | 久久大片 | 久久久av免费 | 日韩在线视| 九九热在线观看 | 精品欧美一区二区在线观看 | 精产嫩模国品一二三区 | av在线播放网址 | 最近2019中文免费高清视频观看www99 | 亚洲欧美视频一区二区三区 | 天天干天天草 | 草免费视频 | av中文字幕免费在线观看 | 日韩精品一区二区三区中文字幕 | 成人中文字幕在线观看 | 国产一区视频在线 | 91免费高清视频 | 97免费视频在线 | 人交video另类hd | 超碰午夜| 在线观看片 | 日本一区二区三区视频在线播放 | 国内丰满少妇猛烈精品播放 | 国产精品1区2区 | 亚洲国产精品va在线看黑人动漫 | 探花视频免费在线观看 | 在线观看成人小视频 | 亚洲最大成人免费网站 | 黄色三级免费网址 | 国产精品麻豆91 | 久久综合久久八八 | 国内久久精品视频 | 99热精品在线 | 中文字幕在线观看第二页 | 日本天天色 | 人人射人人爽 | aaa毛片视频 | 欧美国产视频在线 | 能在线观看的日韩av | 伊人影院得得 | 观看免费av | 狠狠gao| 久久久久福利视频 | 久久国产片 | 精品久久久影院 | 久久免费视频6 | 在线一区av | 一色屋精品视频在线观看 | 91麻豆看国产在线紧急地址 | 亚洲综合婷婷 | 久久综合久久综合这里只有精品 | 51久久夜色精品国产麻豆 | 欧美日韩国产在线精品 | 中文字幕免费高清 | 日韩免费在线观看视频 | 区一区二区三在线观看 | 日韩欧美一区二区三区在线观看 | av青草| 中文字幕刺激在线 | 亚洲精品国产第一综合99久久 | 色综合久久久 | 五月色丁香 | 亚洲精品视频网 | 91桃色国产在线播放 | 久草在线视频资源 | 一区二区三区精品久久久 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 又黄又刺激视频 | 日夜夜精品视频 | 久久久www成人免费毛片麻豆 | 17婷婷久久www | 在线观看成人毛片 | 99精品国产99久久久久久福利 | 日韩婷婷 | 久久久久久激情 | 日韩激情综合 | 国产在线久草 | 久久免费影院 | 偷拍精偷拍精品欧洲亚洲网站 | 99在线观看免费视频精品观看 | 成人av电影免费观看 | 精品视频一区在线观看 | 精品国产免费观看 | 国产精品久久久久久久久久久久午夜 | 国产精品免费在线观看视频 | 综合久久精品 | av在线a| 日日夜夜天天射 | 国产精品久久久久久久久久直播 | 欧美在线观看小视频 | 丁香六月国产 | 亚洲视频在线免费看 | 久久久精品免费观看 | 国内精品99 | 日日干综合 | 狠狠88综合久久久久综合网 | 国产黄免费看 | 久久综合狠狠狠色97 | 亚洲国产成人av网 | 久久精品99久久久久久2456 | 精品久久网站 | 2021国产精品视频 | 麻豆成人小视频 | 欧美在线a视频 | 九精品| 欧美性超爽| 国产伦精品一区二区三区… | 国产精品久久久久永久免费看 | 日韩免费精品 | 欧美视频日韩 | 日本 在线 视频 中文 有码 | 日韩高清av| 亚洲黄色激情小说 | 99久久这里有精品 | 超碰在线公开免费 | 五月天色丁香 | 久草在线视频免赞 | 日韩在线观看高清 | 一级α片免费看 | 一区二区三区四区精品视频 | www黄色 | 久久精品久久精品久久精品 | 欧美日韩视频观看 | 日韩精品不卡在线 | 成人wwwxxx视频 | 国产69精品久久99不卡的观看体验 | 久久久久国产一区二区 | 久久久影视 | 免费不卡中文字幕视频 | 国产区精品 | 精品久久99 | 一区二区三区视频 | 一区二区三区精品在线 | 中文国产在线观看 | 女人18毛片90分钟 | 久久精品婷婷 | 一区二区三区高清在线观看 | 一区二区三区在线视频观看58 | 国产精品欧美 | 精品国产一区二区三区男人吃奶 | 中文字幕国语官网在线视频 | 国产91精品久久久久 | 久久久精品成人 | 国产精品嫩草在线 | 日韩在线播放欧美字幕 | 成人在线免费小视频 | 精品国产99国产精品 | 国产五月色婷婷六月丁香视频 | 国产 日韩 欧美 在线 | 成人av免费播放 | 99欧美精品 | 亚洲黄色片一级 | 91精品国产自产在线观看 | 福利电影一区二区 | 成人久久综合 | 日韩欧美网站 | 欧洲av不卡| 色综合天天综合网国产成人网 | 免费aa大片| 九九一级片 | 国产午夜精品一区二区三区嫩草 | 日韩影视精品 | 国产爽视频 | 久草精品国产 | 看片网站黄色 | 91看片一区二区三区 | 久久色网站| 亚洲精品福利在线观看 | 婷婷伊人五月 | 美女网站在线播放 | 亚洲免费精品视频 | 欧美精品乱码99久久影院 | 精品国自产在线观看 | 99视频久久 | 91香蕉嫩草 | 亚洲最大免费成人网 | 波多野结衣电影一区二区三区 | 超碰在线1 | 中文av在线免费观看 | 亚洲国产丝袜在线观看 | 国产老妇av | 色婷婷 亚洲 | 在线观看av黄色 | 亚洲精品女人 | 欧美精品做受xxx性少妇 | 国产精品国产三级在线专区 | 91网站观看| 综合网伊人 | 日本在线成人 | 日韩色综合网 | 国产成人精品久久二区二区 | 欧美一区二区三区激情视频 | 国产成人精品久久久久 | 午夜视频色 | 黄免费在线观看 | 人人干干人人 | 日韩av手机在线看 | 色综合久| 一区二区三区中文字幕在线观看 | 一区二区免费不卡在线 | 国产成人61精品免费看片 | 天天干天天操天天爱 | 特级毛片网站 | 国产免费久久精品 | 91成版人在线观看入口 | 欧美一级日韩免费不卡 | 亚洲日本成人网 | 成人综合婷婷国产精品久久免费 | 婷婷久久国产 | 四虎成人精品永久免费av | 99九九视频 | 麻豆91精品91久久久 | 黄色大全免费观看 | 女人18片| 一区二区精品久久 | 久久视频网 | 成人av高清在线观看 | 999久久久久久 | 一区二区三区国产欧美 | 黄色日本免费 | 国产午夜精品一区二区三区欧美 | 91在线观 | 天天综合亚洲 | 人人澡超碰碰97碰碰碰软件 | 在线免费观看欧美日韩 | 日韩精品免费在线观看 | 免费一级日韩欧美性大片 | 久久91久久久久麻豆精品 | 亚洲精品国产精品国 | 91在线色| 男女激情网址 | 成人91av| 91精彩视频在线观看 | 91免费网址 | 九九九九九国产 | 亚洲国产精品影院 | 99这里只有 | 17videosex性欧美| 国产人免费人成免费视频 | 国产精品久久久久免费观看 | 国产高清在线观看av | 日本久久久亚洲精品 | 91探花在线视频 | 免费视频网 | 97人人澡人人添人人爽超碰 | 综合久久久 | 欧美日韩一区二区三区视频 | 99热九九这里只有精品10 | 亚洲毛片视频 | 久久这里只有精品久久 | 国产精品日韩高清 | 激情五月婷婷综合 | 粉嫩高清一区二区三区 | 欧美另类美少妇69xxxx | 久久久午夜视频 | 51久久夜色精品国产麻豆 | 午夜 久久 tv | 樱空桃av | 国产免费观看高清完整版 | 99精品欧美一区二区三区黑人哦 | 97在线视频免费播放 | 狠狠干中文字幕 | 97人人射 | 在线视频1卡二卡三卡 | 91禁看片| 97品白浆高清久久久久久 | 天天操天天摸天天射 | 黄色小说在线免费观看 | 日韩网站视频 | 国产九九九视频 | 久草影视在线 | 亚洲激情视频在线观看 | 欧美色伊人 | 国产对白av| 精品在线免费视频 | 日日射天天射 | 女人魂免费观看 | 男女靠逼app | 人人澡人人干 | 人人看人人做人人澡 | 午夜精品影院 | 亚洲人成人99网站 | 色94色欧美 | 99免费在线| 天天爽人人爽夜夜爽 | 久久精品草| 欧美日韩国产网站 | 午夜视频一区二区三区 | 国产精美视频 | 日韩av在线小说 | 久草网视频在线观看 | 精品久久久久久久久久久久久久久久久久 | 麻豆精品在线 | 亚洲三级影院 | 国产精品免费视频网站 | 狠狠久久伊人 | 在线观看色网 | 久草在线视频免赞 | 午夜av免费在线观看 | 亚洲精品视频在线免费 | 97精品国自产拍在线观看 | 波多野结衣在线观看一区二区三区 | 最新免费中文字幕 | av一区二区在线观看中文字幕 | h动漫中文字幕 | 国产区在线 | 国产精品久久久久久久久久久久午夜片 | 久久久久日本精品一区二区三区 | 九九九热精品免费视频观看 | 国产性xxxx|