微软的xenroll中有一个接口acceptpkcs7提供了证书的安装功能,本文将为您讲述如何通过该接口实现在web上自动安装用户证书及根证书,并提供部分实例代码。

一、证书的安装

微软的xenroll中有一个接口acceptpkcs7提供了证书的安装功能。具体的参数如下:

HRESULT acceptPKCS7(BSTR PKCS7) 其中参数pkcs7就是经过base64编码的证书。

如果要在web页中安装证书,过程如下:

1、初始化xenroll.dll

在html代码中加入

<OBJECT id=XEnroll classid=clsid:127698e4-e730-4e5c-a2b1-21490a70c8a1 codebase="xenroll.dll">
</OBJECT>


2、读证书

证书可以从LDAP或数据库中读取,这不是我们的主题,所以在这里略过。有关细节可以参看本的LDAP等主题。

3、调用acceptPKCS7接口

代码示例如下:

on error resume next
sPKCS7 = 你取到证书内容
err.clear
XEnroll.AcceptPkcs7(sPKCS7)
if err.Number <> 0 then
if err.number = -2146885628 then
MsgBox "系统中已经存在该证书,或证书不是在这台机器申请的"
else
MsgBox "证书下载时出错,错误号="&err.description
end if
else


MsgBox "证书已成功装入"
end if


说明:只有在本机生成的证书请求才可以这样安装证书。

二、根证书的安装

微软的xenroll中的另外一个接口acceptpkcs7提供了根证书的安装功能。具体的参数如下:

[ c++]HRESULT InstallPKCS7(BSTR PKCS7)
[ vb ]Sub InstallPKCS7( ByVal PKCS7 As String )


其中参数pkcs7就是经过base64编码的根证书,如果要在web页中安装证书,过程和安装用户证书一样。