SQL Server 數據加密功能解析

来源:http://www.cnblogs.com/lyhabc/archive/2016/11/09/6046358.html
-Advertisement-
Play Games

SQL Server 數據加密功能解析 轉載自: 騰雲閣 https://www.qcloud.com/community/article/194 數據加密是資料庫被破解、物理介質被盜、備份被竊取的最後一道防線,數據加密,一方面解決數據被竊取安全問題,另一方面有關法律要求強制加密數據。SQL Ser ...


SQL Server 數據加密功能解析

 

轉載自: 騰雲閣 https://www.qcloud.com/community/article/194

數據加密是資料庫被破解、物理介質被盜、備份被竊取的最後一道防線,數據加密,一方面解決數據被竊取安全問題,另一方面有關法律要求強制加密數據。SQL Server 的數據加密相較於其他資料庫,功能相對完善,加密方法較多。通常來講,數據加密分為對稱加密和非對稱加密。對稱加密:加密與解密使用同一密鑰,密鑰需要傳輸,安全性較弱,但性能較非對稱要好。非對稱加密:加密與解密使用不同密鑰(公鑰和私鑰),較對稱密鑰安全性較好,但是演算法較複雜,帶來性能上的損失。因此,折中的方法是使用對稱密鑰加密數據,使用非對稱密鑰加密對稱密鑰。這樣既保證高性能,又提高密鑰的可靠性。

同樣,SQL Server 就使用了折中的方法,所以SQL Server 加密功能包含2個部分:數據加密和密鑰管理

 

 

一.數據加密

說道數據加密,我們不得不說下加密演算法,SQL Server支持多種加密演算法:

 


二.密鑰管理

1.SQL Server加密層次結構


由圖可以看出,加密是分層級的。每一個資料庫實例都擁有一個服務主密鑰(Service Master Key),這個密鑰是實例的根密鑰,在實例安裝的時候自動生成,其本身由Windows提供的數據保護API進行保護(Data Pertection API),服務主密鑰除了為其子節點提供加密服務之外,還用於加密一些實例級別的信息,比如實例的登錄名密碼或者鏈接伺服器的信息。

在服務主密鑰之下的是資料庫主密鑰(Database Master Key),這個密鑰由服務主密鑰進行加密。這是一個資料庫級別的密鑰,可以用於為創建資料庫級別的證書或非對稱密鑰提供加密,每一個資料庫只能有一個資料庫主密鑰。

EKM模塊,這個比較特別,全稱可擴展密鑰管理模塊,該功能增強sqlserver密鑰管理的能力,允許將密鑰存儲到資料庫之外,包括一些硬體,如智能卡、USB設備或硬體安全模塊(HSM);並且允許使用第三方產品來管理密鑰和進行加密;另外,有條件的可以使用更高性能的HSM模塊來加解密,減少加解密上性能的損失。

 

2.SQL Server加密方式

對象定義加密

未保證觸發器、存儲過程、視圖等定義信息,我們可以在定義sqlserver對象的時候添加WITH ENCRYPTION欄位來加密對象。

 

列數據加密

通過函數加密表中的某一列數據。可以通過密碼、對稱密鑰、非對稱密鑰、證書等4中方式加密。其中,還包括 帶有驗證器的加密函數,驗證器用來解決密文替換問題,驗證器一般選用不更改獨一無二的id,這樣就算密文替換,驗證器不對,一樣失敗。

 

連接加密

通過證書的方式對ssl連接加密,一般用於鏡像,客戶端和SQL Server之間的連接就是通過這種方式,防止黑客竊取客戶端和資料庫之間的發送的數據。

 

TDE透明數據加密(2008)

透明數據加密,顧名思義,是在用戶不感知的情況下完成加解密操作。
它的加密是在頁級別進行,是在寫入磁碟前加密,讀入記憶體時解密,針對數據和日誌文件,做到實時I/O加密,並且備份文件也會一同加密。
密鑰存在資料庫引導記錄中,收到證書或者非對稱密鑰的保護,也可以與EKM模塊一同使用。官方說法,額外占用3%-5%的cpu資源。
TDE也有一些缺點:
壓縮率小,由於它是先加密再壓縮的,所以無法顯著壓縮備份。
備份同樣是加密的,所有恢復的時候要小心,註意備份證書和密鑰,才能在另個實例中還原資料庫
性能有一定損耗

 

