日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SQL Server 2005數據加密技術的實際應用

瀏覽:282日期:2023-11-05 12:10:10
本文將從應用程序開發者的角度探討基于SQL Server 2005數據加密特性的應用。

SQL Server 2005數據加密技術

數據用數字方式存儲在服務器中并非萬無一失。實踐證明有太多的方法可以智取SQL Server 2000認證保護,最簡單的是通過使用沒有口令的sa賬號。盡管SQL Server 2005遠比它以前的版本安全,但攻擊者還是有可能獲得存儲的數據。因此,數據加密成為更徹底的數據保護戰略,即使攻擊者得以存取數據,還不得不解密,因而對數據增加了一層保護。

SQL Server 2000以前的版本沒有內置數據加密功能,若要在SQL Server 2000中進行數據加密,不得不買第三家產品,然后在服務器外部作COM調用或者是在數據送服務器之前在客戶端的應用中執行加密。這意味著加密的密鑰或證書不得不由加密者自己負責保護,而保護密鑰是數據加密中最難的事,所以即使很多應用中數據已被很強的加密過,數據保護仍然很弱。

SQL Server 2005通過將數據加密作為數據庫的內在特性解決了這個問題。它除了提供多層次的密鑰和豐富的加密算法外,最大的好處是用戶可以選擇數據服務器管理密鑰。SQL Server 2005服務器支持的加密算法如下:

⑴ 對稱式加密(Symmetric Key Encryption):

對稱式加密方式對加密和解密使用相同的密鑰。通常,這種加密方式在應用中難以實施,因為用同一種安全方式共享密鑰很難。但當數據儲存在SQL Server中時,這種方式很理想,你可以讓服務器管理它。SQL Server 2005 提供RC4、RC2、DES 和 AES 系列加密算法。

⑵ 非對稱密鑰加密(Asymmetric Key Encryption):

非對稱密鑰加密使用一組公共/私人密鑰系統,加密時使用一種密鑰,解密時使用另一種密鑰。公共密鑰可以廣泛的共享和透露。當需要用加密方式向服務器外部傳送數據時,這種加密方式更方便。SQL Server 2005 支持 RSA 加密算法以及 512 位、1,024 位和 2,048 位的密鑰強度。

⑶ 數字證書(Certificate):

數字證書是一種非對稱密鑰加密,但是,一個組織可以使用證書并通過數字簽名將一組公鑰和私鑰與其擁有者相關聯。SQL Server 2005 支持“因特網工程工作組”(IETF) X.509 版本 3 (X.509v3) 規范。一個組織可以對 SQL Server 2005 使用外部生成的證書,或者可以使用 SQL Server 2005 生成證書。

SQL Server 2005 采用多級密鑰來保護它內部的密鑰和數據,如下圖所示:

SQL Server 2005數據加密技術的實際應用

圖1 SQL Server 2005采用多級密鑰保護它內部的密鑰和數據

圖中引出箭頭的密鑰或服務用于保護箭頭所指的密鑰。所以服務主密鑰(service master key)保護數據庫主密鑰(database master keys),而數據庫主密鑰又保護證書(certificates)和非對稱密鑰(asymmetric keys)。而最底層的對稱性密鑰(symmetric keys)被證書、非對稱密鑰或其他的對稱性密鑰保護(箭頭又指回它本身)。用戶只需通過提供密碼來保護這一系列的密鑰。

圖中頂層的服務主密鑰,安裝SQL Server 2005新實例時自動產生和安裝,用戶不能刪除此密鑰,但數據庫管理員能對它進行基本的維護,如備份該密鑰到一個加密文件,當其危及到安全時更新它,恢復它。

服務主密鑰由DPAPI(Data Protection API)管理。DPAPI在Windows 2000 中引入,建立于Windows的Crypt32 API之上。SQL Server 2005 管理與DPAPI的接口。服務主密鑰本身是對稱式加密,用來加密服務器中的數據庫主密鑰。

數據庫主密鑰與服務主密鑰不同,在加密數據庫中數據之前,必須由數據庫管理員創建數據庫主密鑰。通常管理員在產生該密鑰時,提供一個口令,所以它用口令和服務主密鑰來加密。如果有足夠的權限,用戶可以在需要時顯式地或自動地打開該密鑰。下面是產生數據庫主密鑰的T-SQL代碼示例:

USE EncryptionDB

CREATE MASTER KEY

ENCRYPTION BY PASSWORD = 'UTY6%djzZ8S7RyL'

每個數據庫只有一個數據庫主密鑰??梢杂肁LTER MASTR KEY語句來刪除加密,更改口令或刪除數據庫主密鑰。通常這由數據庫管理員來負責做這些。

有了數據庫主密鑰,就可以著手加密數據。T-SQL有置于其內的加密支持。使用CREATE語句創建各種密碼,ALTER語句修改他們。例如要創建對稱式加密,可以通過一對函數EncryptByKey 和 DecryptByKey來完成。

數據加密技術應用解析

下面通過實例來探討SQL Server 2005數據加密與解密技術的實現。

