-
SQL Server的行级安全性详解
目录一、前言二、描述三、权限四、安全说明:侧信道攻击五、跨功能兼容性六、示例一、前言行级别安全性使您能够使用组成员身份或执行上下文来控制对数据库表中行的访问。行级别安全性 (RLS) 简化了应用程序中的安全性设计和编码。RLS 可帮助您对数据行访问实施限制。例如,您可以确保工作人员仅访问与其部门相关的数据行。另一个示例是将客户的数据访问限制为仅与其公司相关的数据。访问限制逻辑位于数据库层中,而不是远离另一个应用程序层中的数据。每次尝试从任何层访问数据时,数据库系统都会应用访问限制。这通过减少安全系统的表面积,使您的安全系统更加可靠和强大。通过使用创建安全策略 Transact-SQL 语句和作为内联表值函数创建的谓词实现 RLS。行级别安全性首次引入 SQL Server 2016 (13.x)。二、描述RLS 支持两种类型的安全谓词。筛选器谓词以静默方式筛选可用于读取操作(选择、更新和删除)的行。阻止谓词显式阻止违反谓词的写入操作(插入后、更新后、更新之前、删除之前)。对表中行级数据的访问受定义为内联表值函数的安全谓词的限制。然后,安全策略调用和强制执行该函数。对于筛选器谓词,应用程序不知道从结果集中筛选的行。如果筛选了所有行,则将返回空集。对于块谓词,任何违反谓词的操作都将失败并显示错误。从基表中读取数据时应用筛选器谓词。它们影响所有获取操作:选择、删除和更新。用户无法选择或删除已筛选的行。用户无法更新筛选的行。但是,可以更新行,以便以后对其进行筛选。块谓词会影响所有写入操作。“插入后”和“更新后”谓词可以防止用户将行更新为违反谓词的值。BEFORE UPDATE 谓词可以阻止用户更新当前违反谓词的行。在删除之前 谓词可以阻止删除操作。筛选器和阻止谓词以及安全策略都具有以下行为:可以定义一个谓词函数,该函数与另一个表联接和/或调用函数。如果使用 (默认值) 创建安全策略,则可以从查询访问联接或函数,并按预期工作,而无需任何其他权限检查。如果使用 创建安全策略,则用户将需要对这些附加表和函数的 SELECT 权限才能查询目标表。如果谓词函数调用 CLR 标量值函数,则还需要 EXECUTE 权限。可以针对已定义但已禁用安全谓词的表发出查询。筛选或阻止的任何行不受影响。如果 dbo 用户、db_owner角色的成员或表所有者查询已定义并启用了安全策略的表,则会按照安全策略的定义过滤或阻止行。尝试更改由架构绑定安全策略绑定的表的架构将导致错误。但是,可以更改谓词未引用的列。尝试在已为指定操作定义谓词的表上添加谓词会导致错误。无论是否启用谓词,都会发生这种情况。尝试修改函数(用作架构绑定安全策略中的表的谓词)将导致错误。定义多个包含非重叠谓词的活动安全策略会成功。筛选器谓词具有以下行为:定义用于筛选表中行的安全策略。应用程序不知道针对 SELECT、UPDATE 和 DELETE 操作筛选的任何行。包括筛选掉所有行的情况。应用程序可以插入行,即使它们将在任何其他操作期间被筛选。块谓词具有以下行为:UPDATE 的块谓词被拆分为 BEFORE 和 AFTER 的单独操作。例如,不能阻止用户将行更新为具有高于当前值的值。如果需要这种逻辑,则必须将触发器与 DELETE 和 INSERT 中间表一起使用,以同时引用旧值和新值。如果谓词函数使用的列未更改,优化程序将不会检查 AFTER UPDATE 块谓词。尚未对批量 API 进行任何更改,包括批量插入。这意味着块谓词 AFTER INSERT 将应用于批量插入操作,就像它们将常规插入操作一样。三、权限创建、更改或删除安全策略需要“更改任何安全策略”权限。创建或删除安全策略需要对架构具有 ALTER 权限。此外,添加的每个谓词都需要以下权限:对用作谓词的函数的 SELECT 和 REFERENCE 权限。对绑定到策略的目标表的 REFERENCES 权限。对用作参数的目标表中的每一列的 REFERENCES 权限。安全策略适用于所有用户,包括数据库中的 dbo 用户。Dbo 用户可以更改或删除安全策略,但可以审核他们对安全策略的更改。如果高特权用户(如 sysadmin 或 db_owner)需要查看所有行以排除故障或验证数据,则必须编写安全策略以允许这样做。如果使用 创建安全策略,则要查询目标表,用户必须对谓词函数以及谓词函数中使用的任何其他表、视图或函数具有 SELECT 或 EXECUTE 权限。如果使用 (默认值) 创建安全策略,则当用户查询目标表时会绕过这些权限检查。四、安全说明:侧信道攻击(1)恶意安全策略管理器。请务必注意,恶意安全策略管理器具有在敏感列上创建安全策略的足够权限,并有权创建或更改内联表值函数,但可以与对表具有选择权限的其他用户串通,通过恶意创建旨在使用侧通道攻击推断数据的内联表值函数来执行数据泄露。此类攻击需要串通(或授予恶意用户的过多权限),并且可能需要多次迭代修改策略(需要删除谓词的权限以破坏架构绑定)、修改内联表值函数以及在目标表上重复运行 select 语句。我们建议您根据需要限制权限,并监视任何可疑活动。应监视活动,例如不断更改的策略和与行级别安全性相关的内联表值函数。(2)精心设计的查询。通过使用利用错误的精心设计的查询,可能会导致信息泄露。五、跨功能兼容性通常,行级别安全性将跨功能按预期工作。但是,也有一些例外。本节记录了将行级别安全性与 SQL Server 的某些其他功能结合使用的几个注意事项和注意事项。DBCC SHOW_STATISTICS报告未过滤数据的统计信息,并可能泄露受安全策略保护的信息。因此,对查看具有行级别安全策略的表的统计信息对象的访问受到限制。用户必须拥有该表,或者用户必须是 sysadmin 固定服务器角色、db_owner固定数据库角色或db_ddladmin固定数据库角色的成员。文件流:RLS 与文件流不兼容。内存优化表:必须使用该选项定义用作内存优化表的安全谓词的内联表值函数。使用此选项,将禁止内存优化表不支持的语言功能,并在创建时发出相应的错误。索引视图:通常,可以在视图之上创建安全策略,也可以在受安全策略约束的表之上创建视图。但是,不能在具有安全策略的表之上创建索引视图,因为通过索引查找行将绕过该策略。变更数据捕获:变更数据捕获可能会泄漏应筛选为db_owner成员或为表启用 CDC 时指定的“控制”角色成员的用户(注意:您可以将此函数显式设置为 NULL,以使所有用户都能访问变更数据)。实际上,db_owner和此控制角色的成员可以查看表上的所有数据更改,即使表上有安全策略也是如此。更改跟踪:更改跟踪可能会将应筛选的行的主键泄露给同时具有“选择”和“查看更改跟踪”权限的用户。实际数据值不会泄露;只有 A 列被更新/插入/删除了带有 B 主键的行的事实。如果主密钥包含机密元素(如社会保险号),则会出现问题。然而,在实践中,这个CHANGETABLE几乎总是与原始表连接,以获得最新的数据。全文搜索:使用以下全文搜索和语义搜索函数的查询预计会降低性能,因为引入了额外的联接来应用行级安全性并避免泄漏应过滤的行的主键:CONTAINSTABLE、FREETEXTTABLE、semantickeyphrasetable、semanticsimilaritydetailstable、semanticsimilaritytable、semanticsimilaritytable。列存储索引:RLS 与聚集列存储索引和非聚集列存储索引兼容。但是,由于行级别安全性应用函数,因此优化程序可能会修改查询计划,使其不使用批处理模式。分区视图:不能在分区视图上定义块谓词,也不能在使用块谓词的表上创建分区视图。筛选器谓词与分区视图兼容。时态表:时态表与 RLS 兼容。但是,当前表上的安全谓词不会自动复制到历史记录表中。要将安全策略应用于当前表和历史记录表,必须在每个表上单独添加安全谓词。六、示例向数据库进行身份验证的用户的方案。创建三个用户,并创建并填充一个包含六行的表。然后,它为表创建一个内联表值函数和安全策略。然后,该示例演示如何为各种用户筛选 select 语句。(1)创建三个将演示不同访问功能的用户帐户。CREATE USER Manager WITHOUT LOGIN;CREATE USER SalesRep1 WITHOUT LOGIN;CREATE USER SalesRep2 WITHOUT LOGIN;GO(2)创建一个表来保存数据。CREATE SCHEMA SalesGOCREATE TABLE Sales...
数据库操作教程 2023-05-12 12:11:21 -
福佑卡车战略合作千挂科技,预计今年将提供百万公里级的干线智能货运服务
5月12日消息,福佑卡车与千挂科技联合宣布达成战略合作,将千挂科技的智能卡车接入福佑卡车自动驾驶货运网络,为平台客户提供干线智能驾驶运力服务,目前已正式投入商业化运营。据介绍,搭载千挂科技智能驾驶系统的牵引卡车,可实现干线场景下的高级别智能驾驶,帮助司机有效减少长途驾驶产生的肌肉及精神疲劳,确保行车安全,增加司机日均驾驶距离,有效解决单司机驾驶场景下的运力持续性难题,从而科学降低运营成本,提升干线整体运输效率...
业界动态 2023-05-12 11:00:13 -
网络出版商担忧谷歌AI搜索会白嫖内容损害网站流量收益
5月12日消息,当地时间本周三,谷歌宣布将生成式人工智能引入搜索引擎,这可能是谷歌搜索引擎历史上最大的变化之一。但网络出版商普遍担心,全新的谷歌搜索可能会影响到他们网站的流量...
互联网 2023-05-12 10:00:59 -
3nm贵出天际多家客户推迟订单台积电喊话:别怕涨价在想办法了
快科技5月12日消息,台积电去年底已经量产了3nm工艺,今年会大规模放量,苹果依然会首发3nm,但是台积电的3nm工艺代工成本不菲,很多厂商也吃不消。此前数据显示,从10nm开始,台积电的每片晶圆价格开始疯狂增长,2018年的7nm晶圆每片价格飙升至10000美元,2020年的5nm工艺晶圆每片价格突破16000美元...
手机互联 2023-05-12 09:46:20 -
苹果更新听歌识曲服务Shazam,现支持AppleMusicClassic
IT之家5月11日消息,苹果近日升级了听歌识曲服务Shazam,在最新15.33版本中添加了对AppleMusicClassical的支持,允许两款应用协同工作,帮助用户寻找古典音乐。IT之家附Shazam应用程序版本15.33的发行说明:用户现在可以在AppleMusicClassical中启用Shazam服务,简单点击Shazam按钮或者搜索古典音乐即可...
智能设备 2023-05-11 11:10:19 -
加密货币热潮退去矿企转身为AI提供高性能计算服务
5月11日消息,去年9月,当以太坊区块链不再使用工作量证明算法来验证交易时,加密货币市场对高性能专用处理器的需求几乎在一夜之间消失了。那些使用或托管图形图像处理单元(GPU)的加密货币矿企发现,加密货币领域日益困难,他们曾经蓬勃发展的业务关键组成部分一去不复返...
业界动态 2023-05-11 10:52:31 -
谷歌升级FindMyDevice:扩展类别、数亿台安卓设备构建追踪网络
IT之家5月11日消息,谷歌效仿苹果和Tile的定位追踪解决方案,在I/O2023开发者大会上宣布升级FindMyDevice平台。谷歌的SameerSamat宣布,FindMyDevice平台在“未来几个月内”支持追踪耳机、平板电脑和其他产品类别...
手机互联 2023-05-11 10:12:21 -
专访图灵人工智能研究院CEO李强:未来合规与数据安全将是国产AI大模型行业应用核心竞争力
出品|网易科技作者|赵芙瑶编辑|丁广胜当我们在谈论ChatGPT时,我们在谈论什么?时间进入到2023年5月,ChatGPT所引起的风暴还在持续发酵。从其令人震惊的多模态能力、到国产大模型开启“百模大战”、类ChatGPT产品如雨后春笋般涌现,ChatGPT的上下游产业以难以想象的速度进化着...
智能设备 2023-05-10 11:29:42 -
阅文集团管理层调整:程武辞职侯晓楠接任CEO
5月9日,阅文集团宣布管理层调整,现任阅文集团首席执行官程武因个人生活规划调整辞任目前管理职务,董事会委任阅文集团总裁侯晓楠出任阅文集团首席执行官。资料显示,程武和侯晓楠于2020年4月加入阅文,分别任职阅文集团首席执行官和阅文集团总裁...
互联网 2023-05-09 17:25:20 -
中国银行四川省分行落地“龙泉教培”数字人民币预付资金管理项目
来源:封面新闻4月27日,“龙泉教培”数字人民币预付资金管理项目(以下简称“龙泉教培项目”)在成都成功落地,是全国首批、全省首个实现数字人民币智能合约预付卡“元管家”面客推广。数字人民币“智能合约”技术具有透明可信、自动执行、强制履约的优点,与数字人民币相结合后可应用于条件支付、定时支付业务场景,有利于发挥资金监管职能,受到各行各业广泛关注...
区块链 2023-05-09 11:44:40 -
促进Web3合规,「中科链源」提供区块链安全解决方案|Tech100
在参与者日益增多的前提下,Web3的基础设施(如链本身、智能合约等)和应用(钱包、NFT等)却持续被质疑安全性有待加强。有统计显示,2022年,全球Web3的六大主要赛道中,公链、跨链桥、交易所、钱包、DeFi、NFT均发生多起安全事件...
区块链 2023-05-09 10:57:19 -
安恒信息范渊:AI+安全这条路是可以走通的
“AI+安全,这个大幕才刚刚拉开,未来还有更大的可能性。”安恒信息董事长范渊在2023西湖论剑·数字安全大会上如是说...
互联网 2023-05-09 10:53:26