动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
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教程 ]的信息



本月文章推荐
.Linux 中 x86 的内联汇编.
.REDHAT9下安装Oracle9.2.0的成功.
.oracle 10g中的正则表达式.
.ORACLE在HP-UX下的系列问题处理(.
.如何对CLOB字段进行全文检索?.
.Oracle数据库缓冲区忙等待的原因.
.ORA-01092: ORACLE 例程终止。强.
.Oracle Database 10 g : 为 DBA .
.簇的使用.
.Oracle DBA数据库结构试题精选.
.将纵向数据列表转化为横向数据字.
.关于shared pool的深入探讨(一).
.开放和基于标准的智能套件.
.教你检测Oracle的可用性和表空间.
.我的oracle笔记七(其他).
.处理Oracle数据库中一张有效的Dr.
.Linux 帐号与身份管理.
.Oracle冷备份的不完全恢复(一).
.Oracle Database 10 g : 为 DBA .
.Oracle诊断案例-Job任务停止执行.

利用Oracle的同意安全机制来控制访问

发表日期:2008-2-9 |



  Oracle提供用于控制数据访问规则的多种方式,包括:
  
  同意安全机制(比如系统、对象、作用的优先特权)
  
  同意执行安全(比如定义和触发特权)
  
  虚拟私有数据库(VPD)
  
  N-tier的验证(比如RADIUS的验证服务器)
  
  现在让我们通过查看同意安全机制来开始一些最基本的知识,并了解安全机制的优点和缺欠。原始关系模型为用户提供了用于访问控制的同意特权的方法。这一模型最初是由E.F. Codd描述,并成为了多种商业关系数据库交叉的标准。
  
  Oracle同意安全机制具有多种形式:对象同意,系统特权同意,以及基于功能的同意。这一形式的主要目的是使数据库中的用户可以批准访问特定数据对象来控制数据访问。
  --------------------------------------------------------------------------------
  Oracle安全机制
  这是用于数据控制的Oracle设计的多章节的第二部分。假如你还没有阅读这一部分,可以先查看这一文章系列的第一部分《从开始就注重Oracle设计的安全性》
  --------------------------------------------------------------------------------
  对象特权
  对象特权分配执行一个特定对象的特定操作权利。这里提供了对象特权分配的范例:
  
  同意选择,在用户插入fred, mary, joe;
  
  在定制列表中执行同意插入;
  
  同意所有的用户执行fred;
  
  同意用户查阅中对mary的选择;
  
  你可以看到,对象特权的直接分配需要Oracle数据库用户的每一对象的特定同意。假如你有100个列表和1,000个用户的数据库,这就需要100,000独立的同意声明来分配安全机制。
  
  系统特权
  系统特权包括很多访问方式,比如任何列表的选择。系统特权同意的范例包括以下:
  
  同意建立任何簇(cluster)用于customer_role;
  
  同意选择任何列表用于fred;
  
  同意建立任何列表;
  
  同意建立tablespace用于dba_role。
  
  显然,系统特权应该只限于安全级别不是很高的情况,因为一个简单的同意声明可以将列表上的所有安全机制去掉。
  
  基于功能的安全机制
  功能安全机制可以答应你将相关的同意机制归为一个集合。由于功能机制是一个定义好的特权集合,特权分配给用户就会变得相当轻易,比如以下范例:
  
  建立all_customer的功能安全机制;
  
  同意all_customer的选择,更新;
  
  同意all_customer选择item_table;
  
  功能安全机制的优点在于它的明显性,这是因为功能安全机制答应你定义一套访问规则,然后分配给合适的用户。
  
  然而,与VPD安全机制不一样,执行数据访问的复杂规则是不可能的。
  
  同意安全机制的设计
  假如你要执行Oracle数据库的安全机制,你必须做一些仔细的前期计划以确保每一功能都满足不同用户的访问,而且功能上不冲突。设计同意安全机制的步骤如下:
  
  1.    定义所有已经的不同类别的用户的功能。
  
  2.    定义每种功能的访问规则。
  
  3.    定义所有行、列的访问限制。
  
  4.    建立所有数据访问的查看。
  
  5.    分配功能的查看。
  
  6.    分配用户的功能。
  
  为了减少功能重复的可能性,很多Oracle设计者建立功能的等级性,如图A所示。
  
  
图A

  
利用Oracle的同意安全机制来控制访问

  用户组访问
  可以注重到程序员和分析任务之间访问特权的重复性。程序员必须非常地注重访问的要点。
  
  在实际操作中,功能的设计可能会变得复杂。
  
  行和列访问的设计
  在实际设计中,同意访问整个列表并不是很简单,通常你需要在一个列表内限制特定行的访问。唯一可实现的方法是建立每一行的限制独立查看,然后将查看分配给用户功能。例如,假设你是做基于下面商业规则的设计功能:
  
  只有治理者才能查看雇员的工资列(列限制)。
  
  其他雇员只能查看雇员名字和电话号码(行限制)。
  为了能够在Oracle中使用功能安全机制来执行这一设计,可以采用以下步骤:
  
  建立治理者和雇员的基本功能。
  
  建立合适的查看。
  
  同意功能的查看。
  
  在Oracle中,表A说明了这一设计。

  
  现在你可以分配合适的同意声明,然后测试查看结果,并看看它们是怎么工作(表B)。
  
  同意安全机制的漏洞
  设计中同意安全机制产生漏洞有很多观点。包括:
  
  分配同意给PUBLIC。
  
  使用WITH ADMIN选择分配功能。
  
  重复、未设计的访问功能。
  
  分配系统特权给功能。
  
  建立公共的同义字。
  
  例如,在Oracle中你可以明确将权利赋予公用的列表,这样就可以具备只读访问。这种系统特权取代了功能安全机制,并生成了漏洞,如下所示:
  
  生成pubs.customer的公用同字义的用户;
  
  同意用户的公用选择;
  
  另一个重要漏洞是列表的公用同义字。请记住,Oracle在缺省情况下是nobody,除非是对象答应执行列表的任何操作。同样,列表名称必须在SQL中定义,如表C所示。
  
  现在,当你与一个名为SCOTT的用户连接,他是不能看到列表的行,如表D中的例子所示。
  
  在这种情况下,你知道列表是存在的,但Oracle只承认有权限的列表名称(可参见表 E)。
  
  复杂性
  从表面上看,设计Oracle数据库的同意安全机制很复杂。本文中提到的观点提供了建立Oracle安全机制的新方法,以及同意执行模型和VPD。在下面两个章节里,我将会检查采用这些新方法的数据库设计。
上一篇:Oracle 数据安全问题面面观(1) 人气:441
下一篇:一些 schema 的常用脚本归类介绍 人气:413
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-24 Sablog-X v2.0 预览版
2008-7-24 帝国备份王EmpireBak 2008 正式版
2008-7-24 网趣网上购物系统时尚版 v8.2
2008-7-24 纵横B2B电子商务系统XYECS!B2B v
2008-7-24 e路小说小偷 v1.2.0723
2008-7-24 凌风美女图片站程序 v2.2
2008-7-24 TOM15电影收索程序
2008-7-24 清风信息自动采集生成系统 v1.0
2008-7-24 QQ邮箱编辑器 v1.0 (小小菜刀ASP
2008-7-19 UltraEdit 简体中文增强版 14.10
2008-7-19 CentOS 5.2 i386 LiveCD
2008-7-19 Snapture多功能相机 v1.4
2008-7-19 iAcces中文输入法 v1.0Build016
2008-7-19 Cookbook烹饪秘籍 v2.5
2008-7-19 苹果专用DVD转换工具 v1.1.59汉化
2008-7-19 Modem修复软件ZiPhone修改版04.0
2008-7-19 AgileMessenger即时通讯工具美化
2008-7-19 Sketches画图软件 v0.7b6破解版


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号