传承裴老师与孟老师《windows黑客技术解密与攻防 I--C语言篇》的教诲,写下自己的第一段黑客编程代码,以此祭奠昔日的梦想,并作为对自己的鼓励。
简易端口扫描器:
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
/*
新手练手:
简易端口扫描器
*/
#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>\n"
);
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\n"
,i);
if
(connect(sockfd,(
struct
sockaddr *)&their_addr,
sizeof
(
struct
sockaddr))==SOCKET_ERROR)
{
//如果端口扫描失败,则进行下一个端口的扫描
continue
;
}
//否则认为此端口开放
printf
(
"-------------端口 %d 开放!-------------\n\n"
,i);
}
closesocket(sockfd);
WSACleanup();
return
0;
}
/*
扫描速度每秒才两个,过慢,不符合实际,可使用多线程技术改装。
*/
/*
调试提示:开始-->运行-->输入"cmd"-->找到生成的xxx.exe程序所在路径-->输入:xxx argv[1] 就可以了
*/
|
<编译环境:VC++ 6.0>
PS:
看到这段代码,内心兴奋的同时,不觉间又黯然神伤。
总觉的自己学的很多了,却是还要差的远。多线程技术啊,一定得掌握,不然这速度,也太慢了。留作纪念。
本文转自 006玩命 51CTO博客,原文链接:http://blog.51cto.com/weiyuqingcheng/1377194,如需转载请自行联系原作者