本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
NCryptSignHash 使用密钥存储提供商 (KSP)
该NCryptSignHash函数创建哈希值的签名。
参数
-
hKey[输入] -
用于对哈希进行签名的密钥的句柄。
pPaddingInfo[输入,可选]-
指向包含填充信息的结构的指针。结构类型取决于
dwFlags值。仅对非对称密钥使用此参数;对于其他密钥类型,请将其设置为 NULL。 pbHashValue[输入]-
指向包含待签哈希值的缓冲区的指针。使用指定缓冲区大小
cbHashValue。 cbHashValue[输入]-
待签名的
pbHashValue缓冲区的大小(以字节为单位)。 pbSignature[出局]-
用于存储签名的缓冲区的地址。使用指定缓冲区大小
cbSignature。要确定所需的缓冲区大小,请将此参数设置为 NULL。该函数将所需的大小(以字节为单位)存储在所指向的位置
pcbResult。 cbSignature[输入]-
pbSignature缓冲区的大小(以字节为单位)。如果pbSignature为 NULL,则该函数将忽略此参数。 pcbResult[出局]-
指向 DWORD 变量的指针,该变量存储复制到
pbSignature缓冲区的字节数。如果
pbSignature为 NULL,则存储所需的缓冲区大小(以字节为单位)。 dwFlags[输入]-
用于修改函数行为的标志。允许的标志取决于您的密钥类型。使用以下值之一:
值 含义 bcrypt_pad_ PKCS1
使用填 PKCS1 充方案。设置
pPaddingInfo为指向BCRYPT_PKCS1_PADDING_INFO结构。BCRYPT_PAD_PSS
使用概率签名方案 (PSS) 填充方案。将
pPaddingInfo参数设置为指向BCRYPT_PSS_PADDING_INFO结构。NCRYPT_SILENT_FLAG
此标志无效。
返回值
该函数返回指示成功或失败的状态码。
常见的返回码包括:
| 返回代码 | 描述 |
|---|---|
|
错误_成功 |
操作成功完成。 |
|
NTE_INVALID_PARAMETER |
一个或多个参数无效。 |
|
NTE_FAIL |
操作无法完成。 |
|
NTE_INVALID_HANDLE |
中的句柄 |
|
NTE_BAD_FLAGS |
该 |
|
NTE_BUFFER_TOO_SMALL |
该 |
|
NTE_BAD_KEY_STATE |
密钥状态无效。 |
|
NTE_INTERNAL_ERROR |
对哈希进行签名时发生内部错误。 |