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

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

传承裴老师与孟老师《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>\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:

   看到这段代码,内心兴奋的同时,不觉间又黯然神伤。

   总觉的自己学的很多了,却是还要差的远。多线程技术啊,一定得掌握,不然这速度,也太慢了。留作纪念。


   享受阳光,享受生活。愿与大家共同进步。


                                                            --刀刀



你可能感兴趣的:(端口扫描,黑客编程)