我遇到了关于BIO *到PKCS7 *转换的问题。我想调用PKCS7_decrypt()函数来解密密文。在此之前,我有这部分代码:
in = BIO_new_mem_buf(chEnc, iLength);
if (!in) {
fprintf(stderr, "\nError in BIO_new_mem_buf in verifyEC. STDERR: ");
ERR_print_errors_fp(stderr);
return 0;
}
p7 = d2i_PKCS7_bio(in, NULL);
if (!p7) {
fprintf(stderr, "Error in d2i_PKCS7_bio.\n");
ERR_print_errors_fp(stderr);
return 0;
}
d2i_PKCS7_bio()始终失败并返回此错误消息:
140172957116064:错误:0D0680A8:asn1编码例程:ASN1_CHECK_TLEN:错误标记:tasn_dec.c:1319: 140172957116064:错误:0D07803A:asn1编码例程:ASN1_ITEM_EX_D2I:嵌套asn1错误:tasn_dec.c:381:Type = PKCS7
知道怎么解决吗?这是编码导致的问题吗?还是转换问题?
提前致谢
答案 0 :(得分:0)
这可能是由于错误的输入格式: d2i_PKCS7_bio期望二进制文件PKCS7。
另一方面,如果你的输入是pem格式,你应该改为调用PEM_read_bio_PKCS7。