黑客编程破处之旅:简易端口扫描器

  传承裴老师与孟老师《windows黑客技术解密与攻防 I–C语言篇》的教诲,写下自己的第一段黑客编程代码,以此祭奠昔日的梦想,并作为对自己的鼓励。

  简易端口扫描器:

  代码如下:

  /*

  新手练手:

  简易端口扫描器

  */

  #include <stdio.h>

  #include <winsock2.h>

  #pragma comment(lib,"ws2_32")

  #define START 20

  #define END 500

  int main(int argc,char *argv[])

  {

  if(argc!=2)

  {

  printf("Usage:scanport<IP>
");

  return -1;

  }

  int i;

  WSADATA ws;      //用于接受winsock结构

  SOCKET sockfd;

  struct sockaddr_in their_addr;

  WSAStartup(MAKEWORD(2,2),&ws);

  their_addr.sin_family = AF_INET;

  their_addr.sin_addr.S_un.S_addr = inet_addr(argv[1]);

  //根据命令行参数确定扫描IP

  for(i = START;i<=END;i++)

  {

  //循环建立socket后连接

  sockfd = socket(AF_INET,SOCK_STREAM,0);

  their_addr.sin_port = htons(i);

  printf("正在扫描的端口:%d
",i);

  if(connect(sockfd,(struct sockaddr *)&their_addr,sizeof(struct sockaddr))==SOCKET_ERROR)

  {

  //如果端口扫描失败,则进行下一个端口的扫描

  continue;

  }

  //否则认为此端口开放

  printf("————-端口 %d 开放!————-

",i);

  }

  closesocket(sockfd);

  WSACleanup();

  return 0;

  }

  /*

  扫描速度每秒才两个,过慢,不符合实际,可使用多线程技术改装。

  */

  /*

  调试提示:开始–>运行–>输入"cmd"–>找到生成的xxx.exe程序所在路径–>输入:xxx argv[1]  就可以了

  */

  <编译环境:VC++ 6.0>

 

发表评论

邮箱地址不会被公开。 必填项已用*标注