使用windows crypt API解析X509证书
一、版本号
结构体CERT_INFO中的字段dwVersion即为证书版本,可以直接通过下面的代码获得:
DWORD dwCertVer = m_pCertContext->pCertInfo->dwVersion;
版本值的定义如下:
也就是说,V1的值为0;V3的值为2,目前绝大多是证书都是V3版本。
二、序列号
序列号对应结构体CERT_INFO中的字段SerialNumber,不过该字段为ASN.1编码的大数对象,需要解码才能转化为我们平时看到的十六进制序列号。获取序列号的函数如下:
- ULONG CCSPCertificate::get_SN(LPSTR lptcSN,ULONG *pulLen)
- {
- CHAR scSN[512] = {0};
- if (!m_pCertContext)
- {
- return CERT_ERR_INVILIDCALL;
- }
- if (!pulLen)
- {
- return CERT_ERR_INVALIDPARAM;
- }
- PCRYPT_INTEGER_BLOB pSn = &(m_pCertContext->pCertInfo->SerialNumber);
- for (int n = (int)(pSn->cbData - 1); n >= 0; n--)
- {
- CHAR szHex[5] = {0};
- sprintf_s(szHex, "%02X", (pSn->pbData)[n]);
- strcat_s(scSN, 512, szHex);
- }
- if (!lptcSN)
- {
- *pulLen = strlen(scSN) + 1;
- return CERT_ERR_OK;
- }
- if (*pulLen <= strlen(scSN) + 1)
- {
- return CERT_ERR_BUFFER_TOO_SMALL;
- }
- strcpy_s(lptcSN, *pulLen, scSN);
- *pulLen = strlen(scSN);
- return CERT_ERR_OK;
- }
三、公钥算法(证书算法)
证书中的公钥算法,需要通过CERT_INFO中字段SubjectPublicKeyInfo来获取。具体函数如下:
- ULONG CCSPCertificate::get_KeyType(ULONG* pulType)
- {
- if (!m_pCertContext)
- {
- return CERT_ERR_INVILIDCALL;
- }
- if (!pulType)
- {
- return CERT_ERR_INVALIDPARAM;
- }
- PCERT_PUBLIC_KEY_INFO pPubKey = &(m_pCertContext->pCertInfo->SubjectPublicKeyInfo);
- if (pPubKey)
- {
- if (_stricmp(pPubKey->Algorithm.pszObjId, szOID_RSA_RSA) == 0)
- {
- *pulType = CERT_KEY_ALG_RSA;
- }
- else if (_stricmp(pPubKey->Algorithm.pszObjId, szOID_ECC_PUBLIC_KEY) == 0)
- {
- *pulType = CERT_KEY_ALG_ECC;
- }
- else
- {
- *pulType = 0;
- return CERT_ERR_ALG_UNKNOWN;
- }
- }
- else
- {
- return GetLastError();
- }
- return CERT_ERR_OK;
- }
四、证书用途
证书从用途来分,分为“签名证书”和“加密证书”两大类。“签名证书”的公钥用来验证签名,而“加密证书”的公钥则用来加密数据。我们需要通过调用函数CertGetIntendedKeyUsage()来获取证书的用途,具体函数实现如下:
- ULONG CCSPCertificate::get_KeyUsage(ULONG* lpUsage)
- {
- BYTE btUsage[2] = {0};
- if (!m_pCertContext)
- {
- return CERT_ERR_INVILIDCALL;
- }
- if (!lpUsage)
- {
- return CERT_ERR_INVALIDPARAM;
- }
- if (CertGetIntendedKeyUsage(GLOBAL_ENCODING_TYPE, m_pCertContext->pCertInfo, btUsage, 2))
- {
- if (btUsage[0] & CERT_DIGITAL_SIGNATURE_KEY_USAGE)
- {
- *lpUsage = CERT_USAGE_SIGN;
- }
- else if (btUsage[0] & CERT_DATA_ENCIPHERMENT_KEY_USAGE)
- {
- *lpUsage = CERT_USAGE_EXCH;
- }
- else
- {
- *lpUsage = 0;
- return CERT_ERR_USAGE_UNKNOWN;
- }
- }
- else
- {
- return GetLastError();
- }
- return CERT_ERR_OK;
- }
五、签名算法
证书的签名算法,是指证书用来签名时使用的算法(包含HASH算法)。签名算法用结构体CERT_INFO中SignatureAlgorithm字段来表示,可以通过SignatureAlgorithm的子字段pszObjId返回签名算法的Oid,这样对比Oid就可以知道签名算法的具体含义了。pszObjId常见得定义如下:
- #define CERT_SIGNATURE_ALG_RSA_RSA "1.2.840.113549.1.1.1" //RSA直接签名
- #define CERT_SIGNATURE_ALG_MD2RSA "1.2.840.113549.1.1.2" //MD2作Hash、然后RSA签名
- #define CERT_SIGNATURE_ALG_MD4RSA "1.2.840.113549.1.1.3" //MD4作Hash、然后RSA签名
- #define CERT_SIGNATURE_ALG_MD5RSA "1.2.840.113549.1.1.4" //MD5作Hash、然后RSA签名
- #define CERT_SIGNATURE_ALG_SHA1RSA "1.2.840.113549.1.1.5" //SHA1作Hash、然后RSA签名
- #define CERT_SIGNATURE_ALG_SM3SM2 "1.2.156.10197.1.501" //SM3作Hash、然后SM2签名
以上为http://blog.csdn.net/yyfzy/article/details/46790043内容
接下来是我的实现截图
有需要源码的留下邮箱
使用windows crypt API解析X509证书的更多相关文章
- [转贴]使用CryptoAPI解析X509证书和P12证书
原文在 http://bbs.pediy.com/archive/index.php?t-97663.html,但是觉得这篇文章非常好,我抄下来作我笔记用 一.解析X509证书 1.从磁盘上的证书文件 ...
- 通过OpenSSL解析X509证书基本项
在之前的文章"通过OpenSSL解码X509证书文件"里.讲述了怎样使用OpenSSL将证书文件解码,得到证书上下文结构体X509的方法. 以下我们接着讲述怎样通过证书上下文结构体 ...
- 使用Python Openssl库解析X509证书信息
X.509 证书结构描述 常见的X.509证书格式包括: 后缀 作用 cer/crt 用于存放证书,它是2进制形式存放的,不含私钥 pem 以Ascii来表示,可以用于存放证书或私钥. pfx/p12 ...
- CSP:使用CryptoAPI解码X509证书内容
微软的CryptoAPI提供了一套解码X509证书的函数,一个X509证书解码之后,得到一个PCCERT_CONTEXT类型的结构体指针. 通过该结构体,我们就能够获取想要的证书项和属性等. X509 ...
- openssl解析国密X509证书
openssl解析国密X509证书,把公钥拿出来重写一下就行了 x = strToX509(pbCert, pulCertLen);dwRet = getCertPubKey(x, &a ...
- 通过OpenSSL解码X509证书文件
在Windows平台下.假设要解析一个X509证书文件,最直接的办法是使用微软的CryptoAPI. 可是在非Windows平台下,就仅仅能使用强大的开源跨平台库OpenSSL了.一个X509证书通过 ...
- Windows错误码解析
C或者C++开发肯定经常会遇到各种错误码,由于每个错误码只是一个枚举或者一个整形数值,调试或者输出日志的时候,无法知道这个错误码的具体含义,这时候就需要将此错误码解释出来.对于自己定义的错误码,可以通 ...
- X509 证书生成
X509证书介绍X.509 是由国际电信联盟(ITU-T)制定的数字证书标准,相信这是人尽皆知的了,目前X.509证书据我所知有三个版本,.net中使用的是x.509-2,X.509-2 版引入了主体 ...
- java微信开发API解析(二)-获取消息和回复消息
java微信开发API解析(二)-获取消息和回复消息 说明 * 本演示样例依据微信开发文档:http://mp.weixin.qq.com/wiki/home/index.html最新版(4/3/20 ...
随机推荐
- React初识(按钮点击+输入绑定)
简单按钮点击事件: <!DOCTYPE html><html> <head> <meta charset="utf-8"> ...
- 2015项目timeline
1. app签到 http://h5.a.rongyi.com/html/app/sign/index.html (pc无效果.app端 20160105) 2.圣诞活动--砍价 http://h5 ...
- Java中如何克隆集合——ArrayList和HashSet深拷贝
编程人员经常误用各个集合类提供的拷贝构造函数作为克隆List,Set,ArrayList,HashSet或者其他集合实现的方法.需要记住的是,Java集合的拷贝构造函数只提供浅拷贝而不是深拷贝,这意味 ...
- 复制物料(参考的MMCC想法)
MMCC这个事务码没用过,也是才听到的,都是业务搞起来的...然后感觉这个东西有点意思,就搞搞咯 网上找的一篇文章,自己修改的.改了默认收货工厂为创建时的工厂,因为这边一直报收货工厂必输...不管是不 ...
- Web自动化测试学习方向(Selenium)
目前越来越多的人想学自动化测试,认为自动化测试好牛逼.经常在测试交流群里看见有HR发招聘广告说:招初级(功能测试),招中级(性能测试),招高级(自动化测试)...... 我不去讨论他们这个初中高级的说 ...
- 课堂作业二 PAT1025 反转链表
MyGitHub 终于~奔溃了无数次后,看到这个结果 ,感动得不要不要的::>_<:: 题目在这里 题目简述:该题可大致分为 输入链表 -> 链表节点反转 -> 两个步骤 输入 ...
- Vue2.X的状态管理vuex记录
记住上述的顺序情况:想要改变state,只能通过Mutation,虽然action可以直接改变state,这样会使每个状态可以方便的跟踪和记录(用Devtools跟踪) vue Method -- ...
- git clone error: RPC failed; result=22, HTTP code = 502
http://www.jianshu.com/p/645d3fe4e028 git克隆的工程太大用https的方式会有如下问题 hbl:tmp hubert$ git clone https://gi ...
- 无废话SharePoint入门教程二[SharePoint发展、工具及术语]
一.前言 1.由于上一篇文章的标题命名失误,此篇标题写给百度搜索”什么是SharePoint”. 2.关于什么是SharePoint,请参见本人的第一篇文章:http://www.cnblogs.co ...
- 使用Support Vector Machine
使用svm(Support Vector Machine)中要获得好的分类器,最重要的是要选对kernel. 常见的svm kernel包括linear kernel, Gaussian kernel ...