您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“SQLServer2008中的非對稱密鑰加密有什么用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“SQLServer2008中的非對稱密鑰加密有什么用”吧!
SQLServer2008中非對稱密鑰加密有什么用
我們看一組例子:
示例一、創(chuàng)建非對稱密鑰
創(chuàng)建非對稱密鑰使用如下命令:
CREATEASYMMETRICKEY創(chuàng)建非對稱密鑰。(http://msdn.microsoft.com/en-us/library/ms174430.aspx)
viewplaincopytoclipboardprint
示例二、查看當(dāng)前數(shù)據(jù)庫中的非對稱密鑰
使用目錄視圖sys.asymmetric_keys(http://msdn.microsoft.com/en-us/library/ms188399.aspx)來查看。
viewplaincopytoclipboardprint
示例三、修改非對稱密鑰的私鑰密碼
你可以使用帶有ENCRYPTIONBYPASSWORD和DECRYPTIONBYPASSWORD選項的ALTERASYMMETRICKEY(http://technet.microsoft.com/en-us/library/ms189440.aspx)修改私鑰的密碼。
viewplaincopytoclipboardprint
--修改私鑰密碼
ALTERASYMMETRICKEYasymDemoKey--要修改的密鑰名稱
WITHPRIVATEKEY--私鑰
(ENCRYPTIONBYPASSWORD='newpasswordE4D352F280E0',--指定新密碼
DECRYPTIONBYPASSWORD='TestASYM123!')--舊密碼是用來解密的
--修改私鑰密碼
ALTERASYMMETRICKEYasymDemoKey--要修改的密鑰名稱
WITHPRIVATEKEY--私鑰
(ENCRYPTIONBYPASSWORD='newpasswordE4D352F280E0',--指定新密碼
DECRYPTIONBYPASSWORD='TestASYM123!')--舊密碼是用來解密的
示例四、使用非對稱密鑰對數(shù)據(jù)進行加密和解密。
由于同時需要公鑰和密鑰,在維護保密數(shù)據(jù)時使用非對稱密鑰來加密數(shù)據(jù)是非常安全的方式。但同時用于大數(shù)據(jù)集時將消耗更多的資源。
不推薦使用非對稱密鑰對數(shù)據(jù)加密,但它仍然是一個選擇。一旦將非對稱密鑰加到數(shù)據(jù)庫,就可以用來加密和解密數(shù)據(jù)。
用到以下兩個sql函數(shù):
EncryptByAsymKey加密數(shù)據(jù)。(http://technet.microsoft.com/en-us/library/ms186950.aspx)
DecryptByAsymKey解密數(shù)據(jù)。(http://msdn.microsoft.com/en-us/library/ms189507.aspx)
注意,在通過證書加密時,DecryptByAsymKey返回的是varbinary類型的加密數(shù)據(jù)。
下面是一個例子:
viewplaincopytoclipboardprint
useDB_Encrypt_Demo
go
--創(chuàng)建需要加密的數(shù)據(jù)
CreateTableBankUser
(PKIDintprimarykeyidentity(10001,1)
,UserNovarbinary(1000)null
,CurStatesmallintdefault(0)notnull
)
go
insertintoBankUser
(UserNo,CurState)
VALUES(EncryptByAsymKey(AsymKey_ID('asymDemoKey'),'137492837583249ABR'),1)
--插入一條記錄,字段UserNo存儲了加密的號碼值
go
selectPKID,Curstate,cast(UserNoasnvarchar(1000))asUserNo
fromBankUser
wherePKID=10001
useDB_Encrypt_Demo
go
--創(chuàng)建需要加密的數(shù)據(jù)
CreateTableBankUser
(PKIDintprimarykeyidentity(10001,1)
,UserNovarbinary(1000)null
,CurStatesmallintdefault(0)notnull
)
go
insertintoBankUser
(UserNo,CurState)
VALUES(EncryptByAsymKey(AsymKey_ID('asymDemoKey'),'137492837583249ABR'),1)
--插入一條記錄,字段UserNo存儲了加密的號碼值
go
selectPKID,Curstate,cast(UserNoasnvarchar(1000))asUserNo
fromBankUser
wherePKID=10001
SQLServer2008中非對稱密鑰加密有什么用
明文結(jié)果:
查看未加密的數(shù)據(jù):
viewplaincopytoclipboardprint
SELECTPKID,Curstate,
cast
(DecryptByAsymKey(AsymKey_ID('asymDemoKey'),UserNo,N'newpasswordE4D352F280E0')
asvarchar(1000))asUserNo--需要原始私鑰
fromBankUserwherePKID=10001
SELECTPKID,Curstate,
cast
(DecryptByAsymKey(AsymKey_ID('asymDemoKey'),UserNo,N'newpasswordE4D352F280E0')
asvarchar(1000))asUserNo--需要原始私鑰
fromBankUserwherePKID=10001
示例五、刪除非對稱密鑰
命令:DROPASYMMETRICKEY刪除指定的非對稱密鑰(http://msdn.microsoft.com/en-us/library/ms188389.aspx)
例子:
viewplaincopytoclipboardprint
DROPASYMMETRICKEYasymDemoKey
DROPASYMMETRICKEYasymDemoKey
到此,相信大家對“SQLServer2008中的非對稱密鑰加密有什么用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。