青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

大龍的博客

常用鏈接

統計

最新評論

一個構造SYN包做掃描的例子: ------------------ 轉

//---------------------------------------------------------------------------  
  //Filename:ss.c  
  //Author:yunshu  
  //---------------------------------------------------------------------------  
  //Filename:ss.c  
  //Author:yunshu  
  //Last:2004-04-02  
  //Thank   Wineggdrop's   Code  
  //---------------------------------------------------------------------------  
  #include   <winsock2.h>  
  #include   <ws2tcpip.h>  
  #include   <MSTcpIP.h>  
  #include   <stdio.h>  
  #include   <string.h>  
   
  #pragma   comment(lib,"ws2_32")  
   
  ////////////////////////////////////////////////////////////////  
  //全局變量  
  ////////////////////////////////////////////////////////////////  
   
  #define   srcPort   8296  
   
  char   srcIP[20]   =   {0};//定義源地址  
  char   tgtIP[20]   =   {0};//定義目的地址  
  int     portNow;//定義正在掃描的端口  
   
  //標準端口列表  
  int   ports[20]   =   {21,22,23,25,53,79,80,110,111,135,139,445,554,1080,1433,1521,3306,3389,5631,8080};  
   
  typedef   struct   ip_hdr  
  {  
          unsigned   char   h_verlen;   //4位首部長度,4位IP版本號  
          unsigned   char   tos;   //8位服務類型TOS  
          unsigned   short   total_len;   //16位總長度(字節)  
          unsigned   short   ident;   //16位標識  
          unsigned   short   frag_and_flags;   //3位標志位  
          unsigned   char   ttl;   //8位生存時間   TTL  
          unsigned   char   proto;   //8位協議   (TCP,   UDP   或其他)  
          unsigned   short   checksum;   //16位IP首部校驗和  
          unsigned   int   sourceIP;   //32位源IP地址  
          unsigned   int   destIP;   //32位目的IP地址  
  }IP_HEADER;  
   
  typedef   struct   tcp_hdr   //定義TCP首部  
  {  
          USHORT   th_sport;   //16位源端口  
          USHORT   th_dport;   //16位目的端口  
          unsigned   int         th_seq;   //32位序列號  
          unsigned   int         th_ack;   //32位確認號  
          unsigned   char   th_lenres;   //4位首部長度/6位保留字  
          unsigned   char   th_flag;   //6位標志位  
          USHORT   th_win;   //16位窗口大小  
          USHORT   th_sum;   //16位校驗和  
          USHORT   th_urp;   //16位緊急數據偏移量  
  }TCP_HEADER;  
   
  typedef   struct   tsd_hdr   //定義TCP偽首部  
  {  
          unsigned   long   saddr;   //源地址  
          unsigned   long   daddr;   //目的地址  
          char   mbz;  
          char   ptcl;   //協議類型  
          unsigned   short   tcpl;   //TCP長度  
  }PSD_HEADER;  
   
  ////////////////////////////////////////////////////////////////  
  //函數原形  
  ////////////////////////////////////////////////////////////////  
   
  int                 send_packet();//發送數據函數  
  int                 recv_packet();//監聽數據函數  
  USHORT           checksum(USHORT   *,   int   );//計算檢驗和函數  
  void               usage(char   *);//顯示幫助函數  
  void               check_port(char   *);//判斷端口是否開放函數  
   
   
  ////////////////////////////////////////////////////////////////  
  //main函數  
  ////////////////////////////////////////////////////////////////  
   
  int   main(int   argc,char   *argv[])  
  {  
          WSADATA                 WSAData;  
          DWORD                     thread_ID   =   1;  
          char                       FAR   hostname[128];  
          struct   hostent   *phe;  
   
          if(argc   !=   2)//檢查命令行參數是否正確  
          {  
                  usage(argv[0]);  
                  exit(0);  
          }  
   
          if   (WSAStartup(MAKEWORD(2,2),   &WSAData))  
          {  
                  printf("WSAStartup   Error...\n");  
                  exit(0);  
          }  
   
          strcpy(tgtIP,argv[1]);//得到目標主機的ip地址  
   
          gethostname(hostname,128);//獲取本機主機名  
   
          phe   =   gethostbyname(hostname);//獲取本機ip地址結構  
   
          if(phe   ==   NULL)  
          {  
                  printf("Get   LocalIP   Error...\n");  
          }  
   
          strcpy(srcIP,   inet_ntoa(*((struct   in_addr   *)phe->h_addr_list[0])));//得到本機ip地址  
   
          //調試用,注釋掉  
          //printf("test\t%s\n",tgtIP);  
          //printf("test\t%s\n",srcIP);  
   
          //開啟新線程,接受數據包,分析返回的信息  
          CreateThread(NULL,   0,   (LPTHREAD_START_ROUTINE)recv_packet,NULL,0,&thread_ID);  
   
          Sleep(1000);//休息一下再啟動發送數據包函數  
   
          for(int   tmp   =   0;   tmp   <   20;   tmp++)  
          {  
                  ++thread_ID;  
   
                  //要掃描的端口  
                  portNow   =   ports[tmp];  
   
                  //開啟新線程,發送數據包  
                  CreateThread(NULL,   0,   (LPTHREAD_START_ROUTINE)send_packet,NULL,0,&thread_ID);  
   
                  //防止生成線程過快,休息  
                  Sleep(100);  
          }  
   
          Sleep(1000);//等待掃描接結束  
          WSACleanup();  
          return   0;  
  }   
 
