VerifySignedByAsymKey (Transact-SQL)
測試數位簽署的資料在簽署之後是否已經變更。
語法
VerifySignedByAsymKey( Asym_Key_ID , clear_text , signature )
引數
Asym_Key_ID
這是資料庫中的非對稱金鑰憑證識別碼。clear_text
這是正在驗證的純文字資料。signature
這是附加在已簽署資料中的簽章。signature 是 varbinary。
傳回類型
int
簽章符合時傳回 1,否則傳回 0。
備註
VerifySignedByAsymKey 會使用指定之非對稱金鑰的公開金鑰解密資料的簽章,並比較解密值與新計算的資料 MD5 雜湊。如果值相符,簽章將確認為有效。
權限
需要非對稱金鑰的 VIEW DEFINITION 權限。
範例
A. 測試含有效簽章的資料
如果所選的資料在以非對稱金鑰 WillisKey74 簽署之後尚未變更,則下列範例會傳回 1。如果資料已被竄改,則下列範例會傳回 0。
SELECT Data,
VerifySignedByAsymKey( AsymKey_Id( 'WillisKey74' ), SignedData,
DataSignature ) as IsSignatureValid
FROM [Adventureworks].[SignedData04]
WHERE Description = N'data encrypted by asymmetric key ''WillisKey74'''
GO
RETURN
B. 傳回包含含有效簽章之資料的結果集
下列範例會傳回 SignedData04 中的資料列,它們包含自從以非對稱金鑰 WillisKey74 簽署之後尚未變更的資料。這個範例會呼叫函數 AsymKey_ID,從資料庫取得非對稱金鑰的識別碼。
SELECT Data
FROM [Adventureworks].[SignedData04]
WHERE VerifySignedByAsymKey( AsymKey_Id( 'WillisKey74' ), Data,
DataSignature ) = 1
AND Description = N'data encrypted by asymmetric key ''WillisKey74'''
GO