热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

DB210新特性:RCAC基于行和列级别的权限控制

在客户环境中,有可能存在着一些表记载的信息需要被不同角色的用户来访问。应用需要控制表中的一些敏感信息只能被特定的用户访问。此前用户一般只能通过创建多个视图和开发应用增加逻辑等来做到这一点。

在客户环境中,有可能存在着一些表记载的信息需要被不同角色的用户来访问。应用需要控制表中的一些敏感信息只能被特定的用户访问。此前用户一般只能通过创建多个视图和开发应用增加逻辑等来做到这一点。

RCAC 通过对表里面行和列的访问权限控制,可以简单的实现这种安全性需求。安全访问得到控制,开发应用变的简单。

DB2 Galileo,也就是 DB2 的 V10 版本是 IBM 在 2012 年推出的新产品。原先的 DB2 pureScale 可以说是 DB2 中的一个独立分支,版本号为 9.8,现在也集成到了 DB2 Galileo 中。DB2 Galileo 不仅集成了 DB2 pureScale,在很多方面也都有大的改进,并且开发了许多新的功能。例如在原先杰出的压缩技术基础上引入了页内进一步压缩机制,获得更好的压缩效率;多温度控制功能,帮助客户解决如何优化利用不同的存储设备,获得更好的性能效果,与 DB2 的工作负载管理结合,最优系统资源利用;新的索引查询技术,无需建立冗余的索引,使用现有综合索引获得更快的查询速度;新的客户端导入数据的技术可以帮助客户能够并行更高效率导入数据,数据几乎实时可见等等。本文中将关注 DB2 中关于细粒度的权限控制 RCAC(Row and Column Access Control)特性。顾名思义,这个特性能够让用户的权限控制细化到行和列的级别。

RCAC 的应用场景

细粒度的权限控制并不是一个新兴的需求,这在长久的应用中一直会被提到。例如在客户环境中,有可能存在着一些表记载的信息需要被不同角色的用户来访问。应用需要控制表中的一些敏感信息只能被特定的用户访问。这些敏感信息,可能是一些列的内容不应被特定用户访问到,也有可能是表中的一些条目(行)不应被展示。为了做到这一点,用户一般需要通过创建视图或者开发应用增加逻辑等来做到这一点。即便如此,因为仅仅在应用层做了限制,并没有规避用户能够访问表中敏感数据的风险。RCAC 通过对表里面行和列的访问权限控制,可以简单的实现这种安全性需求。不仅安全访问得到控制,而且开发应用也变的简单。

RCAC 的技术介绍

RCAC 是对表中行和列的访问控制。对于行的控制,RCAC 使用的是创建 Permission(许可)的技术,能够控制用户对于表的访问只能查询到自己应该看到的信息,其他条目信息不应该被该用户察觉。假如一张表有 100 个条目,某个特定的角色只应访问 10 个条目,那么对于这个用户来说,他能看得的仅仅是一张具有 10 个条目的完整的表。他的任何查询,只会访问到这十个条目。对于列的控制,RCAC 的展示技术和行不太一样。RCAC 使用的是 Data Mask(面具)技术,也就是在敏感信息的列上可以创建面具,对于这些敏感的列,应该获得该信息的用户仍然可以正常查看,但是不应访问到此信息的只能看到数据返回的是一张面具,而不是真实的值。所以无论任何用户,都可以看到表的真实结构,不会给应用开发带来麻烦,使用同样的查询语句,最后的结果会因人而异。下面通过一个例子来看如何应用 DB2 10RCAC 技术。在这个例子中,使用了 DB2 的 sample 数据库。如果用户拿到 DB2 10 的安装介质,就可以来尝试下面的实现步骤。

RCAC 技术实现案例

安装 DB2 10 环境和 sample 数据库

首先在操作系统上安装 DB2 10 副本,然后为实例用户创建实例,本文中使用的实例用户是 db2inst1。查看 DB2 版本为 V10。然后创建 sample 示例数据库。

清单 1. 查看 DB2 版本

				
 db2inst1@idb1122a:~> db2level 
 DB21085I  Instance "db2inst1" uses "64" bits and DB2 code release "SQL10010"
 with level identifier "0201010E". 
 Informational tokens are "DB2 v10.1.0.0", "s111206", "LINUXAMD64101", and Fix 
 Pack "0". 
 Product is installed at "/opt//db2/V10.1". 

清单 2. 创建 sample 示例数据库

				
 db2inst1@idb1122a:~> db2inst1@idb1122a:~> db2sampl -dbpath /db2/sample -name sample 

  Creating database "sample" on path "/db2/sample"... 
  Connecting to database "sample"... 
  Creating tables and data in schema "DB2INST1"... 
  Creating tables with XML columns and XML data in schema "DB2INST1"... 

  'db2samp' processing complete. 

定义相关用户和角色

DB2 权限控制是针对访问者的控制,也就是最终用户。DB2 的用户认证是由操作系统或者第三方用户认证软件来完成的。所以本案例中需要在操作系统创建连接数据库的用户。本案例在操作系统创建了两个用户 pernal 和 sanders 用以展示。

清单 3. 创建角色

				
 db2inst1@idb1122a:~> db2 create role manager 
 DB20000I  The SQL command completed successfully. 

清单 4. 关联用户和角色

				
 db2inst1@idb1122a:~> db2 grant manager to sanders with admin option 
 DB20000I  The SQL command completed successfully. 

到此可以看到 , 案例的连接用户有两个。Sanders 是一个 manager,而 pernal 就是一个普通职员。本文设计的情景中,这两个用户多会去访问 staff 这张表。Sanders 可以看到 staff 里面自己和属于自己员工的信息。而 pernal 只能看到自己的信息。在 staff 这张表中有一列 SALARY,记载的是每个人的薪水信息,这个信息是机密的,只有员工自己能看到。所以无论是 Sanders 还是 pernal,他们都只能看到自己的 salary 信息,而不能看到其他人的,即使 Sanders 是 manager,他也不能看到自己员工的财务信息。

推荐阅读
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
author-avatar
我就是老笨2013
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有