//計算檢驗和函數,完全抄別人的  
  USHORT   checksum(USHORT   *buffer,   int   size)  
  {  
          unsigned   long   cksum=0;  
   
          while(size   >1)  
          {  
                  cksum   +=   *buffer++;  
                  size   -=   sizeof(USHORT);  
          }  
          if(size)  
          {  
                  cksum   +=   *(UCHAR*)buffer;  
          }  
          cksum   =   (cksum   >>   16)   +   (cksum   &   0xffff);  
          cksum   +=   (cksum   >>   16);  
          return   (USHORT)(~cksum);  
  }  
   
  void   usage(char   *prog)  
  {  
          printf("===========================================\n");  
          printf("Used   To   Scan   Remote   Host's   Ports\n");  
          printf("OurTeam:<a     target="_blank">http://www.ph4nt0m.net\n</a>");  
          printf("Usage:%s   TargetIP\n",prog);  
          printf("===========================================\n");  
          exit(0);  
  }  
   
   
  //發送數據包的函數  
  int   send_packet()  
  {  
          SOCKET                           sendSocket;  
          BOOL                               flag;  
          int                                 timeout;  
          SOCKADDR_IN                 sin;  
          IP_HEADER                     ipHeader;  
          TCP_HEADER                   tcpHeader;  
          PSD_HEADER                   psdHeader;  
          char                               szSendBuf[60];  
          int                                 ret;  
          unsigned   long             source_ip;  
          unsigned   long             target_ip;  
   
          //建立原生數據socket  
          if((sendSocket   =   WSASocket(AF_INET,   SOCK_RAW,   IPPROTO_RAW,   NULL,   0,   WSA_FLAG_OVERLAPPED))   ==   INVALID_SOCKET)  
          {  
                  printf("Socket   Setup   Error...\n");  
                  return   0;  
          }  
   
          //設置自己填充數據包  
          if(setsockopt(sendSocket,   IPPROTO_IP,   IP_HDRINCL,   (char   *)&flag,   sizeof(flag))   ==   SOCKET_ERROR)  
          {  
                  printf("Setsockopt   IP_HDRINCL   Error...\n");  
                  return   0;  
          }  
   
          //設置超時時間  
          timeout   =   1000;  
          if(setsockopt(sendSocket,   SOL_SOCKET,   SO_SNDTIMEO,   (char   *)&timeout,   sizeof(timeout))   ==   SOCKET_ERROR)  
          {  
                  printf("Setsockopt   SO_SNDTIMEO   Error...\n");  
                  return   0;  
          }  
   
          target_ip   =   inet_addr(tgtIP);  
          source_ip   =   inet_addr(srcIP);  
   
          sin.sin_family   =   AF_INET;  
          sin.sin_port   =   htons(portNow);  
          sin.sin_addr.S_un.S_addr   =   target_ip;  
   
          //填充IP首部  
          ipHeader.h_verlen   =   (4<<4   |   sizeof(ipHeader)/sizeof(unsigned   long));  
          //   ipHeader.tos=0;  
          ipHeader.total_len   =   htons(sizeof(ipHeader)+sizeof(tcpHeader));  
          ipHeader.ident   =   1;  
          ipHeader.frag_and_flags   =   0x40;  
          ipHeader.ttl   =   128;  
          ipHeader.proto   =   IPPROTO_TCP;  
          ipHeader.checksum   =   0;  
          ipHeader.sourceIP   =   source_ip;//源IP  
          ipHeader.destIP   =   target_ip;//目的IP  
   
          //填充TCP首部  
          tcpHeader.th_dport   =   htons(portNow);//目的端口  
          tcpHeader.th_sport   =   htons(srcPort);   //源端口  
          tcpHeader.th_seq   =   0x12345678;  
          tcpHeader.th_ack   =   0;  
          tcpHeader.th_lenres   =   (sizeof(tcpHeader)/4<<4|0);  
          tcpHeader.th_flag   =   2;//syn標志位。0,2,4,8,16,32->FIN,SYN,RST,PSH,ACK,URG(推測,哈哈)  
          tcpHeader.th_win   =   htons(512);  
          tcpHeader.th_urp   =   0;  
          tcpHeader.th_sum   =   0;  
   
          //填充tcp偽首部  
          psdHeader.saddr   =   ipHeader.sourceIP;  
          psdHeader.daddr   =   ipHeader.destIP;  
          psdHeader.mbz   =   0;  
          psdHeader.ptcl   =   IPPROTO_TCP;  
          psdHeader.tcpl   =   htons(sizeof(tcpHeader));  
   
          //計算TCP校驗和  
          memcpy(szSendBuf,   &psdHeader,   sizeof(psdHeader));  
          memcpy(szSendBuf   +   sizeof(psdHeader),   &tcpHeader,   sizeof(tcpHeader));  
   
          tcpHeader.th_sum   =   checksum((USHORT   *)szSendBuf,   sizeof(psdHeader)   +   sizeof(tcpHeader));  
   
          //計算IP檢驗和  
          memcpy(szSendBuf,   &ipHeader,   sizeof(ipHeader));  
          memcpy(szSendBuf   +   sizeof(ipHeader),   &tcpHeader,   sizeof(tcpHeader));  
          memset(szSendBuf   +   sizeof(ipHeader)   +   sizeof(tcpHeader),   0,   4);  
          ipHeader.checksum   =   checksum((USHORT   *)szSendBuf,   sizeof(ipHeader)   +   sizeof(tcpHeader));  
   
          memcpy(szSendBuf,   &ipHeader,   sizeof(ipHeader));  
          memcpy(szSendBuf   +   sizeof(ipHeader),   &tcpHeader,   sizeof(tcpHeader));  
   
          //發送數據包  
          ret   =   sendto(sendSocket,   szSendBuf,   sizeof(ipHeader)   +   sizeof(tcpHeader),   0,   (struct   sockaddr*)&sin,   sizeof(sin));  
   
          if(ret   ==   SOCKET_ERROR)  
          {  
                  printf("Send   Packet   Error...\n");  
                  return   0;  
          }  
          else   return   1;  
  }  
   
  int   recv_packet()  
  {  
          SOCKADDR_IN                 sniff;  
          SOCKET                         sock;  
          char                         recvBuffer[65000]   =   {0};//緩沖區存放捕獲的數據  
   
          //建立socket監聽數據包  
          sock   =   socket(AF_INET,SOCK_RAW,IPPROTO_IP);  
   
          sniff.sin_family   =   AF_INET;  
          sniff.sin_port   =   htons(0);  
          sniff.sin_addr.s_addr   =   inet_addr(srcIP);  
   
          //綁定到本地隨機端口  
          bind(sock,(PSOCKADDR)&sniff,sizeof(sniff));  
   
          //設置SOCK_RAW為SIO_RCVALL,以便接收所有的IP包  
          //copy來的  
          DWORD   dwBufferLen[10]   ;  
          DWORD   dwBufferInLen   =   1   ;  
          DWORD   dwBytesReturned   =   0   ;  
          WSAIoctl(sock,SIO_RCVALL,&dwBufferInLen,sizeof(dwBufferInLen),&dwBufferLen,sizeof(dwBufferLen),&dwBytesReturned,NULL,NULL);  
   
          while(TRUE)  
          {  
                  memset(recvBuffer,0,sizeof(recvBuffer));  
   
                  //開始捕獲數據包  
                  int   bytesRecived   =   recv(sock,recvBuffer,sizeof(recvBuffer),0);  
                  if(bytesRecived   <=   0)  
                  {  
                          break;  
                  }  
                  check_port(recvBuffer);  
          }  
          return   1;  
  }  
   
  void   check_port(char   *buffer)  
  {  
          IP_HEADER                 *ipHeader;//IP_HEADER型指針  
          TCP_HEADER                 *tcpHeader;//TCP_HEADER型指針  
   
          ipHeader   =   (IP_HEADER   *)buffer;  
          tcpHeader   =   (TCP_HEADER   *)   (buffer+sizeof(IP_HEADER));  
   
          if(ipHeader->sourceIP   !=   inet_addr(tgtIP))  
          {  
                  return;  
          }  
   
          for(int   tmp=0;tmp<20;tmp++)  
          {  
                  //SYN+ACK   ->   2+16=18(也是推測,哈哈)  
                  if(tcpHeader->th_flag   ==   18   &&   tcpHeader->th_sport   ==   htons(ports[tmp]))  
                  {  
                          printf("[Found]\t%s\tport\t%d\tOpen\n",tgtIP,ports[tmp]);  
                  }  
          }  
  }

