Как проверить длину ключа сертификата PEM с помощью функций openSSL - PullRequest
3 голосов
/ 12 января 2012

Как проверить длину ключа сертификата PEM, сгенерированного таким образом:

# openssl genrsa -des3 -out server.key 1024
# openssl req -new -key server.key -out server.csr
# cp server.key server.key.org
# openssl rsa -in server.key.org -out server.key
# openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

Мне нужна функция C, использующая процедуры из OpenSSL, которая выполняет проверку сертификата PEM (я использую его для HTTPS-сервера lighttpd) и возвращает длину ключа, сохраненного в сертификате (в данном случае 1024 ).

1 Ответ

7 голосов
/ 12 января 2012

После некоторой настройки, я считаю, нашли правильные процедуры.

Следующее должно помочь вам начать изучение других подпрограмм OpenSSL на случай, если вам понадобится обрабатывать сертификаты других типов ( x509 , pem ).

Также прочитайте ваши локальные x509.h и pem.h для структур и функций, которые будут восстанавливать другую информацию, которую вы ищете.

/* Compile with 'gcc -Wall -lcrypto foo.c' or similar...
   ---------------------------------------------------------
   $ ./a.out server.crt
   Opened: server.crt
   RSA Public Key: (1024 bit) 

   $ ./a.out server.key
   ERROR: could not read x509 data from server.key                
*/

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

int main(int argc, char *argv[]) 
{
    FILE *fp = NULL;
    X509 *x509 = NULL;
    EVP_PKEY *public_key = NULL;

    fp = fopen(argv[1], "r");
    if (fp) {
        PEM_read_X509(fp, &x509, NULL, NULL);
        fclose(fp);

        if (x509) {
            fprintf(stderr, "Opened PEM certificate file: %s\n", argv[1]);
            /* do stuff with certificate... */
            public_key = X509_get_pubkey(x509);
            if (public_key) {
                switch (public_key->type) {
                    case EVP_PKEY_RSA:
                        fprintf(stdout, "RSA Public Key: (%d bit)\n", BN_num_bits(public_key->pkey.rsa->n));
                        break;
                    default:
                        fprintf(stdout, "Unknown public key type? See OpenSSL documentation\n");
                        break;
                }
                EVP_PKEY_free(public_key);
            }
            X509_free(x509);
        }
        else {
            fprintf(stderr, "ERROR: could not read x509 data from %s\n", argv[1]);
            return EXIT_FAILURE;
        }
    }
    else {
        fprintf(stderr, "ERROR: could not open file!\n");
        return EXIT_FAILURE;
    }

    return EXIT_SUCCESS;
}
...