我试图在证书上设置友好姓名,因为我用以下代码将证书存放在一台机器上:
CRYPT_DATA_BLOB fName = {_tcslen(FriendlyName) * sizeof(TCHAR), FriendlyName};
CertSetCertificateContextProperty(certContext, CERT_FRIENDLY_NAME_PROP_ID, 0, &fName));
当友好名称是一个指向友好名称和 CentContext 的 LPWSTR 时, 显然友好名称是一个指向友好名称和 CertContext 的 LPWSTR 是保存仓库证书的有效证书背景。 函数工作正确, 名称被写入证书中。 但是, 当我在证书 shun- in 中看到它时, 名称的最后字母被短写了 。 我尝试过在名称长度上添加一个字, 最后将名称剪切成两半。 我检查了友好名称和长度以确保它们正确和正确。 如果我将友好名称改成 LPSTR, 它会显示为 Kanjii 字符 。 在微软提供的示例中, 它们会做以下操作 :
BYTE *pName = (BYTE *)"Temp Name.";
CRYPT_DATA_BLOB Friendly_Name_Blob={32,pName};
我不知道他们从哪弄来的32个,他们也没有提供我可以找到的解释。当我用32个时,它再次删除了名字。知道我做错了什么以及如何纠正它吗?