一段 CryptAPI 取得 证书序列号 的代码

CryptAPI 取得 证书序列号 的操作

cheungmine

通过Win32 CryptAPI查找个人证书库(MY)中的指定的证书的序列号。显示之。证书的序列号经过处理,和IE中显示的一样(只是人为地去掉了空格)。

// 去除指定字符 // 下面的代码用于字符串替换 static char* trim(char *str, char chr){ return (*str==0)?str:(((*str!=chr)?(((trim(str+1, chr)-1)==str)?str:(*(trim(str+1,chr)-1)=*str,*str=chr,trim(str+1,chr))):trim(str+1,chr))); } // 删除字符串中的指定字符, 返回字符串 static char *trimString(char *str, char chr) { #pragma warning( disable: 4996 ) return lstrcpy(str, trim(str, chr)); #pragma warning( default: 4996 ) } // 提取X509证书序列号,返回与IE看到的证书序列一致(去掉空格) static BOOL parseX509CertSerialNumber(PCCERT_CONTEXT hCert, char sn[]) { int i, len; char c0, c1; BOOL bResult; CRYPT_INTEGER_BLOB SerialNumber; char *s; // 取得要解码的信息尺寸 bResult = CryptFormatObject( hCert->dwCertEncodingType, 0, 0, NULL, 0, hCert->pCertInfo->SerialNumber.pbData, hCert->pCertInfo->SerialNumber.cbData, NULL, &SerialNumber.cbData); ASSERT(bResult); if (!bResult) return FALSE; // 分配解码数据存放 SerialNumber.pbData = (BYTE *) malloc(SerialNumber.cbData); // 解码数据 bResult = CryptFormatObject( hCert->dwCertEncodingType, 0, 0, NULL, 0, hCert->pCertInfo->SerialNumber.pbData, hCert->pCertInfo->SerialNumber.cbData, SerialNumber.pbData , &SerialNumber.cbData); ASSERT(bResult); if (!bResult){ free(SerialNumber.pbData); return FALSE; } s = (char*) malloc(48); s = ::_com_util::ConvertBSTRToString((BSTR)SerialNumber.pbData); lstrcpy(sn, s); free(s); free(SerialNumber.pbData); // 去除空格 trimString(sn, 32); // 颠倒字符串 len = strlen(sn); ASSERT(len%2==0); for(i=0; i<len/2; i+=2){ c0 = sn[i]; c1 = sn[i+1]; sn[i]=sn[len-i-2]; sn[i+1]=sn[len-i-1]; sn[len-i-2]=c0; sn[len-i-1]=c1; } return TRUE; }

==========================

如下代码调用:

------------------------------------------------------------------------------------------------------------

HCERTSTORE hStore = CertOpenStore(CERT_STORE_PROV_SYSTEM,
PKCS_7_ASN_ENCODING|X509_ASN_ENCODING,
0,
CERT_SYSTEM_STORE_CURRENT_USER,
L"MY");
if (hStore==NULL){
throw"Fail to open my cert store";

}

// 要查找的证书
char szBuf[512];
szBuf[511]=0;

BOOL bRet;
DWORD cbSize;

PCCERT_CONTEXT hCert = 0;

charSerialNumber[48];// 必须是48

while((hCert=CertEnumCertificatesInStore(hStore, hCert)) != NULL){
// 发行者名称

cbSize = CertGetNameString(hCert,

CERT_NAME_SIMPLE_DISPLAY_TYPE,

CERT_NAME_ISSUER_FLAG,

0,

szBuf,

128);

// 取出序列号
if (!parseX509CertSerialNumber(hCert, SerialNumber)){
bRet = CertCloseStore(hStore, 0);
throw "Fail to get serial number";
}

// SerialNumber存放了你想要的序列号,如:

// ‎"df48a548cef576bb4ae7a726b6938424"

// 做你喜欢的事

......

}

// 关掉这个家伙

bRet = CertCloseStore(hStore, 0);

------------------------------------------------------------------------------------------------------------

补充:很讨厌这套API。真的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值