保存openssl中RSA密钥对
2015-06-16 18:31
309 查看
标准的openssl生成的证书的顺序是 :
[OpenSSL 测试程序: ]https://github.com/qianguozheng/datastructure]
如下是生成密钥对, 根据密钥并且分别保存密钥对的私钥,与公钥.
经过测试, 密钥对中的私钥可以提取出公钥, 我对其密钥不是很了解,通过测试发现是可以的. 不知道谁可以讲述下.
[OpenSSL 测试程序: ]https://github.com/qianguozheng/datastructure]
如下是生成密钥对, 根据密钥并且分别保存密钥对的私钥,与公钥.
经过测试, 密钥对中的私钥可以提取出公钥, 我对其密钥不是很了解,通过测试发现是可以的. 不知道谁可以讲述下.
[code]/* 产生RSA密钥 */ RSA *rsa = RSA_new(); BIGNUM* e = BN_new(); /* 设置随机数长度 */ BN_set_word(e, 65537); /* 生成RSA密钥对 */ RSA_generate_key_ex(rsa, 2048, e, NULL); printf("BIGNUM: %s\n", BN_bn2hex(rsa->n)); /* 提取私钥 */ printf("PRIKEY:\n"); FILE *filename = NULL; filename = fopen("privateKey.pem", "wb"); PEM_write_RSAPrivateKey(filename, rsa, NULL, NULL, 0, NULL, NULL); fclose(filename); //writeRSA(rsa, NULL); /* 提取公钥 */ unsigned char *n_b = (unsigned char *)calloc(RSA_size(rsa), sizeof(unsigned char)); unsigned char *e_b = (unsigned char *)calloc(RSA_size(rsa), sizeof(unsigned char)); int n_size = BN_bn2bin(rsa->n, n_b); int b_size = BN_bn2bin(rsa->e, e_b); RSA *pubrsa = RSA_new(); pubrsa->n = BN_bin2bn(n_b, n_size, NULL); pubrsa->e = BN_bin2bn(e_b, b_size, NULL); printf("PUBKEY: \n"); FILE *publicKey = NULL; publicKey = fopen("publicKey.pem", "wb"); PEM_write_RSAPublicKey(publicKey, pubrsa); fclose(publicKey); RSA_free(rsa); RSA_free(pubrsa);
相关文章推荐
- 虚拟内存管理 --嵌入式Linux系统工程师系列之ARM920T的MMU与Cache
- 【Chrome】chrome架构及特性
- maven项目如何在Linux下运行?
- OpenCms创建网站的过程示意图——专用OpenCms人们刚开始学习
- nginx linux 配置文档
- 重要的开源资源及50个c/c++源代码网站
- linux进程调度CFS
- erlang进程监控:link和monitor
- Linux_1.5_makefile工程管理
- Hadoop第三讲
- Linux Shell 之 Shell中的函数调用
- Linux Shell 之 Shell中的函数调用
- 利用Openbabel将SMILES转化为canonical SMILES
- ubuntu 14.04(trusty)下搭建本地docker regestry
- 请问JAVA三层架构,持久层,业务层,表现层,都该怎么理解?和MVC三层模型有什么区别
- 每天进步一点点——linux——mv
- 找工作相关网站
- Lucene 简单案例
- 基于Keepalived实现LVS双主高可用集群 推荐
- linux,apache,php,mysql常用的查看版本信息的方法