Chinaunix
标题:
自己写的端口扫描代码,为什么陷入死循环中?
[打印本页]
作者:
刘一痕
时间:
2010-07-10 14:29
标题:
自己写的端口扫描代码,为什么陷入死循环中?
本帖最后由 刘一痕 于 2010-07-10 14:32 编辑
#include <string.h>
#include <stdio.h>
#include <arpa/inet.h>
#define PORT 0
#define IP "192.168.0.84" //目标机IP
int scan(int port)
{
struct sockaddr_in clientaddr;
int sockfd = socket(AF_INET,SOCK_STREAM,0);
if(-1 == sockfd)
{
perror("socket return error in function main");
return -1;
}
memset(&clientaddr,0,sizeof(struct sockaddr_in));
clientaddr.sin_family = AF_INET;
clientaddr.sin_addr.s_addr = inet_addr(IP);
int number;
for(number = port;number<65535;number++ )
{
clientaddr.sin_port = htons(PORT+number);
if(0== connect(sockfd,(struct sockaddr *)&clientaddr,sizeof(struct sockaddr)))
{
printf("port %d open\n",number);
close(sockfd);
return number;
}
}
return -1;
}
int main(void)
{
int temp_i;
int ret;
for(temp_i = 0;temp_i < 65535; )
{
ret = scan(temp_i+1);
if(ret == -1 )
{
printf("scan end\n");
return 0;
}
else
{
temp_i = ret;
}
}
return 0;
}
上面的代码是我自己写的一段端口扫描代码,扫描目标机 192.168.0.84,结果却在scan函数中出现死循环
作者:
langue
时间:
2010-07-12 01:38
同学你是不是忘记 temp_i++ 了?
作者:
hellioncu
时间:
2010-07-12 08:34
阻塞了
作者:
ka-bar
时间:
2010-07-12 15:47
同意楼上的。
作者:
雨夜流星
时间:
2010-07-16 17:12
本帖最后由 雨夜流星 于 2010-07-16 17:15 编辑
回复
1#
刘一痕
这个端口扫描代码问题太多了吧?
1、temp_i的值,当你的sacn()返回-1时,是个什么情况?为何main和scan里面两次循环?
2、从0~65535,每次调用scan()都重新建立一个socket,这个不合理吧?
2、int sockfd = socket(AF_INET,SOCK_STREAM,0); 每次都建立链接,会很耗资源。
探测端口,只需要发一个syn包到该端口即可,不需要建立链接。使用原始套接字,直接发包,
socket(AF_INET, SOCK_RAW, IPPROTO_RAW); 然后再用一个socket去捕获返回的数据,判断rst,ack。
作者:
rune_zhang
时间:
2010-07-16 18:35
本帖最后由 rune_zhang 于 2010-07-16 18:36 编辑
你的int是多少字节的呢,如果是2字节的,那就得死循环了。因为-32768,和32767都比65535小。
建议你先看看int是16位的还是32位的
作者:
lanying_wzw
时间:
2010-07-16 22:22
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2