一种对数据库管理员权限进行控制的方法

文档序号:6442536阅读:4377来源:国知局
专利名称:一种对数据库管理员权限进行控制的方法
技术领域
本发明涉及一种数据库管理员权限控制方法,尤其涉及一种通过转移自主访问控制归属和受限管理员权限模式实现的数据库管理员权限控制方法,属于数据库安全技术领域。
背景技术
在通常的数据库系统中,管理员拥有以下权限>启动或停止非安全相关的系统功能>实现对系统中基本资源的管理,例如表空间、数据库管理等>管理自主存取控制的权限 普通用户的创建和管理 角色的创建和管理· GRANT (授权)和REVOKE (撤销授权)语句>具有普通用户创建各种对象的能力而数据库安全员拥有以下权限>启动和停止强制存取控制功能>创建、删除、应用或移除策略>创建、删除标签>授予和回收强制存取控制的特权>管理默认安全员的用户属性,例如密码>创建和管理其它安全员对于数据库管理员而言,其拥有的操作特权越多,受到的访问限制越少。一旦出现账号泄露的情况,造成的损失也越大。因此,通过合理限制数据库管理员的权限,能够有效减少数据库管理中的不安全因素。在申请号为200610019230.8的中国发明专利申请中,公开了一种应用于数据库安全管理的三权分立安全方法,其特点是把数据库管理员分为数据库管理员、数据库审计员和数据库安全员三类,其中数据库管理员完成自主存取控制、系统维护及管理,数据库审计员完成系统的审计,而数据库安全员完成系统的安全(标记)管理。该方法实现了数据库系统权限的三权分立,对应这三个权限的系统管理员之间分工明确,各司其责,既相互制约又相互配合,共同实现数据库的安全管理功能。这种体系结构不仅解决了国内外数据库产品中存在的系统权限过于集中的问题,同时也实现了国家标准中所要求的强制访问控制功能,进一步提高了系统的安全性。在没有采用三权分立的数据库系统中,数据库管理员拥有极大的权限,从另一个角度说也带来了无尽的隐患。一旦账号泄密,则数据库所有的安全保障都不复存在。因此对于数据库系统的安全管理来说,对数据库管理员进行一定程度的权限控制是非常必要的。 另一方面,数据库管理员对数据库中各种对象的无限制访问,通常也会带来安全隐患。通过
3限制数据库管理员对私有对象的访问,从而减少安全隐患的发生也是非常有必要的。

发明内容
本发明所要解决的技术问题在于提供一种对数据库管理员权限进行控制的方法。 利用该方法可以使数据库管理员不再对普通用户的私有对象具有访问和操作的权限。为实现上述的发明目的,本发明采用下述的技术方案一种对数据库管理员权限进行控制的方法,其特征在于包括如下步骤步骤1 通过权限控制接口,对数据库管理员是否为受限状态进行设置;步骤2 设置数据库管理员运行状态;步骤3 将数据库管理员的运行状态保存成为一个布尔值,如果该值为真,则表示数据库管理员运行于不能访问私有对象的受限模式;如果该值为假,则表示数据库管理员运行于权限开放模式。其中较优地,所述步骤2中,通过增加SQL语句设置数据库管理员运行状态。其中较优地,在所述步骤3中,通过对所述SQL语句进行解析和执行,将数据库管理员的运行状态保存成为布尔值。其中较优地,在对数据库管理员的权限操作中,通过固定的API去查询数据库管理员的权限状态。其中较优地,将所述API的返回值与反映数据库管理员运行状态的所述布尔值进行与操作,判断出所述数据库管理员当前是否有权限执行相关的操作。其中较优地,进行自主访问控制权限查询时,如果是数据库安全员则继续执行;如果是数据库管理员则结束执行。其中较优地,所述自主访问控制通过SQL语句的方式进行设置。本发明对数据库管理员的权限进行了重新界定,使数据库管理员不再必然拥有自主访问控制权限和对普通用户的私有对象进行访问和操作的权限,从而有效减少了安全隐患的发生,进一步改善了数据库系统的安全性能。


