共用方式為


VerifySignedByCert (Transact-SQL)

測試數位簽署的資料是否已經在簽署之後變更。

主題連結圖示Transact-SQL 語法慣例

語法

VerifySignedByCert( Cert_ID , signed_data , signature )

引數

  • Cert_ID
    這是資料庫中的憑證識別碼。 int
  • signed_data
    這是 nvarcharcharvarcharnchar 類型的變數,其中包含已經利用憑證加以簽署的資料。
  • signature
    這是附加在已簽署資料中的簽章。 varbinary.

傳回類型

int

如果已簽署的資料不變,則傳回 1,否則傳回 0。

備註

VerifySignedByCert 利用儲存在資料庫的憑證,從先前簽署的資料衍生簽章。VerifySignedByCert 會將新衍生的簽章,與在擷取資料時附加在簽署資料後面的簽章互相比較。如果新衍生的簽章,與附加在簽署資料的簽章一樣,就證明資料在簽署之後沒有變更。簽章計算是以正在進行確認之模組中的所有字元為基礎,這些字元包括開頭空白、尾端空白、歸位字元 (Carriage Return) 和換行字元 (Line Feed) 等。

權限

需要憑證的 VIEW DEFINITION 權限。

範例

A. 驗證簽署的資料尚未遭到竄改

下列範例會測試 Signed_Data 中的資訊,在利用名為 Shipping04 的憑證簽署之後,是否已經變更。簽章是儲存在 DataSignature 中。憑證 (Shipping04) 會傳遞至 Cert_ID,後者則會傳回資料庫中的憑證識別碼。如果 VerifySignedByCert 傳回 1,表示簽章正確。如果 VerifySignedByCert 傳回 0,表示 Signed_Data 中的資料,並不是產生 DataSignature 所用的資料。在本例中,表示 Signed_Data 在簽署之後已經變更,或者 Signed_Data 是以不同的憑證簽署的。

SELECT Data, VerifySignedByCert( Cert_Id( 'Shipping04' ),
    Signed_Data, DataSignature ) AS IsSignatureValid
FROM [AdventureWorks].[SignedData04] 
WHERE Description = N'data signed by certificate ''Shipping04''';
GO

B. 只傳回具有有效簽章的記錄

這項查詢只會傳回自從使用憑證 Shipping04 簽署之後尚未變更的記錄。

SELECT Data FROM [AdventureWorks].[SignedData04] 
WHERE VerifySignedByCert( Cert_Id( 'Shipping04' ), Data, 
    DataSignature ) = 1 
AND Description = N'data signed by certificate ''Shipping04''';
GO

請參閱

參考

Cert_ID (Transact-SQL)
SignByCert (Transact-SQL)
CREATE CERTIFICATE (Transact-SQL)
ALTER CERTIFICATE (Transact-SQL)
DROP CERTIFICATE (Transact-SQL)
BACKUP CERTIFICATE (Transact-SQL)

其他資源

加密階層

說明及資訊

取得 SQL Server 2005 協助