sql server 裡面的 dynamic Data Masking

来源:http://www.cnblogs.com/Gin-23333/archive/2016/04/20/5412028.html
-Advertisement-
Play Games

有時候啊,當我們存放在資料庫裡面的數據,需要明文存放,但是對於前臺查詢出來的,又不太希望明文放出去的時候(比方說客戶的手機啊,郵箱啊)之類有點敏感的信息,之前通常是保存個明文,然後在前臺展現的時候再特殊處理一下,然後就ok了。 而現在呢,在2016提供了data mask的功能,可以遮掩對應列的一些 ...


有時候啊,當我們存放在資料庫裡面的數據,需要明文存放,但是對於前臺查詢出來的,又不太希望明文放出去的時候(比方說客戶的手機啊,郵箱啊)之類有點敏感的信息,之前通常是保存個明文,然後在前臺展現的時候再特殊處理一下,然後就ok了。

而現在呢,在2016提供了data mask的功能,可以遮掩對應列的一些基礎信息

事不宜遲,先做樣例

 1 create table t2(ID int identity,Name nvarchar(50),PWD varchar(20),Phone varchar(50),Email varchar(200))
 2 
 3 go
 4 insert into t2 (Name ,PWD ,Phone ,Email )
 5 select '張三','zhangsan','12433281924','[email protected]'
 6 union all
 7 select '李四','wojiaolisi','18734612309','[email protected]'
 8 union all
 9 select '王五','wangwu','15378198234','[email protected]'
10 union all
11 select 'sixgod','godsixzhao','00834123642','[email protected]'
12 
13 select * from t2
14 
15 ID          Name                                               PWD                  Phone                                              Email
16 ----------- -------------------------------------------------- -------------------- -------------------------------------------------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
17 1           張三                                                 zhangsan             12433281924                                        zhangsan@qq.com
18 2           李四                                                 wojiaolisi           18734612309                                        lisi@sohu.com
19 3           王五                                                 wangwu               15378198234                                        wangwu@21cn.com
20 4           sixgod                                             godsixzhao           00834123642                                        sixgod@qq.com
測試表搭建

 然後我們對這個表的某個列進行mask 的操作。比方說我們對密碼進行一個mask 可以使用以下語句

alter table t2 alter column PWD add masked with (function='default()')

然後我創建來一個用戶Test1 然後只對他授予一個查詢的許可權。運行如下

execute as login='Test1'

select * from t2

ID          Name                                               PWD                  Phone                                              Email
----------- -------------------------------------------------- -------------------- -------------------------------------------------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
1           張三                                                 xxxx                 12433281924                                        zhangsan@qq.com
2           李四                                                 xxxx                 18734612309                                        lisi@sohu.com
3           王五                                                 xxxx                 15378198234                                        wangwu@21cn.com
4           sixgod                                             xxxx                 00834123642                                        sixgod@qq.com

預設的方法,是將整個列的替換成XXXX來顯示。(僅僅在查詢的時候會變成這樣,數據並沒有真正修改成 XXXX)。這是一種mask 的方法。

2016提供給了4種mask 的方式,上面已經演示來一種,還有3種分別是 email(),ramdom(),Custom masking 這3種,下麵就演示一下

alter table t2 alter column Email add masked with (function='Email()')
alter table t2 alter column ID add masked with (function='Random(1000,9999)')
alter table t2 alter column Phone add masked with (function='partial(4,"****",4)')

select * from t2

ID          Name                                               PWD                  Phone                                              Email
----------- -------------------------------------------------- -------------------- -------------------------------------------------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
7952        張三                                                 xxxx                 1243****1924                                       zXXX@XXXX.com
7601        李四                                                 xxxx                 1873****2309                                       lXXX@XXXX.com
5583        王五                                                 xxxx                 1537****8234                                       wXXX@XXXX.com
3190        sixgod                                             xxxx                 0083****3642                                       sXXX@XXXX.com

2、Email() 這個函數只顯示email 的第一位以及 @,其他全部使用X來Mask
3、Random(1000,9999) 顯示的值從1000~9999 之間生成的隨機整數進行mask

4、partial 相當於自定義mask 模式,格式 (首碼保留位數,mask串,尾碼保留位數) 這個格式進行創建

 

那是不是加來mask之後就無法看到原始數據呢?並不是的,是需要使用許可權進行控制

grant unmask to User
revoke unmask from User

只要有unmask這個許可權,那麼就可以看到原始數據啦~~~
PS:可以查看那些列有mask 的哦

 

 

 

select object_name(object_id),name,masking_function
    from sys.masked_columns

(無列名)    name    masking_function
t2    ID    random(1000, 9999)
t2    PWD    default()
t2    Phone    partial(4, "****", 4)
t2    Email    email()

 


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

-Advertisement-
Play Games
更多相關文章
  • 需求一:將字典轉換成自己需的對象,對象的屬性是字典的key值,直接使用key值獲取數據存在兩個缺點,一是key值難以記憶,二是直接使用key值Xcode不會有智能提示,很容易導致未知的錯誤。使用模型時,可以直接通過點語法將需要的數據點出,保證數據準確無誤。使用模型的優點還在於存儲、傳值都比較方便,不 ...
  • Objective C RunTime System (一、基本結構) === 寫OC也有一段時間了~之前一直在研究Objective C的RunTime,應該稱為Runtime系統,國內博客對Runtime的文章甚少,翻牆查閱文獻大量英文,書籍也翻閱甚多,因為近段時間家裡親人生病,一時很忙,文章斷 ...
  • 1.準備Linux環境 1.0 點擊VMware快捷方式,右鍵打開文件所在位置 -> 雙擊vmnetcfg.exe -> VMnet1 host-only ->修改subnet ip 設置網段:192.168.8.0 子網掩碼:255.255.255.0 -> apply -> ok 回到windo ...
  • mysqldump mysqldump -u root -d -R --add-drop-table basedata >basedata.sql -d只有表結構即列信息,無內容即行信息 · --no-data, -d Do not write any table row information ( ...
  • oracle客戶端導出dmp文件 備忘: 一直很少用導出dmp文件的,因為導出SQL已經夠用了,今天花了將近1個半小時,導出了一個13.2G的sql文件,記事本、editplus都無法打開,然後在plsql中導入,報錯(如圖)。 意味著一個半小時白費了。沒辦法只有使用exp導出了。 於是找到一個ba ...
  • GUID(Global unique identifier)全局唯一標識符,它是由網卡上的標識數字(每個網卡都有唯一的標識號)以及 CPU 時鐘的唯一數字生成的的一個 16 位元組的二進位值。 GUID 的格式為“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每個 x ...
  • 我們以MySQL中常用的hint來進行詳細的解析,如果你是經常使用Oracle的朋友可能知道,Oracle的hincvt功能種類很多,對於優化sql語句提供了很多方法。 同樣,在MySQL里,也有類似的hint功能。下麵介紹一些常用的。 強制索引 MySQL FORCE INDEX 以上的SQL語句 ...
  • (1) 選擇最有效率的表名順序(只在基於規則的優化器中有效):ORACLE的解析器按照 從右到左的順序處理FROM子句中的表名,FROM子句中寫在最後的表(基礎表 driving table)將被最先處理,在FROM子句中包含多個表的情況下,你必須選擇記錄條數最少的表作為基礎表。如果有3個以上的表連 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...