下面结合附图和具体实施方式
对本发明作进一步的详细说明。图1为本发明中设置自主访问控制权限的示意图;图2为本发明中设置数据库管理员访问私有对象权限的示意图;图3为本发明中,数据库管理员访问私有对象的操作流程图。
具体实施例方式在本发明中,通过将自主访问控制权限转移给安全员以及限制数据库管理员访问私有对象权限的方式,实现对数据库管理员的权限控制。下面对此展开具体的说明。自主访问控制(Discretionary Access Control, DAC)通过设置数据库中各种关系的访问权限来实现对数据库用户的约束。在现有的数据库技术中,特别是采用三权分立权限分配机制的数据库系统中,通常自主访问控制的权限属于数据库管理员,而强制防伪控制的权限属于数据库安全员。这种权限分配方式将自主访问控制作为一种常规的数据库功能来对待,实际上是忽略了自主访问控制的本质。本发明人认为自主访问控制是对用户操作SQL对象进行授权管理。它与强制访问控制一样,都具有限制用户对对象访问权限的特点,都是维护数据库安全的重要手段,因此将自主访问控制的设置权限归属到数据库安全员的名下是实至名归的。与强制访问控制相比较,自主访问控制具有实施简单、粒度较粗等特点,但是自主访问控制作为权限控制的一种方式,对维护数据库的安全也具有重要的作用。其对数据库安全性的重要影响决定了其操作权更适合交给数据库安全员。为此如图1所示,本发明将自主访问控制的设置权限从数据库管理员中划分出去(数据库管理员的其它权限不变), 将其归属于数据库安全员,即数据库安全员具有对数据库进行自主访问控制的权限,而数据库管理员将不能对数据库进行自主访问控制。这样,数据库安全员同时具有自主访问控制和强制访问控制的权限,不但能够有效地限制数据库管理员的超级特权,同时也能够将这两种访问控制手段有机地结合起来阻止对数据库的非法访问。自主访问控制是通过SQL语句的方式进行设置的。在经过词法和语法解析后,数据库管理系统会进行权限查询,查看当前用户是不是数据库管理员,如果是数据库管理员则正常执行。因此,我们可以将权限查询修改为如果是数据库安全员则继续执行,从而将自主访问控制权限转移到数据库安全员。数据库安全员能够对数据库表应用各种自主访问控制的权限,同时也能够取消自主访问控制的权限。如图2所示,本发明进一步限制了数据库管理员对访问私有对象的权限,即在数据库系统由权限受限的数据库管理员开启的情况下,数据库管理员不再对普通用户的私有对象具有访问和操作的权限。在默认情况下,除非数据表的属主用户自主授权,否则数据库管理员无法查询、修改和删除用户自有的数据表。这种对数据库管理员限制私有对象访问权限的操作可以通过由数据库安全员设置受限模式的方式来进行,具体说明如下在数据库系统中,各种访问权限大致可以分为>系统权限是执行特定操作的权限。这些权限包括CREATE DATABASE、CREATE USER,CREATE ROLE 的权限,具体分为 SUPERUSER、SSO、SAO、CREATEDB 和 CREATER0LE 五个系统权限。>对象权限是对给定的用户授予在给定对象(例如表)上执行的操作集。这些操作可以指明为INSERT、SELECT等,具体参见表1
对象权限TABLESELECT I INSERT | UPDATE | DELETE | REFERENCES | TRIGGERVIEWSELECT I INSERT | UPDATE | DELETE |
权利要求
1.一种对数据库管理员权限进行控制的方法,其特征在于步骤1 通过权限控制接口,对数据库管理员是否为受限状态进行设置; 步骤2 设置数据库管理员运行状态;步骤3 将数据库管理员的运行状态保存成为一个布尔值,如果该值为真,则表示数据库管理员运行于不能访问私有对象的受限模式;如果该值为假,则表示数据库管理员运行于权限开放模式。
2.如权利要求1所述的对数据库管理员权限进行控制的方法,其特征在于 所述步骤2中,通过增加SQL语句设置数据库管理员运行状态。
3.如权利要求2所述的对数据库管理员权限进行控制的方法,其特征在于在所述步骤3中,通过对所述SQL语句进行解析和执行,将数据库管理员的运行状态保存成为布尔值。
4.如权利要求3所述的对数据库管理员权限进行控制的方法,其特征在于还包括下述步骤在对数据库管理员的权限操作中,通过固定的API去查询数据库管理员的权限状态。
5.如权利要求4所述的对数据库管理员权限进行控制的方法,其特征在于 将所述API的返回值与反映数据库管理员运行状态的所述布尔值进行与操作,判断出所述数据库管理员当前是否有权限执行相关的操作。
6.如权利要求1或4所述的对数据库管理员权限进行控制的方法,其特征在于还包括下述步骤进行自主访问控制权限查询时,如果是数据库安全员则继续执行;如果是数据库管理员则结束执行。
7.如权利要求6所述的对数据库管理员权限进行控制的方法,其特征在于 所述自主访问控制通过SQL语句的方式进行设置。
全文摘要
本发明公开了一种对数据库管理员权限进行控制的方法,包括如下步骤步骤1通过权限控制接口,对数据库管理员是否为受限状态进行设置;步骤2设置数据库管理员运行状态;步骤3将数据库管理员的运行状态保存成为一个布尔值,如果该值为真,则表示数据库管理员运行于不能访问私有对象的受限模式;如果该值为假,则表示数据库管理员运行于权限开放模式。本发明对数据库管理员的权限进行了重新界定,使数据库管理员不再必然拥有自主访问控制权限和对普通用户的私有对象进行访问和操作的权限,从而有效减少了安全隐患的发生,进一步改善了数据库系统的安全性能。
文档编号G06F17/30GK102411689SQ20111043371
公开日2012年4月11日 申请日期2011年12月21日 优先权日2011年12月21日
发明者刘革非, 孙旭, 杨经正, 王建华 申请人:北京人大金仓信息技术股份有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1