完整端口扫描

优点简单

缺点速度慢,一般防火墙会过滤掉该数据包,且发起扫描的源地址容易被察觉


#include <stdio.h>

#include <winsock2.h>

#pragma comment(lib,"ws2_32")

#define START_PROT 80 //扫描起始端口
#define END_PROT 1025 //扫描结束端口

int main(int argc, char *argv[])
{
if(argc != 2) //检查是否有IP地址参数
{
printf("need a IP");
return 1;
}

int i;
WSADATA ws;
SOCKET sockfd;
struct sockaddr_in target_addr;

WSAStartup(MAKEWORD(2,2),&ws);

//初始化地址结构体
target_addr.sin_family = AF_INET;
target_addr.sin_addr.S_un.S_addr = inet_addr(argv[1]);

for(i=START_PROT; i<END_PROT; i++)
{
sockfd = socket(AF_INET,SOCK_STREAM,0);//建立套接字
target_addr.sin_port = htons(i);//初始化地址端口

if(connect(sockfd,(struct sockaddr *)&target_addr,

sizeof(struct sockaddr)) == SOCKET_ERROR)//尝试连接

{
printf("PORT %d close\n",i);//连接失败,端口未打开
}
else
{
printf("PORT %d open\n",i);//连接成功,端口已打开
}
}
closesocket(sockfd);
WSACleanup();

return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值