假設有一張Customer 表,表中有字段 customer ID、 name、 city 和各種信用卡細節。其中信用卡細節需要加密而其他數據不需要。假設User1有對稱式密鑰,并用該密鑰登錄,運行相應的代碼加密數據。

⑴ 數據加密

① 產生密鑰:在含有Customers 表的數據庫中使用Triple DES作為加密算法,生成對稱式密鑰。本例中,密鑰本身由已經存在在數據庫中的證書保護,如圖一所示,對稱密碼受非對稱密碼和存在的其他對稱式密鑰保護。

CREATE SYMMETRIC KEY User1SymmetricKeyCert

AUTHORIZATION User1

WITH ALGORITHM = TRIPLE_DES

ENCRYPTION BY CERTIFICATE User1Certificate

② 打開密鑰:對稱式密鑰使用前必須顯式打開,所以接下來打開它,重新找回密碼,解密它,并放它在受保護的服務器內存中,準備使用。

OPEN SYMMETRIC KEY User1SymmetricKeyCert

DECRYPTION BY CERTIFICATE User1Certificate

③ 加密數據:在下面的代碼中,使用正常的T-SQL INSERT語句將一行數據插入表中,id、name和city 用明文保存,信用卡類型、號碼以及有潛在機密的客戶注釋用加密方式儲存,用Triple DES加密算法加密數據。

INSERT INTO Customer

VALUES (4, 'John Doe', 'Fairbanks',

EncryptByKey(Key_GUID(

'User1SymmetricKeyCert'), 'Amex'),

EncryptByKey(Key_GUID(

'User1SymmetricKeyCert'),

'1234-5678-9009-8765'),

EncryptByKey(Key_GUID(

'User1SymmetricKeyCert'),

'Window shopper. Spends $5 at most.'))

加密完成后,關閉它,釋放內存,以防它被誤用。

CLOSE SYMMETRIC KEY User1SymmetricKeyCert

以上是整個的數據加密的操作過程。它沒有混亂的密碼管理,也不用調用特別的算法。儲存加密數據的字段是varbinary類型數據,其長度足以儲存擴展的數據(加密數據比明文需要更多的空間,有時候多很多)。

下圖為對Customer 表運行正常的SELECT * 語句顯示的帶有加密數據的結果:

SQL Server 2005數據加密技術的實際應用

圖2 加密后的數據的查詢結果

⑵ 數據解密

要解密已加密的數據,你需要重新打開對稱式加密。使用DecryptByKey函數讀數據,然后關閉對稱式加密。結果及相應的代碼如下。

OPEN SYMMETRIC KEY User1SymmetricKeyCert

DECRYPTION BY CERTIFICATE User1Certificate

SELECT CustID, Name, City,

CONVERT(VARCHAR, DecryptByKey(CreditCardType))

AS CardType,

CONVERT(VARCHAR, DecryptByKey(CreditCardNumber))

AS CardNumber,

CONVERT(VARCHAR, DecryptByKey(Notes))

AS Notes

FROM Customer WHERE CustID = 4

CLOSE SYMMETRICKEYUser1SymmetricKeyCert

SQL Server 2005數據加密技術的實際應用

圖3 對加密數據進行解密后的結果

這個例子顯示了讓SQL Server 2005為你管理密鑰的一種方法。但實際上,用戶總是選擇自己提供一個口令的方式,用RC4算法產生對稱密碼。代碼如下:

CREATE SYMMETRIC KEY User2SymmetricKeyPwd

AUTHORIZATION User2

WITH ALGORITHM = RC4

ENCRYPTION BY PASSWORD = 'sdylvxF&imeG3FP'

SQL Server 2005產生一個基于用戶提供的口令的密鑰來加密數據。除非明確指定,否則口令不保存在在SQL Server 2005數據庫中,用戶必須保護好自己的口令,否則任何一個知道口令的人都可以解密數據。

假如認為對存儲在數據庫中的數據加密完全是浪費處理器時間和存儲空間那就錯了。SQL Server 2005中的數據加密是一個非凡的特性,它為客戶的數據提供了一個重要的保護層。但應用時要注意,只對那些敏感機密的數據進行保護,因為加密消耗服務器處理器大量的資源,如果對一個有一千萬條記錄的表的每個字段都加密的話,運行一條沒有Where 子句的SELECT 就可能導致服務器性能的徹底崩潰。

