⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 myxray.c

📁 一个Linux下抓包软件,可以实现抓包
💻 C
📖 第 1 页 / 共 2 页
字号:
//myxray.c V0.2
#include <sys/socket.h>
#include <sys/types.h>
#include <stdio.h>
#include <errno.h>
#include <sys/ioctl.h>
#include <net/if.h>
#include <signal.h>
#include <netinet/ip.h>
#include <netinet/in.h>
#include <string.h>
#include <arpa/inet.h>
#include <netinet/if_ether.h>
#include <netinet/ip_icmp.h>
#include <time.h>
#include <netinet/igmp.h>
#define __FAVOR_BSD
#include <netinet/tcp.h>
#include <netdb.h>
#include <netinet/udp.h>
#define PACKET_SIZE 4096
#define ETH_HW_ADDR_LEN 6
#define IP_ADDR_LEN 4
#define LOWCOUNTER 10
#define MAX(a,b) ((a)>(b)?(a):(b))
struct arp_packet
    {
    u_char targ_hw_addr[ETH_HW_ADDR_LEN];
    u_char src_hw_addr[ETH_HW_ADDR_LEN];
    u_short frame_type;
    u_short hw_type;
    u_short prot_type;
    u_char hw_addr_size;
    u_char prot_addr_size;
    u_short op;
    u_char sndr_hw_addr[ETH_HW_ADDR_LEN];
    u_char sndr_ip_addr[IP_ADDR_LEN];
    u_char rcpt_hw_addr[ETH_HW_ADDR_LEN];
    u_char rcpt_ip_addr[IP_ADDR_LEN];
    u_char padding[18];
    } ;
void leave();
char * hwaddr (unsigned char *,char *);
void writearpbuf(FILE *,char *,int);//写一个arpbuf到fd中
void writetcpbuf(FILE *,char *,int);
void writeudpbuf(FILE *,char *,int);
void writeigmpbuf(FILE *,char *,int);
void writeicmpbuf(FILE *,char *,int);

int fd_recv = -1 ;
time_t one,two,temptime;
char arpbufone[PACKET_SIZE];
char tcpbufone[PACKET_SIZE];
char udpbufone[PACKET_SIZE];
char igmpbufone[PACKET_SIZE];
char icmpbufone[PACKET_SIZE];
int arpcounter=0,tcpcounter=0,igmpcounter=0,icmpcounter=0,udpcounter=0;
char writebuf[PACKET_SIZE];
FILE * waringfd;
unsigned int total=0,totalarp=0,disarp=0,totaltcp=0,distcp=0,
totaludp=0,disudp=0,totalicmp=0,disicmp=0,totaligmp=0,disigmp=0;
struct ifreq ifr,ifr_old;

