0

libssh を使用して 2 つのシステム間の接続を実現しています。ssh サーバーは redhat、クライアントは CentOS です。

私のコードは問題なくコンパイルおよびリンクされますが、実行時にこれが表示され続けます。

[1] libssh 0.5.5 (c) 2003-2010 Aris Adamantiadis (aris@0xbadc0de.be) Distributed under the LGPL, please refer to COPYING file for information about your rights, using threading threads_noop
[2] Nonblocking connection socket: 4
[2] Socket connecting, now waiting for the callbacks to work
[1] Socket connection callback: 1 (0)
[1] SSH server banner: SSH-2.0-OpenSSH_5.3
[1] Analyzing banner: SSH-2.0-OpenSSH_5.3
[1] We are talking to an OpenSSH client version: 5.3 (50300)
[2] Received SSH_KEXDH_REPLY
[2] SSH_MSG_NEWKEYS sent
[2] Received SSH_MSG_NEWKEYS
./sshclient: symbol lookup error: ./sshclient: undefined symbol: ssh_pki_import_privkey_file

コードは次のようになります。

int main()
{
    ssh_session my_ssh_session;
    ssh_key *pubkey,*privkey;
    int verbosity = SSH_LOG_PROTOCOL;
    int port = 5022,rc;
    char username[20];

    strcpy(username,"yoda"); //assigned a user name
    my_ssh_session = ssh_new();
    if (my_ssh_session == NULL)
            exit(-1);
    ssh_options_set(my_ssh_session, SSH_OPTIONS_HOST, "XX.XX.XX.XX");
    ssh_options_set(my_ssh_session, SSH_OPTIONS_LOG_VERBOSITY, &verbosity);
    ssh_options_set(my_ssh_session, SSH_OPTIONS_PORT, &port);
    ssh_options_set(my_ssh_session, SSH_OPTIONS_USER, username);

    rc = ssh_connect(my_ssh_session);
    if(rc != SSH_OK){
            fprintf(stderr, "Error connecting to host: %s\n",ssh_get_error(my_ssh_session));
            exit(-1);
    }
    rc = ssh_pki_import_privkey_file("/home/yoda/keys/id_rsa",NULL,NULL,NULL,privkey);
    if(rc != SSH_OK){
            fprintf(stderr, "Custom Message: Private Key unacceptable.\n");
            exit(-1);
    }
    fprintf(stdout, "Custom Message: Here now.\n");
    rc = ssh_userauth_publickey(my_ssh_session, NULL, *privkey);
    if(rc == SSH_AUTH_ERROR){
            fprintf(stderr, "Custom Message: A serious error has occured during authentication.\n");
            exit(-1);
    }
    if(rc == SSH_AUTH_DENIED){
            fprintf(stderr, "Custom Message: Unacceptable key or method.\n");
            exit(-1);
    }
    if(rc == SSH_AUTH_PARTIAL){
            fprintf(stderr, "Custom Message: Partially authenticated user.\n");
            exit(-1);
    }
    ssh_key_free(*pubkey);
    ssh_key_free(*privkey);
    ssh_disconnect(my_ssh_session);
    ssh_free(my_ssh_session);
    return(0);
}

このコードには多くの問題があることはわかっていますが、現時点では、このライブラリを初めて試しており、動作させることに関心があります。何が起こっているのかについての洞察をいただければ幸いです。

4

1 に答える 1

-1

libssh 0.5 はメンテナンスを終了しました。libssh 0.6 を使用する必要があります。私の記憶が正しければ、ssh_pki_import_privkey_file() は libssh 0.6 でしか利用できません ...

于 2014-11-03T08:06:52.830 に答える