Серверу libssh не удалось импортировать закрытый ключ хоста RSA - PullRequest
0 голосов
/ 01 сентября 2018

При попытке запустить сервер libssh в Linux я попал в сокет прослушивания ошибок: не удалось импортировать частный ключ хоста RSA. Я использовал два примера в качестве ссылок. https://github.com/substack/libssh/blob/master/examples/samplesshd.c и https://github.com/PeteMo/sshpot/blob/master/main.c. Но последняя ссылка упоминается с использованием открытого ключа, а не частного в файле readme, который меня смущает.

Я все еще практикующая С с мягкой бородой, поэтому я очень уверена, что делаю что-то неправильно. Может быть, даже сам асм (я полагаю, создатель) украсит меня быстрым советом или двумя. Вот мой код:

#include <libssh/libssh.h>
#include <libssh/server.h>  
#include <libssh/callbacks.h>
#include <libssh/legacy.h>
#include <stdlib.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>

#define SSHD_USER "user"
#define SSHD_PASSWORD "password"
#define KEYS_FILE "./ssh_host_rsa_key" 
/*#ifndef KEYS_FILE
#define KEYS_FILE
#else
#endif*/

static int auth_password(char *user, char *password)
{
    if(strcmp(user, SSHD_USER)) {
        return 0;
    } else {
        return 1;
    }

    if(strcmp(password, SSHD_PASSWORD)) {
        return 0;
    } else {
        return 1;
    }

    return 0;    
}


int main()
{
    ssh_bind sshbind = ssh_bind_new();
    ssh_session my_session = ssh_new();

    int port = 900;
    char *address = "127.0.0.1";

    ssh_bind_options_set(sshbind, SSH_BIND_OPTIONS_BINDADDR, address);
    ssh_bind_options_set(sshbind, SSH_BIND_OPTIONS_BINDPORT_STR, &port);
    ssh_bind_options_set(sshbind, SSH_BIND_OPTIONS_HOSTKEY, "ssh-rsa");
    ssh_bind_options_set(sshbind, SSH_BIND_OPTIONS_RSAKEY, KEYS_FILE);

    if (ssh_bind_listen(sshbind) < 0) {
        printf("Error listening to socket: %s\n", ssh_get_error(sshbind));
        return 1;
    }

    /* Loop, waiting for and handling connection attempts. */
    while(1) {
        if (ssh_bind_accept(sshbind, my_session) == SSH_ERROR) {
            fprintf(stderr, "Error accepting a connection: `%s'.\n",ssh_get_error(sshbind));

            return -1;
        } else {
            printf("Accepted a connection.\n");
        }

        switch (fork()) {
            case -1:
                fprintf(stderr,"Fork returned error: `%d'.\n",-1);
                exit(-1);

            case 0:
                exit(auth_password(SSHD_USER, SSHD_PASSWORD));

            default:
                break;
        }
    }

    return 0;
}

Ошибка прослушивания сокета: не удалось импортировать частный ключ хоста RSA

Я также пытался использовать содержимое ssh_host_rsa_key напрямую в качестве переменной несколькими способами. Официальный справочный документ имеет эту строку

ssh_bind_options_set(sshbind, SSH_BIND_OPTIONS_RSAKEY, KEYS_FOLDER "ssh_host_rsa_key")

Я тоже использовал это вместе с блоком #define KEYS_FILE if else, который я закомментировал, когда попробовал другой подход. Прямо сейчас мой закрытый ключ находится в том же каталоге, что и мой сервер (из-за разочарования).

Любые советы или подсказки с благодарностью!

1 Ответ

0 голосов
/ 12 сентября 2018

В маловероятном случае, когда кто-либо когда-либо сталкивался с этой проблемой, я решил создать новые ssh-ключи и связать мой код с ними. По какой-то причине ключи, которые я генерировал в первый раз, не работали, но удаляли их и использовали свежую пару. Никто никогда не будет читать эти слова.

...