共用方式為


DECRYPTBYPASSPHRASE (Transact-SQL)

將以密碼片語加密的資料解密。

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

語法

DecryptByPassPhrase ( { 'passphrase' | @passphrase } 
        , { 'ciphertext' | @ciphertext }
    [ , { add_authenticator | @add_authenticator }
        , { authenticator | @authenticator } ] )

引數

  • passphrase
    這是要用來產生解密金鑰的密碼片語。

  • @passphrase
    這是 nvarchar、char、varchar 或 nchar 類型的變數,其中包含用來產生解密金鑰的密碼片語。

  • 'ciphertext'
    這是要解密的加密文字。

  • @ciphertext
    這是包含加密文字之 varbinary 類型的變數。大小上限是 8,000 位元組。

  • add_authenticator
    指出驗證器是否要與純文字一起加密。如果使用驗證器,則為 1。int.

  • @add_authenticator
    指出驗證器是否要與純文字一起加密。如果使用驗證器,則為 1。int.

  • authenticator
    這是驗證器資料。sysname.

  • @authenticator
    這是含有要衍生驗證器之資料的變數。

傳回類型

varbinary,大小上限為 8,000 位元組。

備註

執行這個函數不需要任何權限。

如果使用錯誤的密碼片語或驗證器資訊,則傳回 NULL。

密碼片語是用來產生解密金鑰,它不會保存下來。

如果對加密文字進行加密時包含了驗證器,則解密時必須提供驗證器。如果在解密時提供的驗證器值不符合與資料一起加密的驗證器值,則解密會失敗。

範例

下列範例會將 EncryptByPassPhrase 中更新的記錄解密。

USE AdventureWorks2008R2;
-- Get the pass phrase from the user.
DECLARE @PassphraseEnteredByUser nvarchar(128);
SET @PassphraseEnteredByUser 
= 'A little learning is a dangerous thing!';

-- Decrypt the encrypted record.
SELECT CardNumber, CardNumber_EncryptedbyPassphrase 
    AS 'Encrypted card number', CONVERT(nvarchar,
    DecryptByPassphrase(@PassphraseEnteredByUser, CardNumber_EncryptedbyPassphrase, 1 
    , CONVERT(varbinary, CreditCardID)))
    AS 'Decrypted card number' FROM Sales.CreditCard 
    WHERE CreditCardID = '3681';
GO