通过OpenSSL解码X509证书文件
在Windows平台下。假设要解析一个X509证书文件,最直接的办法是使用微软的CryptoAPI。
可是在非Windows平台下,就仅仅能使用强大的开源跨平台库OpenSSL了。一个X509证书通过OpenSSL解码之后,得到一个X509类型的结构体指针。
通过该结构体,我们就能够获取想要的证书项和属性等。
X509证书文件,依据封装的不同。主要有下面三种类型:
*.cer:单个X509证书文件,不私钥,能够是二进制和Base64格式。该类型的证书最常见;
*.p7b:PKCS#7格式的证书链文件。包括一个或多个X509证书。不含私钥。
通常从CA中心申请RSA证书时。返回的签名证书就是p7b格式的证书文件;
*.pfx:PKCS#12格式的证书文件,能够包括一个或者多个X509证书,含有私钥,一般有password保护。通常从CA中心申请RSA证书时。加密证书和RSA加密私钥就是一个pfx格式的文件返回。
以下,针对这三种类型的证书文件,使用OpenSSL进行解码,得到相应的X509结构体指针。须要注意的是,演示样例代码中的证书文件内容都是指二进制数据,假设证书文件本身使用的Base64格式。从文件读取之后,须要将Base64格式的内容转化为二进制数据,才干使用以下的解码函数。
一、解码CER证书文件
CER格式的文件最简单,仅仅须要调用API d2i_X509()就可以。
演示样例代码例如以下(lpCertData为二进制数据):
- m_pX509 = d2i_X509(NULL, (unsigned char const **)&lpCertData, ulDataLen);
- if (m_pX509 == NULL)
- {
- return CERT_ERR_FAILED;
- }
二、解码P7B证书文件
因为P7B是个证书链文件,理论上能够包括多个X509证书。可是实际应用中,往往仅仅包括一个文件。所以我们仅仅处理第一个证书。
演示样例代码例如以下:
- int rv = 0;
- int nid = 0;
- PKCS7* p7 = NULL;
- STACK_OF(X509) *certs = NULL;
- BIO* bio = BIO_new(BIO_s_mem());
- // 解码p7b内容
- rv = BIO_write(bio, lpCertData, ulDataLen);
- p7 = d2i_PKCS7_bio(bio, NULL);
- BIO_free(bio);
- // 获取P7的详细格式
- nid = OBJ_obj2nid(p7->type);
- if(nid == NID_pkcs7_signed)
- {
- certs = p7->d.sign->cert;
- }
- else if(nid == NID_pkcs7_signedAndEnveloped)
- {
- certs = p7->d.signed_and_enveloped->cert;
- }
- // 仅仅支持单证书的p7b
- m_pX509 = sk_X509_value(certs, 0);
- if (m_pX509 == NULL)
- {
- return CERT_ERR_FAILED;
- }
如在特殊的情况下。须要处理整个证书链中的全部证书。则仅仅须要循环调用sk_X509_value()知道返回为NULL为止。
三、解码PFX证书文件
解码PFX证书时,实际上是获取X509证书、私钥数据和CA证书链一系列对象,同一时候须要校验PFX的password。演示样例代码例如以下:
- int rv = 0;
- PKCS12 *p12 = NULL;
- EVP_PKEY *pkey = NULL;
- STACK_OF(X509) *ca = NULL;
- BIO *bio;
- // 解码P12内容
- bio = BIO_new(BIO_s_mem());
- rv = BIO_write(bio, lpCertData, ulDataLen);
- p12 = d2i_PKCS12_bio(bio, NULL);
- BIO_free_all(bio);
- // 获取证书对象
- rv = PKCS12_parse(p12, lpscPassword, &pkey, &m_pX509, &ca);
- if (!rv || !m_pX509)
- {
- rv = CERT_ERR_FAILED;
- goto FREE_MEMORY;
- }
- // 释放内存
- FREE_MEMORY:
- PKCS12_free(p12);
- EVP_PKEY_free(pkey);
- sk_X509_free(ca);
至此。三种常见证书文件的解码以完毕,通过解码得到的证书上下文结构体指针m_pX509。通过该指针就能够解析证书的项和扩展属性了。
详细的解析方法,将在兴许的Blog中逐一介绍。
相关博文:通过OpenSSL解析证书基本项
通过OpenSSL解码X509证书文件的更多相关文章
- 通过OpenSSL解析X509证书基本项
在之前的文章"通过OpenSSL解码X509证书文件"里.讲述了怎样使用OpenSSL将证书文件解码,得到证书上下文结构体X509的方法. 以下我们接着讲述怎样通过证书上下文结构体 ...
- 【openssl】利用openssl完成X509证书和PFX证书之间的互转
利用openssl完成X509证书和PFX证书之间的互转 # OpenSSL的下载与安装: 1.下载地址: 官方网址—— https://www.openssl.org/source/ OpenSSL ...
- CSP:使用CryptoAPI解码X509证书内容
微软的CryptoAPI提供了一套解码X509证书的函数,一个X509证书解码之后,得到一个PCCERT_CONTEXT类型的结构体指针. 通过该结构体,我们就能够获取想要的证书项和属性等. X509 ...
- OpenSSL 使用拾遗(二)---- X509 证书的 SKID/AKID 字段
SKID(证书使用者密钥标识符,subject key identifier 的简称)和 AKID(证书颁发机构密钥标识符,authority key identifier 的简称)是 X509 证书 ...
- 通过OpenSSL来生成二进制格式证书文件(pfx和cer)
1.生成RSA字符串私钥 genrsa -out private-rsa.key 2.由1中私钥导出*.cer二进制公钥文件 req -new -x509 -key private-rsa.key - ...
- 转换java keytools的keystore证书到OPENSSL的PEM格式文件
背景:原先业务使用的前端为haproxy,直接端口转发至tomcat,后端进行ssl连接,所以当时生成的步骤如下 ? 1 2 •生成密钥对:keytool -genkey -alias tomcat- ...
- 用OpenSSL命令行生成证书文件
用OpenSSL命令行生成证书文件 1.首先要生成服务器端的私钥(key文件): openssl genrsa -des3 -out server.key 1024 运行时会提示输入密码,此密码用于加 ...
- 利用keytool、openssl生成证书文件
转载请标明出处:http://blog.csdn.net/shensky711/article/details/52225073 本文出自: [HansChen的博客] 用openssl指令逐步生成各 ...
- openssl rsa加密,解密以及X509证书的使用
Openssl的相关使用 生成证书 生成证书见:使用 openssl 生成证书 代码实现 Cert.h #ifndef _CERT_H #define _CERT_H ///header files ...
随机推荐
- configure.ac
# # Copyright (C) - Tobias Brunner # Copyright (C) - Andreas Steffen # Copyright (C) - Martin Willi ...
- 作业还是作孽?——Leo鉴书79
中国孩子,尤其是城市孩子课业过重是个不争的事实.儿子上幼儿园的作业已经能做到8点多了,上小学之后不知道是不是会整得更晚.于是入手这本<家庭作业的迷思>,认真读读.请特别注意,不要买书叫&q ...
- Actor::updateMassFromShapes
unity报错Actor::updateMassFromShapes: Compute mesh inertia tensor failed for one of the actor's mesh s ...
- ant_0105
在projectA中执行projectB的构件文件.projectA的构件文件内容如下 <?xml version="1.0"?> <!-- 在projectA中 ...
- 二、Nginx变量
$arg_PARAMETER 功能:如果在请求中设置了查询字符串,那么这个变量包含在查询字符串是GET请求PARAMETER中的值. $args 功能:该变量的值是GET请求在请求行中的参数. $bi ...
- 知识普及:iOS7搭载新定位技术iBeacon
摘自:http://iphone.91.com/tutorial/jcjc/131023/21619035.html 在2013年六月举行的WWDC上,作为iOS 7中最重要的新特性之一,苹果正式对外 ...
- VC2008如何生成及使用DLL(图文并茂,完整版)
博客分类: Dot net VC2008 DLL Dot net 生成.使用DLL看起来简单,但做起来才发现还是有一些地方需要注意的. 1. 打开VS2008,新建一个VC工程,选择Win32类型 ...
- 读取sd卡下图片,由图片路径转换为bitmap
public Bitmap convertToBitmap(String path, int w, int h) { BitmapFactory.Options opts = ...
- shell登录模式及其相应配置文件(转)
参考<linux命令.编辑器与shell编程>(清华大学出版社) 当启动shell时,它将运行启动文件来初始化自己.具体运行哪个文件取决于该shell是登陆shell还是非登陆shell的 ...
- HDU 4336 Card Collector(动态规划-概率DP)
Card Collector Problem Description In your childhood, do you crazy for collecting the beautiful card ...