備份加密(2014)

支持備份的過程中進行加密,並且支持先壓縮在加密,保持高壓縮比,打破了使用透明數據加密後幾乎沒有壓縮率的窘境。
因此,使用原生備份加密無論在將數據備份到異地數據中心,還是將數據備份到雲端,都能夠以非常低的成本對數據提供額外的安全保障。

 

全程加密AlwaysEncrypted(2016)

全程加密,數據永遠是加密狀態,你可以在加密數據上執行操作,無需先對它們解密,也就是說加密的敏感信息不會有機會變為明文。
全程加密針對列做處理,在創建列主密鑰,列加密密鑰後,可以在創建表的時候設置列加密。
加密模式分為兩種:確定型加密與隨機型加密。
確定型加密能夠確保對某個值加密後的結果是始終相同的,這就允許使用者對該數據列進行等值比較、連接及分組操作。確定型加密的缺點在於有可能揣測出原文,而隨機型加密能夠保證某個給定值在任意兩次加密後的結果總是不同的,從而杜絕了猜出原值的可能性。官方建議需要搜索和分組的列使用確定性加密,而註釋和其他敏感不會進行搜索分組的信息使用隨機性加密。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 百度API:xlongwei 這個人提供的介面很多啊,也很實用:Word轉Html、Word轉Pdf、屬性配置、手機號段、微信公眾號消息加密、微信公眾號消息解密、二維碼、關鍵詞、分詞、拼音、生僻字、微博短鏈接。但是很多都不感興趣的,除了一個,那就是中文分詞啊。以前某天突然對瀏覽器以及編輯器中的滑鼠雙 ...
  • 新版六合彩投註網站系統源碼 (測試完整可商業運行) 帶新開獎結果》》》》》 網站系統可以支持代理開設,股東發展,普通會用等常用的功能。 玩法齊全》連碼自由對碰》各類玩法內附說明。資料庫文件 hs001 修改資料庫連接 文件夾 configs 文件config後臺管理 admin admin前臺會員目 ...
  • 本節介紹EnumMap的用法和實現原理,為什麼要針對枚舉類型單獨實現一個Map?它的用法和其他Map有什麼不同?內部是如何實現的?... ...
  • 效果: ...
  • 使用beans.xml文件進行bean的創建和註入通常是可行的,但在便利性上Spring提供了更簡單的方法——自動裝配 當然,我們也可以在創建bean時對它命名,在CDPlayer類中可以體會到。代碼如下: 值得註意的是,真正的實現過程與代碼主體非常複雜,@Component,@ComponScan ...
  • 一、面向對象 Java中的面向對象與C 的面向對象,本質都是一樣。所以對於學過C 的同學理解Java中面向對象的概念就比較輕鬆。 對象 定義: 萬物皆對象,客觀存在的事物都稱為 對象 。 1、面向對象 類 定義: 類是模具,確定對象將會擁有的特性(屬性)和行為(方法) 特點: A.類是對象的類型 B ...
  • 對DBA而言,不需要域就可以搭建SQL Server AlwaysOn是Windows Server 2016中最令人興奮的功能了,它不僅可以降低搭建的成本,而且還減少了部署和運維的工作量。 上篇博客已給大家分享過:要在沒有域的環境中搭建AlwaysOn需要兩個步驟, 1).搭建基於windows ...
  • 為什麼要創建索引? 在此本人也帶著相同的疑問,能夠解釋的僅僅是:為了減少資料庫查詢時所需要的速度。如果正常查詢和索引查詢所需時間相差很多倍時我們自然是需要索引的了。 想要知道結果,只能等我學得更加深入一點咯。 創建索引 創建索引有三種方法:(1)在創建表時創建索引; (2)使用ALTER TABLE ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...