這篇文章運用簡單易懂的例子給大家介紹怎么加密sql中的表,代碼非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序定制開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了相城免費建站歡迎大家使用!
sql加密表的方法是:首先測試環(huán)境然后再創(chuàng)建數(shù)據(jù)庫主密鑰,之后創(chuàng)建證書以及創(chuàng)建一個對稱秘鑰,最后加密數(shù)據(jù)。
sql server 怎么設(shè)置表中加密
SQL Server支持數(shù)據(jù)庫級的加密(TDE)和列級的數(shù)據(jù)加密,數(shù)據(jù)庫級的加密是在在數(shù)據(jù)庫中進行的,對程序來說是是透明的,開發(fā)過程中不需要做額外的操作。相對數(shù)據(jù)庫級的加密來說,列級的數(shù)據(jù)加密過程有點麻煩,程序需要做一些額外的操作。下圖是SQL Server的加密層次結(jié)構(gòu),可以看出SQL Server的加密是分層級的,上面層級的加密保護其子層級的加密,本文說明一個使用圖中①②③④四個層次的方法來加密/解密數(shù)據(jù)的過程。
(1)測試環(huán)境說明
測試使用SQL Servre 2012 R2,創(chuàng)建如下的數(shù)據(jù)表:
--創(chuàng)建測試用的用戶表
CREATE TABLE TBLUser ( Name nvarchar(30), Password varbinary(1000), ) GO
(2)創(chuàng)建數(shù)據(jù)庫主密鑰
數(shù)據(jù)庫主密鑰(Database Master Key)在服務(wù)主密鑰之下,由服務(wù)主密鑰進行加密。這是一個數(shù)據(jù)庫級別的密鑰,可以用于為創(chuàng)建數(shù)據(jù)庫級別的證書或非對稱密鑰提供加密。每一個數(shù)據(jù)庫只能有一個數(shù)據(jù)庫主密鑰,通過T-SQL語句創(chuàng)建。具體代碼如下:
CREATE MASTER KEY ENCRYPTION BY PASSWORD ='passW@ord' GO
(3)創(chuàng)建證書
創(chuàng)建一個用來加密對稱秘鑰證書,具體代碼如下:
CREATE CERTIFICATE TestCert with SUBJECT = 'Test Certificate' GO
(4)創(chuàng)建一個對稱秘鑰
由SQL Server加密層次結(jié)構(gòu)可以看出,對稱密鑰可以通過密碼創(chuàng)建,也可以通過其它對稱密鑰、非對稱密鑰和證書創(chuàng)建。本文以證書創(chuàng)建一個測試用的對稱秘鑰,具體代碼如下:
CREATE SYMMETRIC KEY TestSymmetric WITH ALGORITHM = AES_256 ENCRYPTION BY CERTIFICATE TestCert GO
(5)加密數(shù)據(jù)
先打開證對稱秘鑰,再使用ENCRYPTBYKEY函數(shù)加密數(shù)據(jù),完成后關(guān)閉對稱秘鑰。具體代碼如下:
OPEN SYMMETRIC KEY TestSymmetric DECRYPTION BY CERTIFICATE TestCert; INSERT INTO TBLUser values('張三', ENCRYPTBYKEY(Key_Guid(N'TestSymmetric'), '123456')); CLOSE SYMMETRIC KEY TestSymmetric; GO
(6)查看加密后的數(shù)據(jù)
直接下SQL查詢加密后的數(shù)據(jù),可以看到password的內(nèi)容是一串不可以閱讀的16進制的字符。
SELECT * FROM TBLUser GO
(7)解密數(shù)據(jù)
先打開證對稱秘鑰,再使用DecryptByKey函數(shù)解密數(shù)據(jù),完成后關(guān)閉對稱秘鑰。具體代碼如下:
OPEN SYMMETRIC KEY TestSymmetric DECRYPTION BY CERTIFICATE TestCert; SELECT Name, CAST(DecryptByKey(password) as varchar(100)) Password FROM TBLUser; CLOSE SYMMETRIC KEY TestSymmetric; GO
關(guān)于怎么加密sql中的表就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。