如何添加扫描端口ip

时间:2019-04-09 12:50:27

标签: c sockets server client

i用扫描所有ip编码扫描服务器和客户端 我用插座/ C 但是我不明白如何在结构中为ip之一添加扫描端口 我的扫描端口有问题 我有一个错误的显示,他没有显示任何打开 问题是什么也没显示在服务器上打开任何端口。 我找不到任何解决方案 我需要帮助

#include <netdb.h> 
#include "stdio.h"
#include <netinet/in.h> 
#include <stdlib.h> 
#include <string.h> 
#include <sys/socket.h> 
#include <sys/types.h> 
#include <arpa/inet.h>
#define MAX 80 
#define PORT 8080 
#define SA struct sockaddr 

// Driver function 
int main() 
{ 
        int sockfd, connfd, len ,start , end,err;
        struct sockaddr_in servaddr, cli; 
        struct sockaddr_in addr_remote;
    char ips[2][20];
    char hostname[30];

    // socket create and verification 
    sockfd = socket(AF_INET, SOCK_STREAM, 0); 
    if (sockfd == -1) { 
    printf("socket creation failed...\n"); 
    exit(0); 
    } 
    else
    printf("Socket successfully created..\n"); 
    bzero(&servaddr, sizeof(servaddr)); 

    // assign IP, PORT 
    servaddr.sin_family = AF_INET; 
    servaddr.sin_addr.s_addr = htonl(INADDR_ANY); 
    servaddr.sin_port = htons(PORT); 

    // Binding newly created socket to given IP and verification 
    if ((bind(sockfd, (SA*)&servaddr, sizeof(servaddr))) != 0) { 
    printf("socket bind failed...\n"); 
    exit(0); 
    } 
    else
    printf("Socket successfully binded..\n"); 

    // Now server is ready to listen and verification 

    if ((listen(sockfd, 5)) != 0) { 
    printf("Listen failed...\n"); 
    exit(0); 
    } 
    else
    printf("Server listening..\n"); 
    len = sizeof(cli); 

    // Accept the data packet from client and verification 
 for(int i=0;i<2;i++){
    connfd = accept(sockfd, (SA*)&addr_remote, &len); 
    if (connfd < 0) { 
    printf("server acccept failed...\n"); 
    exit(0); 
    } 
    else
    printf("server acccept the client...\n"); 
    strcpy(ips[i], inet_ntoa(addr_remote.sin_addr));
    }

    // Display Ip 
   for(int i=0;i<2;i++){
    printf("%s \n",ips[i]);}


    // Scan PORT

        //Get the hostname to scan
        printf("Enter hostname or IP : ");
        gets(hostname);

        //Get start port number
        printf("Enter start port number : ");
        //To Handle the Input
        int data;
        data = scanf("%d",&start);

        //Get end port number
        printf("Enter end port number : ");
        int data2 = scanf("%d" , &end);
        int j;
         //Start the port scan loop
            printf("Starting the portscan loop : \n");
            for( j = start ; j <= end ; j++)
            {
            //Fill in the port number
            servaddr.sin_port = htons(j);

            //Connect using that socket and sockaddr structure

            err =connect(sockfd, (SA*)&servaddr, sizeof(servaddr));
            if( err < 0 )
            {
            //printf("%s %-5d %s\r" , hostname , i, strerror(errno));
            fflush(stdout);
            }
            //connected
            else
            {
            printf("%-5d open\n", j);
            }
        }

    // After chatting close the socket 
    close(sockfd); 
}

1 个答案:

答案 0 :(得分:0)

当对等点完全不响应连接请求时,不仅有“打开”和“关闭”状态,而且还有“已过滤”状态。当主机根本无法访问,或者由于数据包筛选器规则而丢弃某个端口或端口范围时,可能会发生这种情况。

您可以等待connect()超时(可能要花几分钟),也可以切换到非阻塞连接:

fcntl(sockfd, F_SETFL, O_NONBLOCK);

现在,connect()调用将立即返回,您可以在文件描述符上调用select()poll(),并设置任意超时以加快扫描速度。

此外,您可以通过这种方式并行扫描多个端口,从而显着加快了总扫描时间。

但是,真正有效的扫描程序在原始套接字上运行,从而创建SYN数据包并解析答复。