我正在编写一个连接到远程服务器并使用自签名证书的程序。我在程序中的几个点上得到以下错误。

Program received signal SIGSEGV, Segmentation fault.
0xb7ec3688 in X509_STORE_add_lookup () from /lib/i386-linux-gnu/libcrypto.so.1.0.0

此时:
    if (!SSL_CTX_load_verify_locations(
                ssl_ctx_p, "bundle_test.p12.pem", NULL))

还有一个:
Program received signal SIGSEGV, Segmentation fault.
0xb7ec389e in X509_STORE_get_by_subject () from /lib/i386-linux-gnu/libcrypto.so.1.0.0

在这里:
ssl_ret = SSL_connect(ssl_p);

我对此还很陌生,不知道出了什么问题,如果有人能提出更好的方法来调试或解决问题,我将不胜感激!

最佳答案

这个函数本身做不了多少工作。唯一能在函数内部而不是X509_STORE_load_locations()内部导致segfault的是指针解引用ctx->cert_store。请验证ssl_ctx_p是有效的上下文,而不是NULL

int SSL_CTX_load_verify_locations(SSL_CTX *ctx, const char *CAfile,
                const char *CApath)
        {
        return(X509_STORE_load_locations(ctx->cert_store,CAfile,CApath));
        }

关于c - X509_STORE_add_lookup()中的段错误,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/18980212/

10-12 03:51