用C写的单线程扫描器


      本来写着原创的,不过现在想想,不应该说是原创,其实代码都是在前人的基础上改的。
     不过我改的时候,找了好多资料,好不容易才完成的,用VC6。0编译通过了,现在把源码发出来,这个比较简单的,初学者看是最好的了,因为我也是初学者了。

#include <winsock2.h>
#include <stdio.h> //printf函数要用的头文件
#pragma comment(lib,"ws2_32.lib")

void Help(); //申明帮助函数

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

 //申明变量
 WORD wVersion = MAKEWORD(2,0); //socket的版本
 WSADATA wsaData;
 //sockaddr_in结构 
 struct sockaddr_in sin;
 int iFromPort; //开始端口
 int iToPort; //结束端口
 int iNowPort; //正在扫描的端口
 char* cHost; //要扫描的主机
 SOCKET s; //保存创建socket时的返回值
 int iOpenPort; //开放端口个数
 iOpenPort = 0;

 //如果命令行下参数不是4个(包括portscan.exe本身),提示正确的用法
 if(argc != 4)
 { 
  Help(); //给出帮助
  return -1;
 }

 //保存用户输入的要扫描的起始端口和结束端口
 //由于用户输入的是char型,所以要先转成int型 
 iFromPort = atoi(argv[2]);
 iToPort = atoi(argv[3]);
 cHost = argv[1]; 

 //对用户输入的端口进行判断
 if(iFromPort > iToPort || iFromPort < 0 || iFromPort >65535 || iToPort <0 || iToPort >65535)
 {
  printf("起始端口不能大于结束端口,且范围为:1-65535!/n");
  return 0;
 }
 
 if (WSAStartup(wVersion , &wsaData))
 {
  printf("初始化失败!");
  return -1; 
 }
 
 printf("======= 开始扫描 =======/n");
 
 //循环连结端口,以判断端口是否开放
 for(iNowPort = iFromPort; iNowPort <= iToPort; iNowPort++)
 {
  s = socket(AF_INET,SOCK_STREAM,0);
  if(s == INVALID_SOCKET)
  {
   printf("创建socket()失败!/n");
   WSACleanup();  
  }
  
  //给结构成员赋值
  sin.sin_family = AF_INET;
  sin.sin_port = htons(iNowPort);
  sin.sin_addr.S_un.S_addr = inet_addr(cHost);
  
  //建立连结
  if(connect(s,(struct sockaddr*)&sin,sizeof(sin)) == SOCKET_ERROR)
  { 
   printf("%s -> %d:未开放/n",cHost,iNowPort);   
   closesocket(s);
  }
  else
  {
   printf("%s -> %d:开放/n",cHost,iNowPort);
   iOpenPort ++;
   closesocket(s);
  }  
 }
 
 printf("======= 扫描结果 =======/n");
 printf("主机:%s 扫描到%d个端口开放",cHost,iOpenPort);
 //关闭socket
 closesocket(s);
 WSACleanup(); 
 return 0;
}

//以下为帮助函数内容
void Help()
{
 printf("/nPortScan V1.0 by:∮明天去要饭/n");
 printf("Usage:/n");
 printf("  PortScan.exe <TargetIP> <BeginPort> <EndPort>/n");
 printf("Example:/n");
 printf("  PortScan.exe 127.0.0.1 135 445/n");  
}

程序截图:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值