posted on 2009-03-17 20:20 大龍 閱讀(955) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            美国十次了思思久久精品导航| 久久国产精品99国产精| 猛干欧美女孩| 蜜臀a∨国产成人精品| 亚洲第一福利视频| 亚洲第一搞黄网站| 欧美第十八页| 午夜精品短视频| 久久精品日产第一区二区三区| 亚洲高清免费在线| 亚洲日本激情| 国产欧美高清| 亚洲电影av在线| 欧美三级午夜理伦三级中文幕 | 亚洲高清免费视频| 亚洲免费观看在线观看| 国产亚洲精品美女| 亚洲国产小视频| 国产欧美日韩另类一区| 欧美成人精精品一区二区频| 欧美日韩美女在线| 久久亚洲不卡| 欧美性视频网站| 欧美a级一区| 国产伦精品一区二区三区在线观看 | 亚洲国产精品一区| 亚洲视频精选| 亚洲激情在线观看视频免费| 一区二区免费看| 亚洲黄色一区二区三区| 香港久久久电影| 中国成人亚色综合网站| 久久乐国产精品| 欧美一区二区三区四区在线| 欧美精品一区二区在线播放| 久久夜色精品国产亚洲aⅴ| 欧美日韩综合在线| 亚洲高清视频在线| 在线观看欧美日韩| 欧美夜福利tv在线| 午夜久久99| 欧美日韩国产高清| 亚洲韩国日本中文字幕| 一区二区在线看| 欧美亚洲免费| 亚洲欧洲av一区二区| 欧美日韩第一页| 亚洲高清久久网| 在线观看精品视频| 久久激五月天综合精品| 午夜久久久久久| 欧美午夜宅男影院| 亚洲最新视频在线| 亚洲一区二区视频在线观看| 国产一区二区精品| 欧美亚洲综合久久| 欧美综合二区| 国产欧美日韩一区二区三区| 亚洲一区精品视频| 亚洲欧美日韩中文播放| 国产精品久久久久久久久久久久久 | 亚洲一区二区黄色| 亚洲一区二区在| 国产精品xnxxcom| 亚洲视屏在线播放| 欧美亚洲视频在线看网址| 国产精品黄色在线观看| 在线性视频日韩欧美| 亚洲综合国产| 国产亚洲激情| 久久久欧美一区二区| 男女av一区三区二区色多| 在线观看日韩欧美| 另类人畜视频在线| 亚洲黄一区二区| 亚洲新中文字幕| 国产欧美韩日| 久久免费少妇高潮久久精品99| 奶水喷射视频一区| 一区二区三区高清不卡| 国产精品日韩欧美| 久久精品免视看| 亚洲国产午夜| 西西裸体人体做爰大胆久久久| 国产精品视频网| 久久久99爱| 亚洲人成人99网站| 久久国产一区| 91久久久一线二线三线品牌| 欧美日韩美女| 久久久精品国产一区二区三区| 欧美二区在线播放| 午夜亚洲福利在线老司机| 国产在线不卡视频| 欧美日韩精品中文字幕| 欧美在线免费视频| 亚洲激情精品| 久久大综合网| 亚洲作爱视频| 狠狠色丁香婷婷综合久久片| 欧美激情一二三区| 欧美一区二区精美| 亚洲国产精品久久久久秋霞蜜臀 | 久久精品1区| 99视频在线观看一区三区| 国产欧美精品日韩| 欧美激情在线免费观看| 欧美亚洲一区| 一本到12不卡视频在线dvd| 免费日本视频一区| 亚洲欧美一区二区原创| 亚洲欧洲日产国产综合网| 国产伦精品一区| 欧美日韩国内| 欧美二区在线观看| 久久精品日韩欧美| 亚洲免费影视| 亚洲国产另类久久久精品极度| 欧美黑人多人双交| 久久国产精品高清| 亚洲欧美另类综合偷拍| 亚洲国产一区二区三区高清| 久久视频这里只有精品| 欧美一区二区三区精品电影| 中日韩高清电影网| 99精品视频免费观看| 亚洲欧洲在线播放| 黄色国产精品| 国内精品久久久久久| 国产欧美日韩精品丝袜高跟鞋| 欧美视频在线播放| 欧美日韩一区二区三区在线看 | 国产精品永久免费在线| 欧美日韩精品免费观看| 欧美激情综合五月色丁香| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美与欧洲交xxxx免费观看 | 久久高清福利视频| 久久成人18免费观看| 欧美一级片久久久久久久| 午夜精品福利在线观看| 午夜亚洲激情| 午夜精品影院| 久久国产欧美日韩精品| 久久久综合网站| 麻豆免费精品视频| 欧美韩日视频| 欧美日韩综合视频| 国产精品国产三级国产普通话99 | 欧美sm极限捆绑bd| 欧美激情女人20p| 亚洲黄色影院| 一区二区三区 在线观看视| 在线视频欧美日韩精品| 亚洲欧美国产精品专区久久| 欧美在线观看一区二区| 久久久一区二区| 欧美精品亚洲精品| 国产精品美女在线| 一区二区在线看| 99re6这里只有精品视频在线观看| 一区二区三区四区五区精品| 午夜欧美精品久久久久久久| 久久久精品2019中文字幕神马| 免费久久99精品国产自| 亚洲精品一区二区三| 亚洲直播在线一区| 久久性天堂网| 欧美日韩一区三区| 一区三区视频| 亚洲四色影视在线观看| 久久成人精品电影| 亚洲国产精品久久久| 亚洲已满18点击进入久久| 久久精品视频免费| 欧美日韩欧美一区二区| 国外成人网址| 亚洲视频免费| 麻豆精品网站| 亚洲性夜色噜噜噜7777| 久久久久九九视频| 国产精品久久久久一区二区三区共 | 午夜精品福利在线| 另类欧美日韩国产在线| 久久久另类综合| 亚洲欧洲精品成人久久奇米网| 午夜精品久久久久久99热软件 | 亚洲在线观看视频网站| 欧美成人免费小视频| 国产亚洲欧美一区在线观看| 一区二区三区视频在线| 欧美1区3d| 欧美在线播放一区二区| 欧美视频免费在线观看| 亚洲国产一区二区a毛片| 久久久99免费视频| 亚洲摸下面视频| 国产精品白丝av嫩草影院| 亚洲精品日韩在线观看| 欧美成人精精品一区二区频|