4

我想certifi.crt使用 OpenSSL API(不在命令中)读取文件。我不知道该怎么做。如果有人知道,请帮助我。谢谢你。

如果您提供示例代码,那将非常有帮助。

4

1 回答 1

5

如果“.crt”扩展名是指 PEM 文本文件(以 -----BEGIN CERTIFICATE----- 开头,后跟 base64),请在此处开始阅读 OpenSSL 文档。

以下是一些帮助您入门的代码(与 ssl 的链接,例如 g++ ac -lssl):

#include <stdio.h>
#include <openssl/x509.h>
#include <openssl/pem.h>

int main(int argc, char** argv)
{
    FILE* f = fopen("certifi.crt", "r");
    if (f != NULL)
    {
        X509* x509 = PEM_read_X509(f, NULL, NULL, NULL);
        if (x509 != NULL)
        {
            char* p = X509_NAME_oneline(X509_get_issuer_name(x509), 0, 0);
            if (p)
            {
                printf("NAME: %s\n", p);
                OPENSSL_free(p);
            }
            X509_free(x509);
        }
    }
    return 0;
}
于 2011-04-06T22:09:17.460 回答