SignByCert (Transact-SQL)

使用证书对文本进行签名并返回签名。

语法

SignByCert( certificate_ID, @cleartext [,'password' ] )

参数

  • certificate_ID
    当前数据库中证书的 ID。 int.
  • @cleartext
    类型为 nvarcharcharvarcharnchar 的变量,其中包含将要签署的数据。
  • 'password'
    用来对证书私钥进行加密的密码。nvarchar(128)

返回类型

最大大小为 8,000 个字节的 varbinary

备注

需要对证书具有 CONTROL 权限。

示例

以下示例将用证书 ABerglundCert07 来签署 @SensitiveData 中的文本,该证书已用密码“pGFD4bb925DGvbd2439587y”进行解密。然后,它在 SignedData04 表中插入明文和签名。

DECLARE @SensitiveData nvarchar(max);
SET @SensitiveData = N'Saddle Price Points are 
    2, 3, 5, 7, 11, 13, 17, 19, 23, 29';
INSERT INTO [SignedData04]
    VALUES( N'data signed by certificate ''ABerglundCert07''',
    @SensitiveData, SignByCert( Cert_Id( 'ABerglundCert07' ), 
    @SensitiveData, N'pGFD4bb925DGvbd2439587y' ));
GO

请参阅

参考

VerifySignedByCert (Transact-SQL)
Cert_ID (Transact-SQL)
CREATE CERTIFICATE (Transact-SQL)
ALTER CERTIFICATE (Transact-SQL)
DROP CERTIFICATE (Transact-SQL)

其他资源

加密层次结构

帮助和信息

获取 SQL Server 2005 帮助