Как я могу добавить порт сканирования ip - PullRequest
0 голосов
/ 09 апреля 2019

я сервер сканирования кодирования и клиент с проверкой всех 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 голосов
/ 09 апреля 2019

Существуют не только состояния «открыто» и «закрыто», но и «фильтровано», когда одноранговый узел вообще не отвечает на запрос соединения.Это может произойти, когда хост вообще недоступен, или когда определенный порт или портранжер отброшен из-за правил фильтрации пакетов.

Вы можете подождать или истечет таймаут connect() (который может бытьнесколько минут), или вы переключаетесь на неблокирующие соединения:

fcntl(sockfd, F_SETFL, O_NONBLOCK);

Теперь вызов connect() немедленно вернется, и вы можете вызвать select() или poll() в дескрипторе файла с произвольнымтайм-аут для ускорения сканирования.

Более того, вы можете параллельно сканировать несколько портов, что значительно ускоряет общее время сканирования.

Однако действительно эффективные сканеры работают на необработанных сокетах, создавая SYNпакеты и разбор ответов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...