网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.oracle中用创建表时Storage中参数.
.PROC++批量导入导出ORACLE数据.
.如何单独备份一个或多个用户?.
.关于数据库名(db_name)、实例名(.
.library cache pin与PROCEDURE的.
.Oracle数据库空间的使用和管理若.
.归档问题.
.自己作一张软盘的linux.
.关于临时段(temporary segment)的.
.在.net安装程序中部署oracle客户.
.ORACLE控制文件的重建.
.理解oracle的网络结构 解决你的连.
.Oracle AS 10g 下部署 ColdFusio.
.linux安装Oracle启动图形界面问题.
.一次恢复oracle的尝试.
.用Oracle的SQL*Plus工具创建HTML.
.Oracle数据库技术(34).
.Oracle数据库取消8080端口占用.
.轻松解决Oracle 10g 的em中文乱码.
.Oracle性能究极优化 上.

如何利用oracle 10g的列值掩码技术隐藏敏感数据

发表日期:2008-2-9


Oracle的虚拟私有数据库特性(也称作细颗粒度存取控制)对诸如SELECT等数据治理语言DML语句提供行级安全性检查。PL/SQL策略函数和某个数据表相关联,这个函数可以检查当前用户的上下文背景并添加查询中WHERE语句的条件(断言),一个用户或者应用可以这样来写: SELECT * FROM employees; 但是实际上oracle将会执行这样的语句: SELECT * FROM employees

WHERE department_id = 60; 因此,只有在查寻范围之内的行(在department数据表中的前60行)才会被查询语句返回。利用oracle 10g中的新选项可以让oracle返回所有行,而不仅仅是被授权的行。然而,未被授权行中包含的某些列(称为安全相关列)将显示NULL来代替实际数据,而其它的列值将会正常显示。 要想使用列值掩码必须在虚拟私有数据库策略中做两件事。 首先必须创建一个列级策略来设计某些列为安全相关列.其次必须在查询中包含ALL_ROWS选项以用来返回所有行。这两个参数的结合就可以实现列值掩码。 列表A显示了一个称为rls_dept的策略函数。它返回断言“department_id=60”,用来设定对于EMPLOYEES表中60行之内的department字段。(实际上,这个函数并不返回一个静态表,它可以确定当前用户是谁,并据此返回给该用户正确的部门值。) 列表B显示了如何应用列表A中的函数创建列值掩码。在DBMS_RLS包中的过程ADD_POLICY创建一个称为restrict_dept_policy的新策略。参数sec_relevant_cols表明字段salary和commission_pct是安全相关列。一个包含上述两个字段的查询将会应用到该策略函数,不包含的查询就不会应用该策略。最后,参数sec_relevant_cols_opts设定为常量ALL_ROWS。 列值掩码应用于SELECT语句,无论哪个客户访问数据库都可以实施列值掩码,诸如SQL *Plus、.NET应用或者其它工具。 列表A: CREATE OR REPLACE

FUNCTION rls_dept (obj_owner IN VARCHAR2, obj_name IN VARCHAR2)

RETURN VARCHAR2

AS

predicate                 

VARCHAR2 (200);

BEGIN

predicate := 'department_id = 60';

RETURN (predicate);

END rls_dept;

/ 列表B: BEGIN

DBMS_RLS.ADD_POLICY(object_schema=>'HR',

object_name=>'EMPLOYEES',

policy_name=>'restrict_dept_policy',

function_schema=>'HR',

policy_function=>'rls_dept',

sec_relevant_cols=>'salary,commission_pct',

sec_relevant_cols_opt=>dbms_rls.ALL_ROWS);

END;

/
上一篇:Oracle系统密码文件创建、使用及维护 人气:792
下一篇:Oracle 9i数据库中动态重配置深入分析 人气:740
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