標簽: Sql Server 數據庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
成人污污视频| 午夜久久美女| 亚洲国产影院| 高清久久精品| 国产精品毛片久久久| 91精品福利观看| 亚洲免费福利一区| 国产毛片久久| 亚洲一区二区三区四区五区午夜| 九一精品国产| 国内精品福利| 日本黄色精品| 97在线精品| 97精品国产福利一区二区三区| 亚洲综合激情在线| 综合国产精品| 亚洲精品三级| 蜜芽一区二区三区| 久久大逼视频| 一本综合精品| 日韩欧美久久| 欧美久久久网站| 91精品在线免费视频| 四虎精品永久免费| 午夜性色一区二区三区免费视频| 亚洲精品大片| 国产欧美一区二区三区米奇| 国产精品nxnn| 精品久久亚洲| 国精品产品一区| 成人一区不卡| 久久国产精品成人免费观看的软件| 亚洲性色av| 亚洲精品小说| 一区二区三区午夜视频| 青草国产精品| 国产一区2区在线观看| 9999国产精品| 欧美精选一区二区三区| 美女久久一区| 日本不卡一区二区三区| 久久不卡日韩美女| 国产在线日韩精品| 欧美日韩在线二区| 国产午夜久久| 久久国产乱子精品免费女| 欧美a级一区二区| av综合电影网站| 日韩视频一区二区三区在线播放免费观看| 六月丁香综合| 国产精品扒开腿做爽爽爽软件| 色综合狠狠操| 国产高清一区二区| 欧美午夜网站| 成人av三级| 午夜国产精品视频免费体验区| 日韩欧美久久| 亚洲精品福利电影| 亚洲欧美日韩精品一区二区 | 久久av网址| 福利在线免费视频| 免费黄网站欧美| 美女视频一区在线观看| 久久在线免费| 久久国产生活片100| 91精品国产调教在线观看| 亚洲欧美视频| 国产在线一区不卡| 日韩视频在线一区二区三区| 日韩一区二区三区四区五区| 欧美日韩在线观看首页| 亚洲久久在线| 久久国产中文字幕| 日韩超碰人人爽人人做人人添| 亚洲三级欧美| 91精品啪在线观看国产爱臀| 婷婷综合在线| 麻豆精品蜜桃视频网站| 免费不卡中文字幕在线| 国产麻豆一区二区三区| aa国产精品| 日韩1区2区| 91精品日本| 色老板在线视频一区二区| 亚洲一区二区三区免费在线观看| 欧美欧美黄在线二区| 欧美精品一二| 精品免费视频| 国产亚洲一区二区三区啪| 国产在线观看91一区二区三区| 丝袜亚洲另类欧美| a日韩av网址| 欧美激情麻豆| 欧美日一区二区在线观看| 久久国产精品亚洲77777| 日本精品黄色| 91精品视频一区二区| 蜜桃视频在线观看一区| 蜜桃视频欧美| 福利一区二区免费视频| 国产精品嫩草影院在线看| 亚洲一区二区免费在线观看| 麻豆视频在线看| 国内不卡的一区二区三区中文字幕| 五月亚洲婷婷| 亚洲综合精品四区| 亚洲女同一区| 亚洲午夜91| 久久精品国产久精国产| 国产探花一区二区| 亚洲精品影视| 成人三级高清视频在线看| 欧美国产三级| 国产盗摄——sm在线视频| 91嫩草精品| 久久亚洲风情| 色综合视频一区二区三区日韩| 亚洲精品伊人| 国产精品一区高清| 91视频一区| 国产亚洲精品久久久久婷婷瑜伽| 少妇高潮一区二区三区99| 国产日韩一区二区三免费高清 | 一本一本久久| 亚洲精品一级二级三级| 国产欧美大片| 成人在线视频免费看| 久久电影tv| 亚洲在线免费| 国产日韩免费| 蜜桃av.网站在线观看| av成人国产| 国产亚洲精品美女久久 | 麻豆高清免费国产一区| 99久久亚洲精品蜜臀| 蜜臀av国产精品久久久久| 欧美国产极品| 国产一区日韩欧美| 日韩精品久久理论片| 91亚洲自偷观看高清| 欧美特黄一级大片| 综合亚洲色图| 蜜臀国产一区| 日韩在线卡一卡二| 黄色精品视频| 久久亚洲视频| 丰满少妇一区| 亚久久调教视频| 日韩精品电影| 日韩av不卡一区二区| 久久国产小视频| 国产毛片一区二区三区 | 欧美福利一区| 美女毛片一区二区三区四区最新中文字幕亚洲 | 免费国产自线拍一欧美视频| 麻豆91小视频| 亚洲无线观看| 蜜桃精品在线| 国产免费av一区二区三区| 亚洲精品a级片| 精品久久影院| 蜜桃视频在线观看一区| 日韩在线观看| 国产欧美日韩亚洲一区二区三区| 日韩综合精品| 国产麻豆精品久久| 亚洲精品成人| 久久毛片亚洲| 国产欧美亚洲一区| 首页国产欧美久久| 久久国产毛片| 国产一区二区三区黄网站| 日本中文字幕视频一区| 国产在线成人| 色综合狠狠操| 国产精品亚洲人成在99www| 免播放器亚洲| 日韩欧美午夜| 久久久久观看| 天堂av一区| 91精品高清| 日本精品影院| 日韩av在线播放网址| 国产精品流白浆在线观看| 亚洲精品在线二区| 欧美日韩国产在线一区| 视频二区不卡| 成午夜精品一区二区三区软件| 日本久久二区| 夜久久久久久| 亚洲激情社区| 亚洲福利一区| 久久久久国产| 日韩毛片视频| 国产中文欧美日韩在线| 国产精品igao视频网网址不卡日韩 | 成人午夜在线| 麻豆精品久久| 蜜臀国产一区| 国产精品久久亚洲不卡|