我们在开发上都有这样的需求:对部分敏感数据进行屏蔽,如身份证信息,名字的一部分等

显示如:

在开发上,一般来是取出相应的文字后进行替换,如可以用下面的方法。

function plusXing (str,StartLen,endLen) {

var len = str.length-StartLen -endLen;

var xing = '';

for (vari=0;i<len;i++) {

xing+='*';

}

return str.substr(0,StartLen)+xing+str.substr(str.length-endLen);

}

如输入 plusXing(“18023456789”,3,4)

返回结果:180****6789

但是这样的方法存在安全隐患,因为读取出来的源数据是明文。因此在SQL2016和Azure SQL中有了一个数据掩码(Azure SQL翻译为动态数据掩码,Technet上面翻译为动态数据屏蔽)的新功能帮助解决这样的问题。

下面我们来看看能实现什么好玩的功能:

先在本地做个测试:

创建一张表

create TABLE Membership

(MemberID int IDENTITY PRIMARY KEY,

FirstName varchar(100) MASKED WITH (FUNCTION = 'default()') NULL,   ----启用默认掩码

LastName varchar(100) NOT NULL,

Phone# varchar(13) MASKED WITH   (FUNCTION = 'partial(1,"XXXXXXX",0)') NULL,  ---启动动态屏蔽,从第一个字符开始使用XXXXX替换,最后不显示

Email varchar(100) MASKED WITH (FUNCTION = 'email()') NULL);   ----启用email掩码

插入数据:

