Sql Server數(shù)據(jù)庫實現(xiàn)表中字段的列加密
1、問題描述
去年6月份的時候做過一個系統(tǒng),要對里面的一些敏感字段進行一下加密。Sqlserver列加密可以參考官方文檔:SQL Server 技術(shù)文檔 - SQL Server | Microsoft Learn。主要看下來有三種加密方法:1、利用證書對數(shù)據(jù)進行加密和解密。2、利用非對稱密鑰對數(shù)據(jù)進行加密和解密。3、利用對稱密鑰對數(shù)據(jù)進行加密和解密。
2、加密方法介紹
2.1、證書加密(推薦)
2.1.1、創(chuàng)建證書
use mydb; --查看數(shù)據(jù)庫中的證書 select * from sys.certificates; --創(chuàng)建數(shù)據(jù)庫主密鑰 CREATE MASTER KEY ENCRYPTION BY PASSWORD ='123@#456'; --創(chuàng)建證書 CREATE CERTIFICATE MyCert with SUBJECT = 'My Test Certificate' GO --創(chuàng)建證書并授權(quán)給指定用戶(zhangsan) CREATE CERTIFICATE MyCertToZhangSan AUTHORIZATION zhangsan with SUBJECT = 'My Test Certificate To ZhangSan' GO
2.1.2、使用證書加解密
創(chuàng)建一個測試表
--創(chuàng)建測試表TUser_test_Cert,要對pwd字段進行加密因此其字段類型設(shè)為varbinary --varbinary表示可變長度二進制數(shù)據(jù),但是在sqlserver表存放是以十六進制存的。 create table TUser_test_Cert(username varchar(50),pwd varbinary(2000));
在2.1.1環(huán)節(jié)一共建了兩個證書,MyCert這個證書是公用的,而MyCertToZhangSan這個證書是僅限zhangsan這個用戶可以使用!
使用MyCert證書加解密
--使用MyCert證書加密pwd字段 insert into TUser_test_Cert(username,pwd) values('liming', ENCRYPTBYCERT( CERT_ID('MyCert') ,'112233' ) ); select * from TUser_test_Cert; --使用MyCert證書解密pwd字段 select username,CONVERT( varchar(100), DecryptByCert ( CERT_ID('MyCert'),pwd ) ) as pwd from TUser_test_Cert;
使用MyCertToZhangSan證書進行加解密
因為我是對mydb數(shù)據(jù)庫進行證書加解密嘛!因此首先要確保mydb下是否有zhangsan這個用戶!有了zhangsan這個用戶才能創(chuàng)建證書并對其AUTHORIZATION
有個地方要提一下,這里的zhangsan這個用戶是在mydb下的,并不是直接在mydb下直接手動創(chuàng)建的,而是整個sqlserver登錄名zhangsan映射到mydb的一個用戶映射!
其實就是在你新建數(shù)據(jù)庫登錄名的時候做的一個用戶映射,相當于授權(quán)這個登錄名可以有哪些數(shù)據(jù)庫的權(quán)限了!
不過此時mydb新加的zhangsan這個用戶還沒有給他分配角色(所謂角色就是權(quán)限集合)
--創(chuàng)建一個角色zhangsan_role create role zhangsan_role; --給zhangsan_role這個角色分配TUser_test_Cert表的增刪改查權(quán)限 grant select,update,insert,delete on TUser_test_Cert to zhangsan_role;
在mydb里用戶選擇zhangsan右鍵屬性,在成員身份里選中zhangsan_role就行了!
--使用MyCertToZhangSan證書加密pwd字段 insert into TUser_test_Cert(username,pwd) values('zhangsan', ENCRYPTBYCERT( CERT_ID('MyCertToZhangSan') ,'666333' ) ); select * from TUser_test_Cert; --使用MyCert證書解密pwd字段 select username,CONVERT( varchar(100), DecryptByCert ( CERT_ID('MyCertToZhangSan'),pwd ) ) as pwd from TUser_test_Cert;
2.2、非對稱密鑰加解密
----利用非對稱密鑰對數(shù)據(jù)進行加密和解密--- --查看數(shù)據(jù)庫中的非對稱密鑰 select * from sys.asymmetric_keys; --創(chuàng)建非對稱密鑰 CREATE ASYMMETRIC KEY MyTestAsymmetric WITH ALGORITHM = RSA_2048 ENCRYPTION BY PASSWORD = '%^&123%456'; GO insert into TUser_test_Cert(username,pwd) values('ssan', EncryptByAsymKey( ASYMKEY_ID('MyTestAsymmetric') ,'112233' ) ); select * from TUser_test_Cert; select username,CONVERT( varchar(100), DecryptByAsymKey ( ASYMKEY_ID('MyTestAsymmetric'),pwd,N'%^&123%456' ) ) as pwd from TUser_test_Cert;
2.3、對稱密鑰加解密
----利用對稱密鑰對數(shù)據(jù)進行加密和解密---- --查看數(shù)據(jù)庫中的對稱密鑰 select * from sys.symmetric_keys; --創(chuàng)建對稱密鑰 CREATE SYMMETRIC KEY MyTestSymmetric WITH ALGORITHM = AES_256 ENCRYPTION BY PASSWORD = '123456@aes'; GO --打開密鑰并進行加密/解密(只有對稱加密需打開密鑰?。。。? open symmetric key MyTestSymmetric decryption by password='123456@aes'; insert into TUser_test_Cert(username,pwd) values('qianqian', EncryptByKey(Key_GUID('MyTestSymmetric'), 'qw123sa') ); select * from TUser_test_Cert; select username,CONVERT( varchar(100), DECRYPTBYKEY(pwd) ) as pwd from TUser_test_Cert
3、總結(jié)
Sqlserver數(shù)據(jù)庫列字段加密推薦使用證書加密,使用證書加密是對特定的賬號授予他們使用證書加解密的權(quán)限,他們只是用了證書的cert_id,并不會涉及password密鑰。但如果使用其他方法加密的話,比如AES,RSA的話,那么在加解密的時候會把密鑰暴露給開發(fā)人員
所以就不太安全!用證書的話就不會把密碼暴露給開發(fā)人員,只暴露給特定的賬戶!
4、參考資料
創(chuàng)建數(shù)據(jù)庫主密鑰 - SQL Server | Microsoft Learn
SQL Server 數(shù)據(jù)庫對稱加密_QAQ_的博客-CSDN博客
AES加密算法的詳細介紹與實現(xiàn)_TimeShatter的博客-CSDN博客_aes
SQLSERVER加密解密函數(shù)(非對稱密鑰 證書加密 對稱密鑰)_weixin_33877092的博客-CSDN博客
獲取所有用戶名 sql server_jgwei的博客-CSDN博客_sqlserver 查看數(shù)據(jù)庫所有用戶名
[轉(zhuǎn)]【SQLServer】獲取SQL Server數(shù)據(jù)庫用戶名、數(shù)據(jù)庫名、所有表名、所有字段名_liujzss的博客-CSDN博客
SQL Server 創(chuàng)建登錄名和用戶名【詳細介紹】_Henry_626的博客-CSDN博客_sqlserver新建登錄名
到此這篇關(guān)于Sql Server數(shù)據(jù)庫實現(xiàn)表中字段的列加密的文章就介紹到這了,更多相關(guān)Sql 列加密內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
數(shù)據(jù)庫觸發(fā)器DB2和SqlServer有哪些區(qū)別
大部分數(shù)據(jù)庫語句的基本語法是相同的,但具體到的每一種數(shù)據(jù)庫,又有些不一樣,例如觸發(fā)器,DB2和SQL Server兩種很大的不同。對數(shù)據(jù)庫觸發(fā)器DB2和SqlServer有哪些區(qū)別感興趣的朋友一起看看本文吧2015-11-11SQL Server實現(xiàn)顯示每個類別最新更新數(shù)據(jù)的方法
這篇文章主要介紹了SQL Server實現(xiàn)顯示每個類別最新更新數(shù)據(jù)的方法,涉及SQL Server數(shù)據(jù)庫Select查詢操作使用技巧,需要的朋友可以參考下2017-03-03如何創(chuàng)建支持FILESTREAM的數(shù)據(jù)庫示例探討
FILESTREAM使用一種特殊類型的文件組,因此在創(chuàng)建數(shù)據(jù)庫時,必須至少為一個文件組指定 CONTAINS FILESTREAM 子句接下來為你詳細介紹下如何創(chuàng)建支持 FILESTREAM 的數(shù)據(jù)庫2013-03-03MSsql每天自動備份數(shù)據(jù)庫并每天自動清除log的腳本
有自己服務(wù)器的朋友需要用到的東西,因為mssql數(shù)據(jù)需要經(jīng)常備份2008-09-09