`
宋科明
  • 浏览: 101592 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

portscan程序代码

阅读更多

#include <afxext.h>
#include <winsock.h>
// 编译时需使用的库
#pragma comment(lib,"wsock32.lib")
// select()成员定义
#define ZERO (fd_set *)0
// 变量定义
int maxth, scanok, scannum;
int portip, hoststart, hoststop, startport, endport; //定义了开始I和结束P地址,开始和结束端口
long searchnum, searched;
void usage(char *);   // 定义显示使用方法函数
void playx(int);   // 定义状态提示函数
void setip2(char *);   // 定义设置IP函数
void customport(char *, char *, char *); // 定义自定义扫描端口函数
void portscannow(int);   // 定义端口扫描扫描

// 主程序
int main(int argc, char *argv[])
{
WSADATA wsadata;
// 清屏
system("cls.exe");
// 显示版本信息
printf("\r\n==================== HUC Command Line PortScanner V0.2 ====================");
printf("\r\n=============== By Lion, Welcome to http://www.cnhonker.net ===============\r\n\n");

// 检查输入
if ((argc < 3) || (argc > 4))
{
// 显示帮助提示
usage(argv[0]);
return -1;
}

// 检测是否为port扫描
if(!(stricmp(strlwr(argv[1]), "-p") == 0))
{
usage(argv[0]);
return -1;
}

// 程序初始化
if (WSAStartup(MAKEWORD(1,1), &wsadata) != 0) //如果初始化错误
{
printf("\r\nWsatartup error");       //出错信息
return -1;
}

// 端口扫描参数转换
// 如果参数为三个
if (argc == 3)
{
// 直接设置IP
setip2(argv[2]);
}
// 如果参数为四个
else
if (argc == 4)
{
// 进入定制端口扫描处理
customport(argv[0], argv[2], argv[3]);
}
// 参数过多显示帮助
else
{
usage(argv[0]);
return -1;
}

// 扫描端口开始
portscannow(argc);

WSACleanup();
return 0;
}

// 帮助提示函数
void usage(char * prog)
{
printf("Usage: %s <Option>", prog);
printf("\r\n\n <Option>:");
printf("\r\n -p [ Port|StartPort-EndPort ] < HostName|IP|StartIP-EndIP >");
printf("\r\n\n Example: ");
printf("\r\n %s -p 192.168.0.1", prog);
printf("\r\n %s -p 192.168.0.1-192.168.0.254", prog);
printf("\r\n %s -p 21-80 192.168.0.1", prog);
printf("\r\n %s -p 21-80 192.168.0.1-192.168.0.254\r\n", prog);
return;
}

// 进度提示
void playx(int play = 0)
{
// 进度条
char *plays[12]=
{
" | ",
" / ",
" - ",
" \\ ",
" | ",
" / ",
" - ",
" \\ ",
" | ",
" / ",
" - ",
" \\ ",
};

if (searchnum != 0)
{
for (int i = 0 ; i <= 3; i ++)
{
printf(" =%s= %d%s Completed. \r", plays , searched * 100 / (searchnum + 1), "%");
Sleep(5);
}
}
else
{
printf(" =%s=\r", plays[play]); //显示进度
Sleep(10);
}
}

// 设置IP
void setip2(char *cp)
{
int host;
struct hostent *testhost;
char *startip = "", *endip = "";

// 判断是否为 192.168.0.1-192.168.0.254 形式的输入
if (strstr(cp, "-") && strlen(cp) > 15 && strlen(cp) < 32)
{
// 提取出结束IP
endip = strchr(cp, '-') + 1;
// 提取出开始IP
strncpy(startip, cp, strlen(cp) - strlen(strchr(cp, '-')));

// 给控制要扫描IP段的变量赋值
hoststart = ntohl(inet_addr(startip));
hoststop = ntohl(inet_addr(endip));
}
else
{
// 取得输入的主机地址
testhost = gethostbyname(startip);
  
// 如果地址不存在
if(!testhost)
{
WSACleanup( );
printf("\r\nCan't get ip of: %s", cp);
exit(-1);
}
// 给控制要扫描IP段的变量赋值
memcpy(&host, testhost->h_addr, 4);
hoststop = hoststart = ntohl(host);
}
}

// 测试线程是否已满
void TestThread(int thread = 200)
{
for (;;)
{
playx();

// 测试线程是否已满
if (maxth > thread)
Sleep(100);
else break;
}
return;
}

// 等待线程结束函数
void WaitThreadEnd()
{
// 延时
Sleep(6000);

// 显示等待提示
printf("\r   \r\n");
printf(" Wait ( %d )Thread end...\r\n", maxth);

for(;;)
{
// 判断所有线程是否已经结束
if (maxth > 0)
{
// 延时等待线程序结束
Sleep(100);
playx();
continue;
}
else break;
}
printf("\r\n");
return;
}

// 定制端口扫描参数定义
void customport(char *cp, char *cp2, char *cp3)
{
int intport;
char *checker;

// 处理要扫描的端口
// 扫描开始端口变量赋值
startport = atoi(cp2);
// 扫描结束端口变量赋值
endport = atoi(cp2);
  
// 判断是否 21-80 形式
if (strstr(cp2,"-"))
{
intport = atoi(checker = strchr(cp2, '-') + 1);
if (intport > 0 && intport < 65536)
// 扫描结束端口变量赋值
endport = intport;
}

// 端口大小判断
if (startport < 0 || startport > 65536 || endport < 0 || endport > 65535)
{
usage(cp);
exit(-1);
}
// 处理ip地址
setip2(cp3);
}

// 端口扫描函数
UINT portscan(LPVOID port)
{
int addr = portip; // 取得要扫描的地址
int sock;
struct fd_set mask;
struct timeval timeout;
struct sockaddr_in server;
unsigned long flag = 1;

// 创建一个sock
sock = socket(AF_INET, SOCK_STREAM, 0);

// 创建sock失败处理
if (sock == INVALID_SOCKET)
{
printf("\r\nSock Error:%s", WSAGetLastError());
maxth --;
return -1;
}

// 给sock成员赋值
server.sin_family=AF_INET;
server.sin_addr.s_addr = htonl(addr); // 要扫描的地址
server.sin_port = htons(short(port)); // 要扫描的端口

// 显示进度
playx();

// 调用ioctlsocket()设置套接字为非阻塞模式
if (ioctlsocket(sock, FIONBIO, &flag) != 0)
{
// 设置失败处理
printf("\r\nSock Error:%s", WSAGetLastError());
closesocket(sock);
maxth --;
return -1;
}

// 调用connect()连接远程主机端口
connect(sock, (struct sockaddr*)&server, sizeof(server));

timeout.tv_sec = 18; // 超时限制为18秒
timeout.tv_usec = 0;
FD_ZERO(&mask); // 清空集合mask
FD_SET(sock, &mask); // 将sock放入集合mask中

// 用select() 处理扫描结果
switch(select(sock + 1, ZERO, &mask, ZERO, &timeout))
{
case -1:
{
printf("\r\nSelect() error");
maxth --;
return -1;
}

// sock超时处理
case 0:
{
maxth --;
closesocket(sock);   
return -1;
}

default:
if(FD_ISSET(sock, &mask))
{   
// 禁止sock发送和接受数据
shutdown(sock, 0);

// 设置输出结果格式
printf(" [Found:] %s Port: %d open.\r\n", inet_ntoa(server.sin_addr), ntohs(server.sin_port));   

// 关闭sock
closesocket(sock);   
scanok ++;
maxth --;   
return 1;
}
}
return 0;
}

// 扫描开始主函数
void portscannow(int xp)
{
int sport;
char *timenow, timebuf[32];

// 定义默认扫描的端口
char *ports[32]={
"21",
"22",
"23",
"25",
"53",
"79",
"80",
"110",
"111",
"113",
"123",
"135",
"139",
"143",
"443",
"512",
"513",
"514",
"515",
"540",
"1080",
"1433",
"1521",
"1524",
"3306",
"3389",
"5631",
"6000",
"6112",
"8000",
"8080",
"12345"   //这里你也可以自己定义要扫描的端口
};

// 显示扫描开始的时间
timenow = _strtime(timebuf);
printf("\r\nPortScan Start Time: %s\r\n\n",timenow);

// 计数器初始化.
maxth = 0;
scanok = 0;
scannum = 0;
searched = 0;

// 计算要扫描的端口数量
searchnum = hoststop - hoststart +1;
if(xp == 3)
searchnum = searchnum * 32;
if(xp == 4)
searchnum = searchnum * (endport - startport +1);

// 端口扫描开始
for (portip = hoststart; portip <= hoststop; portip ++, scannum ++)
{
// *.*.*.0和*.*.*.255 地址处理
if ((portip % 256) == 0 || (portip % 256) == 255)
{   
if(xp == 3)
searchnum = searchnum - 32;
if(xp == 4)
searchnum = searchnum - (endport - startport +1);
scannum --;
playx();
continue;
}
  
if(i > 11) i = 0;
// 默认端口扫描
// scan 192.168.0.1
// scan 192.168.0.1-192.168.0.254
if (xp == 3)
{
for (sport = 0; sport < 32; sport ++, maxth ++, searched ++)
{   
// 测试当前线程是否大于180
TestThread(180);   
// 产生新的线程处理端口扫描
CWinThread * pthread = AfxBeginThread(portscan,LPVOID(atoi((char*)ports[sport])));
//延时
Sleep(120);   
}   
}
  
// 自定义端口扫描
// scan -p 21 192.168.0.1
// scan -p 21-80 192.168.0.1-192.168.0.254
if (xp == 4)
{ // 计算要扫描的端口
sport = endport - startport;
if(sport > 500 )
{
// 扫描自定义的端口
for(sport = startport; sport <= endport; sport ++, maxth ++, searched ++)
{
  TestThread(2000);
  // 产生新的线程处理端口扫描
  CWinThread * pthread = AfxBeginThread(portscan, LPVOID(sport));
  // 延时
  Sleep(10);
}
}
else
{
// 扫描自定义的端口
for(sport = startport; sport <= endport; sport ++, maxth ++, searched ++)
{
  // 测试当前线程是否大于250
  TestThread(250);
  // 产生新的线程处理端口扫描
  CWinThread * pthread = AfxBeginThread(portscan, LPVOID(sport));
  // 延时
  Sleep(100);   
  playx();
}
}
}
}

// 等待所有的线程结束
WaitThreadEnd();

// 显示端口扫描结束时间
timenow = _strtime(timebuf);
printf("\r\nPortScan End Time: %s", timenow);
printf("\r\nScan %d Hosts completed. Open %d Ports!\r\n", scannum, scanok);
}

分享到:
评论

相关推荐

    PortScan

    在学习和理解PortScan程序时,应关注以下几个核心知识点: 1. **端口扫描原理**:端口扫描通常分为TCP扫描(SYN、ACK、FIN、Connect等方法)和UDP扫描。通过向目标发送特定的网络数据包并分析响应来判断端口状态。 ...

    PortScan 源码 C

    11. **性能优化**:优化代码以减少扫描时间,例如使用并行化策略、限制同时进行的扫描任务数量以减少网络拥堵等。 12. **权限和安全性**:端口扫描可能涉及法律和道德问题,因此在编写和使用PortScan时,需要确保...

    PortScan 端口扫描器

    .NET框架是由微软开发的一套全面的开发平台,它包含了运行应用程序所需的环境,以及一系列类库,用于构建各种类型的应用程序,包括Windows桌面应用(如我们的PortScan)。C#是一种面向对象的编程语言,设计用于.NET...

    portscan端口扫描

    描述中提到"端口扫描源代码,cpp版本,能够成功运行,在vc6环境下",这暗示了该程序是为Microsoft Visual C++ 6.0(vc6)编译器设计的。VC6是一个历史悠久但仍然被广泛使用的开发环境,尤其对于学习和理解C++编程很...

    portScan---thread.zip__scanThread_portscan_thread c

    "portScan---thread.zip__scanThread_portscan_thread c" 提供的资源似乎是一个用C#语言实现的线程化端口扫描程序。在这个项目中,开发者使用了多线程技术来提高扫描效率,这在处理大量并发连接时非常有用。 1. **...

    Portscan --a simple portscanner-开源

    1. 源代码文件:包含Portscan的主程序代码,通常用C、Python或其他编程语言编写。 2. 读取和解析命令行参数的模块:用于接收和处理用户输入的扫描参数,如目标IP地址、端口范围等。 3. 网络通信模块:实现TCP连接...

    PortScan 又一端口扫描,VB版的

    1. **套接字(Sockets)编程**:VB提供了Winsock控件,允许开发者创建基于TCP/IP协议的网络应用程序。在PortScan中,利用Winsock控件发起连接请求,来探测目标主机的端口状态。 2. **异步编程**:由于端口扫描通常...

    portscan.zip_进程与线程_Visual_C++_

    在IT领域,进程和线程是操作系统中的基本概念,它们对于理解程序的执行机制至关重要。在Windows系统中,...通过深入研究"portscan.cpp"源代码,我们可以进一步了解如何在实际应用中有效使用多线程和进程通信技术。

    网络端口扫描工具

    4. `PortScan.pdb`:这是一个程序数据库文件,用于在调试过程中关联源代码行和二进制代码。当遇到错误或需要调试程序时,它能提供源代码级别的信息,帮助开发者理解程序的运行情况。 综上所述,网络端口扫描工具是...

    基于winpcap的端口扫描程序(源代码)

    此项目提供的"PortScan without pic"可能是指源代码中未包含图形用户界面(GUI)部分,仅提供了命令行界面或控制台程序。用户可能需要自行编译源代码或按照说明配置和运行程序。 总的来说,这个基于WinPCap的端口...

    C++ 端口扫描程序

    通过阅读PortScan源代码,我们可以深入理解这些概念是如何结合在一起工作的。 总的来说,"C++ 端口扫描程序"是一个结合了网络编程、操作系统API调用和并发处理的示例项目,对于学习C++和网络扫描技术的开发者来说,...

    V isual C++ 端口扫描 源代码

    3. **PortScan.zip**:这个文件可能包含另一个端口扫描程序的源代码或相关资源,可能是一个不同的实现,供学习者比较和借鉴。 4. **ScanPort**:这可能是源代码文件、程序的某个部分或者与端口扫描相关的其他资源。...

    简单端口扫描器代码

    这段代码是一个简单的端口扫描器,用于检测指定主机在给定端口范围内的开放端口。以下是关于这个程序的关键知识点: 1. **Winsock库**:该程序使用了`&lt;winsock.h&gt;`头文件,这是Windows Socket API(Winsock)的一...

    ipv4ipv6portscan.rar_网络编程_Visual_C++_

    本项目“ipv4ipv6portscan.rar”提供了一个简单的端口扫描工具,基于Visual C++开发,旨在帮助学习者理解和实践网络编程的相关概念。 1. **IPv4与IPv6**: - IPv4:第四版互联网协议,使用32位地址,最多能支持约...

    COOlscan端口扫描器操作手册.pdf

    包括详细设计说明书、测试分析报告、操作手册等文档,以及SuperScan界面和PortScan部分代码。 **2. 软件描述** - **2.1 软件结构** CoolScan的主界面包含输入(如设置扫描参数)、处理(如扫描模式选择)和输出...

    TCP/UDP端口扫描器的设计(含源码)

    第3章 TCP/UDP端口扫描器的设计 3.4 PortScan_TCP 3.5 PortScan_UDP 因为网上没有网络扫描技术揭秘的源代码,所以自己买了书dump下光盘按章节上传,可以根据需要下载

    C++多线程端口扫描程序

    - 源代码`PortScan0623`应该包含了上述的多线程端口扫描逻辑,包括目标主机和端口范围的设定、线程创建、错误处理等关键部分。 - 通过阅读和理解代码,可以学习到如何将多线程与网络编程相结合,实现高效的端口...

    基于Python socket的端口扫描程序实例代码

    在给出的代码中,`get_my_ip()`函数用于获取本地主机的IP和端口号。它通过创建一个UDP套接字并连接到Google DNS服务器(8.8.8.8:80)来实现。`int_to_ip()`和`ip_to_int()`两个辅助函数用于在整型IP地址和字符串IP...

    端口扫描程序,TCP connect, SYN scan, FIN scan,ICMP scan

    通过"portScan"项目,你可以学习到如何在实际代码中实现这些扫描技术,理解它们的工作原理,并可能涉及到网络编程、多线程、异步I/O等方面的知识。这将有助于提升你在网络安全和系统诊断方面的技能。

    端口扫描程序精简版

    这个文件可能是端口扫描程序的源代码或可执行文件,可能包含了上述扫描方法的实现。通过分析和学习这个程序,你可以深入理解端口扫描的工作原理和编程技巧。 总之,端口扫描是网络管理中的重要工具,它的应用既有...

Global site tag (gtag.js) - Google Analytics