TCP掃描器的簡單實現

  1. //TcpPortScanner.cc  
  2. #include <iostream>  
  3. #include <strings.h>  
  4. #include <stdlib.h>  
  5. #include <sys/socket.h>  
  6. #include <netinet/in.h>  
  7. #include <arpa/inet.h>  
  8. using namespace std;  
  9.   
  10. int main(int argc, char *argv[])  
  11. {  
  12.     int fromport = atoi(argv[2]);  
  13.     int toport = atoi(argv[3]);  
  14.     if(fromport > toport)  
  15.     {  
  16.     int temp;  
  17.     temp = fromport;  
  18.     fromport = toport;  
  19.     toport = temp;  
  20.     }  
  21.   
  22.     for(int i = fromport; i < toport; i++)  
  23.     {  
  24.     int sk = socket(AF_INET, SOCK_STREAM, 0);  
  25.   
  26.     struct sockaddr_in server;  
  27.     bzero(&server, sizeof(server));  
  28.     server.sin_family = AF_INET;  
  29.     server.sin_port = htons(i);  
  30.     server.sin_addr.s_addr = inet_addr(argv[1]);  
  31.   
  32.     if(connect(sk, (struct sockaddr*)&server, sizeof(server)) == 0)  
  33.     {  
  34.         cout << argv[1] << "開放了端口:" << i << endl;  
  35.     }  
  36.   
  37.     close(sk);  
  38.     }  
  39.   
  40.     return 0;  
  41. }  


套接字socket(即sk)要在for循環裏面創建,如果在for循環外面創建則第一次connect函數成功之後,sk並沒有關閉,不能用來連接其他的端口,則下次的connect連接就會失敗,所有隻會掃描出一個開了的端口。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章