PKCS#7签名代码图像提取

时间:2010-05-12 09:31:16

标签: openssl x509certificate x509 pkcs#7

我想使用C / CPP从PKCS#7签名代码图像中提取签名者信息。我想知道openssl API。 I am Able to extract Using bouncy castle (CMSSignedData)

请告诉我openssl API,我可以在C / CPP中使用它来提取每个签名者和签名者信息并验证签名者。

有没有像X509_LOOKUP_buffer()那样的API而不是X509_LOOKUP_file()???

先谢谢opensid

1 个答案:

答案 0 :(得分:0)

我有类似的问题。我不得不从PKCS#7签名中提取signedTime属性。我无法在互联网上找到最终的解决方案,但我可以从各个地方获取零件和零件,并提出了这个问题。也许有更好/更好/更安全的方式,这是我第一次这样做,但似乎有效。

在一个函数中,我在一个缓冲区中有p_pkcs7SigSize字节的PKCS#7签名,指向const void * p_pkcs7Sig。我得到了签约时间。我已经删除了错误处理,请不要使用此代码详细!

BIO                         *v_in          = NULL;
PKCS7                       *v_p7          = NULL;
STACK_OF(PKCS7_SIGNER_INFO) *v_signerInfos = NULL;
PKCS7_SIGNER_INFO           *v_signerInfo  = NULL;
ASN1_TYPE                   *v_asn1SigningTime  = NULL;

/* make BIO for input buffer */
v_in = BIO_new_mem_buf( (void*)(uintptr_t) p_pkcs7Sig, p_pkcs7SigSize );

/* make a PKCS7 object of it */
v_p7 = d2i_PKCS7_bio( v_in, NULL);

/* get all signer infos */
v_signerInfos = PKCS7_get_signer_info( v_p7 );

/* if you need all signer infos then loop through all, 
 * count you get by k_PKCS7_SIGNER_INFO_num(v_signerInfos) 
 */

/* get the first signer info */
v_signerInfo = sk_PKCS7_SIGNER_INFO_value(v_signerInfos,0);

/* get signing time */
v_asn1SigningTime = PKCS7_get_signed_attribute( v_signerInfo, NID_pkcs9_signingTime );

/* You should got a v_asn1SigningTime->type == V_ASN1_UTCTIME, 
 * if yes then the actual value is in the string buffer at
 * v_asn1SigningTime->value.utctime->data 
 */

if ( v_in )
{
   BIO_free_all( v_in );
   v_in = NULL;
}