main(int argc, char *argv[])
{
char device[] = "eth0"; // ethernet device name
char protocol[16];
u_char buf_recv[PACKET_SIZE]; // buffer for receive
int ihl;
int ethprotol;
int ipfragoff,df,mf;
int protol;	
char buf1[20],buf2[20],buf3[20],buf4[20];
char strptr[255];
char *srcaddr,*dstaddr;
struct ethhdr *eth ;
struct arp_packet *arphead;
struct udphdr *udp;
struct icmp *icmphdr;
struct iphdr * ip;
struct tcphdr * tcp1;
char *flagsmes;
int flags;
struct igmp * igmp1;
struct in_addr in1;
struct in_addr in2;
int from_len, datalen;
struct sockaddr from;
int arpenable=0;
int tcpenable=0;
int icmpenable=0;
int igmpenable=0;
int loenable=0;
int udpenable=0;
char *tcpflag=NULL;
int c;
char *dstip=NULL;
char *srcip=NULL;
extern char *optarg;
extern int optind;
const char
message[]=
"-a
display arp packet
-t 
display tcp packet
-f   one of RST FIN SYN PUSH ACK URG 
display only tcpflag tcp packet
-u 
display udp packet
-i 
display icmp packet
-g 
display igmp packet
-A 
display all packet
-l 
also display lo layer packet
-s srcip 
display srcip packet
-d dstip 
display dstip packet
Welcome to use myxray which writed by sztcww Good Luck";

if (argc==1) {
printf("%s\n",message);
exit(-1);
}

while ((c = getopt(argc, argv, "Aatugil?s:d:f:")) != EOF)
        switch (c) {
    case 'A':
  tcpenable=1;
  udpenable=1;
  icmpenable=1;
  igmpenable=1;
  arpenable=1;
  break;
case 'd':
  dstip=optarg;
break;
    case 's':
srcip=optarg;
break;
    case 'f':
tcpflag=optarg;
break;
case 'a':
         arpenable=1;
         break;
    case 't':
         tcpenable=1;
         break;
    case 'i':
         icmpenable=1;
         break;
    case 'g':
igmpenable=1;
        break;
    case 'u':
         udpenable=1;
         break;
    case 'l':
loenable=1;
break;
    case '?':
         printf("%s\n",message);
         exit(-1);
        }

if ( (waringfd=fopen("myxray.waring","a+"))==NULL) 
{
perror("fopen");
exit(-1);
} 
fd_recv = socket(AF_INET, SOCK_PACKET, htons(0x0003));
if (fd_recv < 0) { perror( "packet socket error"); exit(-1); }
strcpy(ifr.ifr_name, device);
if (ioctl(fd_recv, SIOCGIFFLAGS, &ifr) < 0 ) 
{
  perror("ioctl SIOCGIFFLAGS error");
  if (fd_recv >= 0) close(fd_recv);
  exit(-1);
}
ifr_old = ifr;
ifr.ifr_flags |= IFF_PROMISC;
if (ioctl(fd_recv, SIOCSIFFLAGS, &ifr) < 0 ) 
{
  perror("ioctl SIOCSIFFLAGS error");
  if (fd_recv >= 0) close(fd_recv);
  exit(-1);
}

signal(SIGINT, leave);
signal(SIGTERM, leave);

one=time(NULL);
AGAIN:
bzero(&from, sizeof(from));
from_len = sizeof(from);
bzero(buf_recv, PACKET_SIZE);
datalen = recvfrom(fd_recv, (char *)buf_recv, 4096, 0,&from, &from_len);
if (datalen < 0)
{
perror("recvfrom error");
  exit(-1);
}
total++;
buf_recv[datalen] = '\0';
if (loenable==0)
if (strcmp(device, from.sa_data) != 0) goto AGAIN;
eth=(struct ethhdr *)buf_recv;
ethprotol=ntohs(eth->h_proto);
if (ethprotol==0x0806) 
{
arphead=(struct arp_packet *)buf_recv;
    memcpy(&in1,arphead->sndr_ip_addr, IP_ADDR_LEN);
    memcpy(&in2,arphead->rcpt_ip_addr, IP_ADDR_LEN);
    srcaddr=inet_ntoa(in1);
    dstaddr=(char*)inet_ntop(AF_INET,&in2,strptr,sizeof(strptr));

totalarp++;

    if ( (!memcmp(srcaddr,dstaddr,MAX(strlen(srcaddr),strlen(dstaddr))))&&
(memcmp(hwaddr(arphead->rcpt_hw_addr,buf1),"00:00:00:00:00:00",17)) ) 
 writearpbuf(waringfd,buf_recv,1);
/*纪录arp包中srcaddr,dstaddr相同的数据包*/
else
{
if ( memcmp(buf_recv,arpbufone,datalen)==0 ) arpcounter++;
else 
{
if (arpcounter>LOWCOUNTER)
/*纪录连续抓到的,arpcounter>LOWCOUNTER的arp包 */
  {
writearpbuf(waringfd,arpbufone,arpcounter+1);
}
memcpy(arpbufone,buf_recv,datalen);
arpcounter=0;
}//end else
}//end else
}
if ((ethprotol==0x0806)&&(arpenable))
{//arp
if ( ( (dstip==NULL)||(strcmp(dstaddr,dstip)==0) )&&
((srcip==NULL)||(strcmp(srcaddr,srcip)==0) ) )
    { 
temptime=time(NULL);
  printf("Recorded %sethhdr\nsrchw:%s--->dsthw:%s proto:%xH\n",
  ctime(&temptime),hwaddr(eth->h_source,buf1),hwaddr(eth->h_dest,buf2),ethprotol);
  printf("arphdr\nhwtype:%d protol:%xH hw_size:%d pro_size:%d op:%d\ns_ha:% s s_ip:%s\nd_ha:%s d_ip:%s\n",
ntohs(arphead->hw_type),ntohs(arphead->prot_type),
arphead->hw_addr_size, arphead->prot_addr_size,
ntohs(arphead->op), hwaddr(arphead->sndr_hw_addr,buf1),
srcaddr, hwaddr(arphead->rcpt_hw_addr,buf2),dstaddr);
  printf("-----------------------------------------------------------\n");
disarp++;
  }
  goto AGAIN;
}//end arp

if (ethprotol==0x0800)
{//ip
ip = (struct iphdr *)&buf_recv[14];
  ihl = (int)ip->ihl << 2;
in1.s_addr = ip->saddr;
  in2.s_addr = ip->daddr;
  srcaddr=inet_ntoa(in1);
dstaddr=(char *)inet_ntop(AF_INET,&in2,strptr,sizeof(strptr));
  //iphdr
  protol=ip->protocol;
  ipfragoff=ntohs(ip->frag_off);
  df=ipfragoff&IP_DF;
  mf=ipfragoff&IP_MF;
   if (df!=0) df=1;
  if (mf!=0) mf=1;

  protol=ip->protocol;

switch (protol) 
{
case 6 :totaltcp++;
  tcp1 = (struct tcphdr *)&buf_recv[14 + ihl];
  flags= tcp1->th_flags;
  if (flags&TH_PUSH) flagsmes="PUSH";
  if (flags&TH_ACK) flagsmes="ACK";
  if (flags&TH_URG) flagsmes="URG";
  if (flags&TH_FIN) flagsmes="FIN";
  if (flags&TH_SYN) flagsmes="SYN";
  if (flags&TH_RST) flagsmes="RST";

if ( !memcmp(buf_recv,tcpbufone,datalen))
tcpcounter++;
else 
{
if (tcpcounter>LOWCOUNTER)
{
         writetcpbuf(waringfd,tcpbufone,tcpcounter);
}
tcpcounter=0;
memcpy(tcpbufone,buf_recv,datalen);
     } 
break;
case 1 : totalicmp++;
   icmphdr=(struct icmp *)&buf_recv[14 + ihl];
            if (!memcmp(buf_recv,icmpbufone,datalen))
icmpcounter++; 
else 
{ 
if (icmpcounter>LOWCOUNTER)
             {
writeicmpbuf(waringfd,icmpbufone,icmpcounter); 
             }
icmpcounter=0;
             memcpy(icmpbufone,buf_recv,datalen);
}
break;
case 17:totaludp++;
  udp= (struct udphdr *)&buf_recv[14 + ihl];
            if ( !memcmp(buf_recv,udpbufone,datalen)) 
udpcounter++;
else 
{
   if (udpcounter>LOWCOUNTER)
               {
     writeudpbuf(waringfd,udpbufone,udpcounter);
               }
   udpcounter=0;stdout
               memcpy(udpbufone,buf_recv,datalen);
}
break;
case 2 :totaligmp++;
      igmp1=(struct igmp *)&buf_recv[14+ihl];
            if (!memcmp(inet_ntoa(igmp1->igmp_group),"0.0.0.0",7))
writeigmpbuf(waringfd,buf_recv,1);
else 
{
  if (!memcmp(buf_recv,igmpbufone,datalen)) 
igmpcounter++; 
  else 
  { 
   if (igmpcounter>LOWCOUNTER)
             {
writeigmpbuf(waringfd,igmpbufone,igmpcounter); }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -