SignByCert (Transact-SQL)

Подписывает текст сертификатом и возвращает подпись.

Синтаксис

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

Аргументы

  • certificate_ID
    Идентификатор сертификата в текущей базе данных. int.
  • @cleartext
    Переменная типа nvarchar, char, varchar или nchar, содержащая данные, которые будут подписаны.
  • 'password'
    Пароль, при помощи которого был зашифрован закрытый ключ сертификата. nvarchar(128).

Типы возвращаемых данных

varbinary с максимальным размером 8 000 байт.

Замечания

Требует разрешения CONTROL для сертификата.

Примеры

В следующем примере текст переменной @SensitiveData подписывается сертификатом ABerglundCert07 после расшифровки сертификата с помощью пароля «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