INSERT Membership (FirstName, LastName, Phone#, Email) VALUES

('张', '三丰', '13980040000', 'zhangsanfeng@contoso.com'),

('王', '一箭', '13698000000', 'wangyijian@contoso.com.co'),

('独孤', '九剑', '13599999999', 'dugujiujian@contoso.net');

SELECT * FROM Membership;

分配一个testuser用户赋予查询权限

CREATE USER TestUser WITHOUT LOGIN;

GRANT SELECT ON Membership TO TestUser;

使用testuser身份进行查询

EXECUTE AS USER = 'TestUser';

SELECT * FROM Membership;

REVERT;

结果如下:

更改掩码

ALTER TABLE Membership

ALTER COLUMN Phone# varchar(13) MASKED WITH (FUNCTION = 'partial(3,"****",4)');  ---更改为从第三位开始,使用*来做掩码,最后显示4位

ALTER TABLE Membership

ALTER COLUMN Phone# varchar(13) MASKED WITH (FUNCTION = 'partial(3,"****",5)');  ---更改为从第三位开始,使用*来做掩码,,最后显示5位

授权查看未经屏蔽数据的权限

授予 UNMASK 权限即可让 TestUser 查看未经屏蔽的数据

GRANT UNMASK TO TestUser;

EXECUTE AS USER = 'TestUser';

SELECT * FROM Membership;

REVERT;

删除未屏蔽权限

-- Removingthe UNMASK permission

REVOKE UNMASK TO TestUser;

删除动态数据屏蔽

以下语句将删除上述示例中创建的针对 FirstName列的屏蔽:

ALTER TABLE Membership

ALTER COLUMN FirstName DROP MASKED;

查询屏蔽列

通过以下语句可以查询到那些列使用了屏蔽

SELECT c.name, tbl.name as table_name, c.is_masked, c.masking_function

FROM sys.masked_columnsAS c

JOIN sys.tables AS tbl

ON c.[object_id] = tbl.[object_id]

WHERE is_masked = 1;

 


以上是在SQL 2016上完成的,再来看看azure SQL上怎么玩

第一种方法也使用上面的代码,用SQLmanagement studio 连接azureSQL 如图

一样执行之前的代码,看看结果

create TABLE Membership

(MemberID int IDENTITY PRIMARY KEY,

FirstName varchar(100) MASKED WITH (FUNCTION = 'default()') NULL,   ----启用默认掩码

LastName varchar(100) NOT NULL,

Phone# varchar(13) MASKED WITH   (FUNCTION = 'partial(3,"****",4)') NULL,  ---启动动态屏蔽,

Email varchar(100) MASKED WITH (FUNCTION = 'email()') NULL);   ----启用email掩码

INSERT Membership (FirstName, LastName, Phone#, Email) VALUES

('张', '三丰', '13980040000', 'zhangsanfeng@contoso.com'),

('王', '一箭', '13698000000', 'wangyijian@contoso.com.co'),

('独孤', '九剑', '13599999999', 'dugujiujian@contoso.net');

SELECT * FROM Membership;

CREATE USER TestUser WITHOUT LOGIN;

GRANT SELECT ON MembershipTO TestUser;

EXECUTE AS USER = 'TestUser';

SELECT * FROM Membership;

REVERT;

查看掩码情况

SELECT c.name, tbl.name as table_name, c.is_masked, c.masking_function

FROM sys.masked_columnsAS c

JOIN sys.tables AS tbl

ON c.[object_id] = tbl.[object_id]

WHERE is_masked = 1

第二种方法,在ARM 界面下,选择Azure SQL,数据的选项里面就有动态数据掩码选项。

点击后

已经展示了使用个掩码的情况,也可以在此界面进行添加,更加简单。

也可以在这个界面进行修改

SQL 数据库动态数据掩码通过对非特权用户模糊化敏感数据来限制此类数据的泄露。

•不对其进行屏蔽的 SQL 用户 - 一组可以在 SQL 查询结果中获取非屏蔽数据的 SQL 用户或 AAD 标识。 请注意,始终不会对拥有管理员权限的用户进行屏蔽,这些用户可以查看没有任何屏蔽的原始数据。

•屏蔽规则 - 一组规则,定义将要屏蔽的指定字段,以及要使用的屏蔽函数。 可以使用数据库架构名称、表名称和列名称定义指定的字段。

•屏蔽函数 - 一组方法,用于控制不同情况下的数据透露。

函数

说明

示例

默认

根据指定字段的数据类型进行完全屏蔽。

对于字符串数据类型,可以使用 XXXX 或者在字段不到 4 个字符长的情况下使用更少的 X(charncharvarcharnvarchartextntext)。

对于数字数据类型,可使用零值(bigint****bit****decimalintmoneynumericsmallintsmallmoneytinyintfloatreal)。

对于日期和时间数据类型,可使用 01.01.1900 00:00:00.0000000(datedatetime2datetimedatetimeoffsetsmalldatetimetime)。

对于二进制数据类型,可使用单字节的 ASCII 值 0(binaryvarbinaryimage)。

列定义语法示例: Phone# varchar(12) MASKED WITH (FUNCTION = 'default()') NULL

ALTER 语法示例: ALTER COLUMN Gender ADD MASKED WITH (FUNCTION = 'default()')

电子邮件

该屏蔽方法公开电子邮件地址的第一个字母,以及电子邮件地址格式中的常量后缀“.com”。 。 aXXX@XXXX.com

定义语法示例: Email varchar(100) MASKED WITH (FUNCTION = 'email()') NULL

ALTER 语法示例:ALTER COLUMN Email ADD MASKED WITH (FUNCTION = 'email()'

随机

一种随机屏蔽函数,适用于任何数字类型,可以在指定范围内使用随机值来屏蔽原始值。

定义语法示例: Account_Number bigint MASKED WITH (FUNCTION = 'random([start range], [end range])')

ALTER 语法示例: ALTER COLUMN [Month] ADD MASKED WITH (FUNCTION = 'random(1, 12)')

自定义字符串

该屏蔽方法公开第一个和最后一个字母,在中间添加自定义填充字符串。 prefix,[padding],suffix

注意:如果因原始值太短而无法进行完整的屏蔽,则不会公开部分前缀或后缀。

定义语法示例: FirstName varchar(100) MASKED WITH (FUNCTION = 'partial(prefix,[padding],suffix)') NULL

ALTER 语法示例: ALTER COLUMN [Phone Number] ADD MASKED WITH (FUNCTION = 'partial(1,"XXXXXXX",0)')

其他示例:

ALTER COLUMN [Phone Number] ADD MASKED WITH (FUNCTION = 'partial(5,"XXXXXXX",0)')

ALTER COLUMN [Social Security Number] ADD MASKED WITH (FUNCTION = 'partial(0,"XXX-XX-",4)')

Permissions

不需任何特殊权限即可使用动态数据屏蔽来创建表,只需标准的 CREATE TABLE 权限以及对架构的 ALTER 权限。

添加、替换或删除对列的屏蔽,需要 ALTER ANY MASK 权限以及对表的 ALTER 权限。 可以将 ALTER ANY MASK 权限授予安全负责人。

具有表的 SELECT 权限的用户可以查看表数据。列在被定义为“已屏蔽”后,将显示屏蔽后的数据。 对于需要从定义了屏蔽的列中检索非屏蔽数据的用户,可授予其 UNMASK 权限。

针对数据库的 CONTROL 权限包括 ALTER ANYMASKUNMASK 权限。

安全说明:可使用推断或暴力技术绕过屏蔽

上面的例子中,我可以这样进行暴力推断

也就是说动态掩码是一个障眼法,不能阻止你去窥探数据的本身。上面的例子就是testuser看到数据,但是他可以推测出了姓“张”的数据。

 

总结:

 

动态数据屏蔽 (DDM) 通过对非特权用户屏蔽敏感数据来限制敏感数据的公开。 它可以用于显著简化应用程序中安全性的设计和编码。

动态数据屏蔽允许用户在尽量减少对应用程序层的影响的情况下,指定需要披露的敏感数据,从而防止对敏感数据的非授权访问。 DDM 可以在数据库上进行配置,以隐藏对指定数据库字段进行查询时获得的结果集中的敏感数据,同时不会更改数据库中的数据。 可以轻松地对现有应用程序使用动态数据屏蔽,因为屏蔽规则是应用于查询结果。许多应用程序可以屏蔽敏感数据,而无需修改现有查询。

  • 一个中央数据屏蔽策略直接对数据库中的敏感字段起作用。

  • 指定有权访问敏感数据的特权用户或角色。

  • DDM 采用完全屏蔽和部分屏蔽功能,以及用于数值数据的随机屏蔽。

  • 简单Transact-SQL 命令定义和管理掩码。

    例如,呼叫中心支持人员通过身份证号或信用卡号的几个数字就可以辨识呼叫者,但系统不会将这些数据内容完全公开给该支持人员。 可以通过定义屏蔽规则来屏蔽查询结果集中身份证号或信用卡号最后四位数字以外的所有数字。另一个例子就是,在需要进行故障排除时,开发人员可以通过对数据进行适当的数据屏蔽来保护个人身份信息 (PII) 数据,因此可以在不违反遵从性法规的情况下,对生产环境进行查询。

    动态数据屏蔽旨在限制敏感数据的公开,防止没有访问权限的用户查看敏感数据。 动态数据屏蔽并不是要防止数据库用户直接连接到数据库并运行可以公开敏感数据的详尽查询。动态数据屏蔽是对其他 SQL Server 安全功能(审核、加密、行级别安全性…)的补充,因此,强烈建议你将此功能与上述功能一起使用,以便更好地保护数据库中的敏感数据

     

数据库安全之数据掩码:SQL新功能之动态数据掩码(SQL2016AZURE SQL)相关推荐

  1. SQL Server中的动态数据屏蔽

    Security has been one of the prime concerns of database developers since the inception of database m ...

  2. azure云数据库_在Azure SQL数据库中实现动态数据屏蔽

    azure云数据库 In this article, we will review Dynamic Data Masking in the Azure SQL database. Dynamic Da ...

  3. 华为云-云容器引擎 CCE新功能发布动态

    新功能发布动态 更新时间: 2020/06/29 GMT+08:00 查看PDF 分享 本文介绍了云容器引擎CCE各特性版本的功能发布和对应的文档动态,新特性将按照时间计划在各个区域(Region)陆 ...

  4. Softing工业边缘产品的新功能助力工业数据集成到IT解决方案中

    Softing的edgeConnector和edgeAggregator产品在3.40版本中新增了一系列功能,使数据集成到IT解决方案变得更加容易. 基于Docker的edgeConnector产品系 ...

  5. 使用SQL DTS功能实现从DB/2向SQL Server传输数据

    前言] 经过自行测试SQL2000 DTS功能,感觉通过DTS工具从DB/2取数来得很方便.容易实现.现将实施步骤贴出来,以供参考. [环境] IBM AS/400e.OS/400.DB/2. ERP ...

  6. 数据权限框架:一个实现数据权限与业务模块完全分离,让数据权限变成独立功能模块的数据权限框架

    meng框架 介绍 meng框架是一个实现了行数据权限和列数据权限的数据权限框架: meng框架能让数据权限变成一个独立的功能模块,与业务模块完全分离,在已经实现的业务逻辑中添加数据权限不需要对原来的 ...

  7. 【3数据可视化】基于vue的动态数据低代码可视化实现

    目录 1.数据科学的产业升级 2.数据可视化的痛点 2.1 数据分析师 2.2 想提升的非技术人员 3.数据可视如何简单化 3.1 数据部分 3.1.1 代码需求 3.1.2 无代码需求 3.2 图表 ...

  8. SQL2017 Azure SQL新功能:图形数据库

    图形数据库是什么呢?如果从字面理解是进行图形处理的数据库,那么你就错了哈哈. 我们先来解释什么是图形数据库. 图形数据库是NoSQL数据库的一种类型,它应用图形理论存储实体之间的关系信息.最常见的例子 ...

  9. Excel新功能:分析数据的使用教程及案例

    制作数据表可能不难,但分析其中的数据时,使用公式寻找重要结论的过程往往让人抓耳挠腮.现在,<Excel>推出了"分析数据"功能,可以创建一系列推荐图表和数据表,让你不需 ...

最新文章

  1. python中weekid什么意思_week_one-python格式化输出
  2. 006 Spark中的wordcount以及TopK的程序编写
  3. STM32固件库的调用
  4. mysql 优化(一)
  5. 那些计算机界的伟大女性
  6. java 同步的方法_关于Java中的同步方法
  7. ICCV 2019 | 旷视研究院提出VANet:具备视角感知力的车辆重识别网络
  8. ASP.NET MVC3 快速入门-第四节 添加一个模型(转)
  9. apt install:文件尺寸不符(25294 != 25412)。您使用的镜像正在同步中?
  10. 读Thinking in Java(1~4)
  11. 电商系统之商品类目及商品属性史
  12. React脚手架安装
  13. 史上最全App瘦身实践
  14. 物联网:Android端控制ZigBee实现生产环境自动控制
  15. SQL练习题——店铺UV、访客信息
  16. MGF6mARice:利用分子图特征和残差块预测水稻DNAn6-甲基腺嘌呤位点
  17. 【无线网络技术】WLAN技术学习笔记
  18. JAVA中pin什么意思_pin是什么意思用法
  19. 《去哪儿网支付系统架构演进全历程》阅读有感
  20. echarts 热点泡泡图

热门文章

  1. FBI树-数据结构(二叉树)
  2. hadoop native安装
  3. 零元学Expression Design 4 - Chapter 5 教你如何用自制笔刷在5分钟内做出设计感效果...
  4. Hbase完全分布式高可用集群安装配置
  5. DMA(2) S3C2410 DMA详解(其它的其实类似)
  6. SQL删除语句同时向备份表插入数据
  7. Java集合框架之四大接口、常用实现类,java基础面试笔试题
  8. python怎样在一行中捕获多个异常
  9. Windows Server 2012/2012 R2:安装和配置 SMTP 服务器
  10. java.sql.SQLException: 关闭的连接 解决办法