怎么加密sql中的表

這篇文章運(yùn)用簡(jiǎn)單易懂的例子給大家介紹怎么加密sql中的表,代碼非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序定制開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了相城免費(fèi)建站歡迎大家使用!

sql加密表的方法是:首先測(cè)試環(huán)境然后再創(chuàng)建數(shù)據(jù)庫(kù)主密鑰,之后創(chuàng)建證書(shū)以及創(chuàng)建一個(gè)對(duì)稱秘鑰,最后加密數(shù)據(jù)。

sql server 怎么設(shè)置表中加密

SQL Server支持?jǐn)?shù)據(jù)庫(kù)級(jí)的加密(TDE)和列級(jí)的數(shù)據(jù)加密,數(shù)據(jù)庫(kù)級(jí)的加密是在在數(shù)據(jù)庫(kù)中進(jìn)行的,對(duì)程序來(lái)說(shuō)是是透明的,開(kāi)發(fā)過(guò)程中不需要做額外的操作。相對(duì)數(shù)據(jù)庫(kù)級(jí)的加密來(lái)說(shuō),列級(jí)的數(shù)據(jù)加密過(guò)程有點(diǎn)麻煩,程序需要做一些額外的操作。下圖是SQL Server的加密層次結(jié)構(gòu),可以看出SQL Server的加密是分層級(jí)的,上面層級(jí)的加密保護(hù)其子層級(jí)的加密,本文說(shuō)明一個(gè)使用圖中①②③④四個(gè)層次的方法來(lái)加密/解密數(shù)據(jù)的過(guò)程。

怎么加密sql中的表

(1)測(cè)試環(huán)境說(shuō)明

測(cè)試使用SQL Servre 2012 R2,創(chuàng)建如下的數(shù)據(jù)表:

--創(chuàng)建測(cè)試用的用戶表

CREATE TABLE TBLUser 
(    
    Name             nvarchar(30),     
    Password         varbinary(1000),    
)
GO

怎么加密sql中的表

(2)創(chuàng)建數(shù)據(jù)庫(kù)主密鑰

數(shù)據(jù)庫(kù)主密鑰(Database Master Key)在服務(wù)主密鑰之下,由服務(wù)主密鑰進(jìn)行加密。這是一個(gè)數(shù)據(jù)庫(kù)級(jí)別的密鑰,可以用于為創(chuàng)建數(shù)據(jù)庫(kù)級(jí)別的證書(shū)或非對(duì)稱密鑰提供加密。每一個(gè)數(shù)據(jù)庫(kù)只能有一個(gè)數(shù)據(jù)庫(kù)主密鑰,通過(guò)T-SQL語(yǔ)句創(chuàng)建。具體代碼如下:

CREATE MASTER KEY ENCRYPTION BY PASSWORD ='passW@ord'
GO

怎么加密sql中的表

(3)創(chuàng)建證書(shū)

創(chuàng)建一個(gè)用來(lái)加密對(duì)稱秘鑰證書(shū),具體代碼如下:

CREATE CERTIFICATE TestCert with SUBJECT = 'Test Certificate'
GO

怎么加密sql中的表

(4)創(chuàng)建一個(gè)對(duì)稱秘鑰

由SQL Server加密層次結(jié)構(gòu)可以看出,對(duì)稱密鑰可以通過(guò)密碼創(chuàng)建,也可以通過(guò)其它對(duì)稱密鑰、非對(duì)稱密鑰和證書(shū)創(chuàng)建。本文以證書(shū)創(chuàng)建一個(gè)測(cè)試用的對(duì)稱秘鑰,具體代碼如下:

CREATE SYMMETRIC KEY TestSymmetric WITH ALGORITHM = AES_256
 ENCRYPTION BY CERTIFICATE TestCert 
GO

怎么加密sql中的表

(5)加密數(shù)據(jù)

先打開(kāi)證對(duì)稱秘鑰,再使用ENCRYPTBYKEY函數(shù)加密數(shù)據(jù),完成后關(guān)閉對(duì)稱秘鑰。具體代碼如下:

OPEN SYMMETRIC KEY TestSymmetric DECRYPTION BY CERTIFICATE TestCert;
INSERT INTO TBLUser values('張三', ENCRYPTBYKEY(Key_Guid(N'TestSymmetric'), '123456'));
CLOSE SYMMETRIC KEY TestSymmetric;
GO

怎么加密sql中的表

(6)查看加密后的數(shù)據(jù)

直接下SQL查詢加密后的數(shù)據(jù),可以看到password的內(nèi)容是一串不可以閱讀的16進(jìn)制的字符。

SELECT * FROM TBLUser
GO

怎么加密sql中的表

(7)解密數(shù)據(jù)

先打開(kāi)證對(duì)稱秘鑰,再使用DecryptByKey函數(shù)解密數(shù)據(jù),完成后關(guān)閉對(duì)稱秘鑰。具體代碼如下:

OPEN SYMMETRIC KEY TestSymmetric DECRYPTION BY CERTIFICATE TestCert;
SELECT Name, CAST(DecryptByKey(password) as varchar(100)) Password FROM TBLUser;
CLOSE SYMMETRIC KEY TestSymmetric;
GO

怎么加密sql中的表

關(guān)于怎么加密sql中的表就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

當(dāng)前題目:怎么加密sql中的表
URL網(wǎng)址:http://muchs.cn/article20/iehsjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、營(yíng)銷型網(wǎng)站建設(shè)用戶體驗(yàn)、ChatGPT、虛擬主機(jī)、服務(wù)器托管

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化