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

大龍的博客

常用鏈接

統計

最新評論

一個構造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>
            亚洲国内高清视频| 99re这里只有精品6| 久久成人资源| 午夜日韩视频| 久久国产精品电影| 蜜臀av性久久久久蜜臀aⅴ| 久久在线视频在线| 欧美成人亚洲成人| 欧美性淫爽ww久久久久无| 欧美图区在线视频| 国产欧美日韩中文字幕在线| 国产一区二区精品久久91| 一区视频在线| 亚洲视频精品| 久久影视三级福利片| 欧美二区在线播放| 一区二区三区欧美激情| 欧美中文字幕不卡| 欧美日本一道本| 国产亚洲欧洲| 亚洲精品自在在线观看| 午夜日韩电影| 亚洲丰满少妇videoshd| 亚洲一区一卡| 欧美高清你懂得| 国一区二区在线观看| 一区二区不卡在线视频 午夜欧美不卡'| 亚洲性视频网址| 久色婷婷小香蕉久久| 一本一道久久综合狠狠老精东影业 | 午夜精品成人在线| 欧美成人资源| 午夜精品久久久久久久久| 欧美成人午夜激情视频| 国产视频精品网| 亚洲一区二区三区777| 欧美大片在线观看| 久久精品国产96久久久香蕉| 美女在线一区二区| 亚洲欧美视频在线| 国产精品v日韩精品v欧美精品网站| 亚洲激情综合| 老司机精品视频网站| 久久综合激情| 欧美有码在线视频| 亚洲韩国日本中文字幕| 午夜精品区一区二区三| 欧美激情在线观看| 亚洲国产成人午夜在线一区| 久久国产夜色精品鲁鲁99| 制服丝袜亚洲播放| 欧美三级日本三级少妇99| 91久久精品国产91久久| 久热成人在线视频| 久久精品人人| 国产自产女人91一区在线观看| 亚洲综合电影| 亚洲一区二区不卡免费| 国产精品高潮呻吟久久av黑人| 亚洲国产精品欧美一二99| 欧美二区乱c少妇| 久久视频这里只有精品| 国产精品久久久久秋霞鲁丝 | 99国内精品久久| 欧美成人一区二区三区在线观看| 午夜亚洲影视| 国产亚洲亚洲| 久久夜色精品亚洲噜噜国产mv| 亚洲一区三区在线观看| 国产精品一级久久久| 欧美一级片在线播放| 99综合精品| 国产欧美精品日韩精品| 久久久777| 免费试看一区| 在线一区二区日韩| 亚洲综合日韩| 亚洲福利国产精品| 99热免费精品| 国模套图日韩精品一区二区| 你懂的网址国产 欧美| 欧美激情综合网| 午夜免费久久久久| 久久亚裔精品欧美| 99在线热播精品免费99热| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 亚洲午夜国产成人av电影男同| 亚洲网站在线| 一区一区视频| 一本色道88久久加勒比精品| 国产乱码精品一区二区三区不卡| 久久久精品tv| 欧美啪啪一区| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲欧美精品suv| 亚洲视频一区二区| 国产欧美精品国产国产专区| 欧美国产成人在线| 国产精品揄拍500视频| 欧美aa在线视频| 国产精品日韩专区| 亚洲国产老妈| 国产亚洲一区二区三区在线播放| 亚洲电影免费在线观看| 国产模特精品视频久久久久 | 午夜精品久久久久久久99热浪潮| 亚洲人成网站色ww在线| 亚洲在线观看免费视频| 亚洲精品国产拍免费91在线| 亚洲欧美日韩爽爽影院| 日韩视频不卡| 久久一区二区三区国产精品| 小黄鸭精品密入口导航| 欧美精品日韩精品| 美女爽到呻吟久久久久| 国产精品尤物| 在线综合欧美| 亚洲午夜电影在线观看| 奶水喷射视频一区| 免费人成网站在线观看欧美高清| 国产精品免费看久久久香蕉| 亚洲精品乱码久久久久久黑人 | 精品成人国产在线观看男人呻吟| 一片黄亚洲嫩模| 一本一本久久a久久精品综合妖精| 久久久久一区二区| 久久一区二区三区超碰国产精品| 国产精品亚洲第一区在线暖暖韩国| 亚洲人成77777在线观看网| 亚洲国产女人aaa毛片在线| 久久久久久穴| 欧美成人有码| 亚洲人成在线播放| 免费一级欧美片在线播放| 国产美女精品视频| 亚洲一区二区精品在线| 亚洲欧美视频在线观看视频| 国产精品都在这里| 亚洲一区二区三区精品动漫| 亚洲欧美在线免费观看| 国产精品天天看| 午夜欧美大片免费观看| 久久激情视频久久| 精品福利电影| 欧美成人按摩| 99riav久久精品riav| 亚洲欧美日韩一区| 国产一区二区三区免费在线观看| 久久精品国产77777蜜臀| 欧美成人精品激情在线观看| 亚洲精选久久| 国产精品免费一区二区三区在线观看 | 久久国产88| 欧美电影资源| 亚洲私人黄色宅男| 国产日韩精品视频一区二区三区| 久久一日本道色综合久久| 日韩一区二区免费高清| 亚洲影音先锋| 国产午夜精品全部视频播放| 久久精品一区二区三区不卡牛牛| 欧美国产国产综合| 亚洲视频www| 黄色成人av| 欧美日韩日韩| 久久av老司机精品网站导航| 欧美a级在线| 亚洲一区二区三区视频播放| 国产午夜精品一区二区三区视频 | 国产精品一区二区三区久久久| 午夜免费在线观看精品视频| 欧美大片一区二区三区| 亚洲一区三区视频在线观看| 国内揄拍国内精品久久 | 激情成人综合网| 欧美激情综合在线| 欧美一级在线亚洲天堂| 亚洲激情视频网站| 久久国产精品亚洲va麻豆| 亚洲老司机av| 国内精品美女在线观看| 欧美日韩在线免费| 久久夜色精品亚洲噜噜国产mv| 一区二区精品在线| 欧美激情成人在线| 欧美在线免费看| 一本久道综合久久精品| 一区二区三区我不卡| 国产精品人人做人人爽人人添| 欧美粗暴jizz性欧美20| 欧美一级理论片| 亚洲精品一品区二品区三品区| 欧美午夜激情小视频| 男女激情视频一区| 久久精品视频亚洲| 亚洲欧美日韩综合aⅴ视频| 亚洲精品一区二区三区樱花| 欧美a级片网| 久久久久国产精品一区二区| 中文国产一区|