传承裴老师与孟老师《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>
下一篇:重新思考如何使用SIEM产品