openssl pem文件的读取



准备工作

生成私钥文件(里面已包含公钥)

openssl genrsa -out private.pem 1024

从私钥文件中提取公钥
openssl rsa -in private.pem -pubout -out public.pem

如果用
openssl rsa -in private.pem -RSAPublicKey_out -out public.pem
报错 unknown option -RSAPublicKey_out
openssl 是0.9.8e版本的,不知道为啥没这个参数
没了这个参数,读取公钥的时候只能用 PEM_read_RSA_PUBKEY
而不能用PEM_read_RSAPublicKey,因为带-RSAPublicKey_out参数生成的pem文件不一样(不仅仅是头尾)

网上抄来的
函数PEM_read_RSA_PUBKEY读取的是
-----BEGIN PUBLIC KEY-----
函数PEM_read_RSAPublicKey读取的是
-----BEGIN RSA PUBLIC KEY-----

但是!!!,为毛private.pem里面是
-----BEGIN RSA PRIVATE KEY-----
这样的,

而生成的public.pem竟然是
-----BEGIN PUBLIC KEY-----
的?


#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <openssl/bn.h>
#include <openssl/rsa.h>
#include <openssl/pem.h>

int main()
{
	RSA *rsa;
	
	
	FILE *fp;
	if ((fp = fopen("C:\\openssl_test\\public.pem", "r")) == NULL) {
        return -1;
    }
	
    rsa = PEM_read_RSA_PUBKEY(fp, NULL, NULL, NULL);
	RSA_free(rsa);
	fclose(fp);

	if ((fp = fopen("C:\\openssl_test\\private.pem", "r")) == NULL) {
        return -1;
    }
    rsa = PEM_read_RSAPrivateKey(fp,NULL,NULL,NULL);

	RSA_free(rsa);
	return 0;   
}






免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM