Username: Password:

带您深入了解数据库管理系统层次安全技术
来源:新客网整理转载 作者:新客网整理转载 发布时间:2008-04-29 00:00:00

数据库系统的安全性很大程度上依赖于数据库管理系统。假如数据库管理系统安全机制很强大,则数据库系统的安全性能就较好。现在市场上流行的是关系式数据库管理系统,其安全性功能很弱,这就导致数据库系统的安全性存在一定的威胁。

由于数据库系统在操作系统下都是以文档形式进行管理的,因此入侵者能够直接利用操作系统的漏洞窃取数据库文档,或直接利用OS工具来非法伪造、篡改数据库文档内容。这种隐患一般数据库用户难以察觉,分析和堵塞这种漏洞被认为是B2级的安全技术措施。

数据库管理系统层次安全技术主要是用来解决这一问题,即当前面两个层次已被突破的情况下仍能保障数据库数据的安全,这就需要数据库管理系统必须有一套强有力的安全机制。解决这一问题的有效方法之一是数据库管理系统对数据库文档进行加密处理,使得即使数据不幸泄露或丢失,也难以被人破译和阅读。

我们能够考虑在三个不同层次实现对数据库数据的加密,这三个层次分别是OS层、DBMS内核层和DBMS外层。

⑴在OS层加密。在OS层无法辨认数据库文档中的数据关系,从而无法产生合理的密钥,对密钥合理的管理和使用也很难。所以,对大型数据库来说,在OS层对数据库文档进行加密很难实现。

⑵在DBMS内核层实现加密。这种加密是指数据在物理存取之前完成加/脱密工作。这种加密方式的长处是加密功能强,并且加密功能几乎不会影响DBMS的功能,能够实现加密功能和数据库管理系统之间的无缝耦合。其缺点是加密运算在服务器端进行,加重了服务器的负载,而且DBMS和加密器之间的接口需要DBMS研发商的支持。

◆定义加密需要工具

◆DBMS

◆数据库应用系统

◆加密器

(软件或硬件)

⑶在DBMS外层实现加密。比较实际的做法是将数据库加密系统做成DBMS的一个外层工具,根据加密需要自动完成对数据库数据的加/脱密处理:

◆定义加密需要工具加密器

(软件或硬件)

◆DBMS

◆数据库应用系统

采用这种加密方式进行加密,加/脱密运算可在客户端进行,他的长处是不会加重数据库服务器的负载并且能够实现网上传输的加密,缺点是加密功能会受到一些限制,和数据库管理系统之间的耦合性稍差。

下面我们进一步解释在DBMS外层实现加密功能的原理:

数据库加密系统分成两个功能单独的主要部件:一个是加密字典管理程式,另一个是数据库加/脱密引擎。数据库加密系统将用户对数据库信息具体的加密需要连同基础信息保存在加密字典中,通过调用数据加/脱密引擎实现对数据库表的加密、脱密及数据转换等功能。数据库信息的加/脱密处理是在后台完成的,对数据库服务器是透明的。

◆加密字典管理程式

◆加密系统

◆应用程式

◆数据库加脱密引擎

◆数据库服务器

◆加密字典

◆用户数据

按以上方式实现的数据库加密系统具备很多长处:首先,系统对数据库的最终用户是完全透明的,管理员能够根据需要进行明文和密文的转换工作;其次,加密系统完全单独于数据库应用系统,无须改变数据库应用系统就能实现数据加密功能;第三,加解密处理在客户端进行,不会影响数据库服务器的效率。

数据库加/脱密引擎是数据库加密系统的核心部件,他位于应用程式和数据库服务器之间,负责在后台完成数据库信息的加/脱密处理,对应用研发人员和操作人员来说是透明的。数据加/脱密引擎没有操作界面,在需要时由操作系统自动加载并驻留在内存中,通过内部接口和加密字典管理程式和用户应用程式通讯。数据库加/脱密引擎由三大模块组成:加/脱密处理模块、用户接口模块和数据库接口模块,如图4所示。其中,"数据库接口模块"的主要工作是接受用户的操作请求,并传递给"加/脱密处理模块",此外还要代替"加/脱密处理模块"去访问数据库服务器,并完成外部接口参数和加/脱密引擎内部数据结构之间的转换。"加/脱密处理模块"完成数据库加/脱密引擎的初始化、内部专用命令的处理、加密字典信息的检索、加密字典缓冲区的管理、SQL命令的加密变换、查询结果的脱密处理连同加脱密算法实现等功能,另外还包括一些公用的辅助函数。

数据加/脱密处理的主要流程如下:

(1) 对SQL命令进行语法分析,假如语法正确,转下一步;如不正确,则转6),直接将SQL命令交数据库服务器处理。

(2) 是否为数据库加/脱密引擎的内部控制命令?假如是,则处理内部控制命令,然后转7);假如不是则转下一步。

(3) 检查数据库加/脱密引擎是否处于关闭状态或SQL命令是否只需要编译?假如是则转6),否则转下一步。

(4) 检索加密字典,根据加密定义对SQL命令进行加脱密语义分析。

(5) SQL命令是否需要加密处理?假如是,则将SQL命令进行加密变换,替换原SQL命令,然后转下一步;否则直接转下一步。

(6) 将SQL命令转送数据库服务器处理。

(7) SQL命令执行完毕,清除SQL命令缓冲区。

喜欢本文,那就收藏到:

    Del.icio.us Google书签 Digg Live Bookmark Technorati Furl Yahoo书签 Facebook 百度搜藏 新浪ViVi 365Key网摘 天极网摘 和讯网摘 博拉网 POCO网摘 添加到饭否 QQ书签 Digbuzz我挖网
相关评论  我也要评论
还没有关于此文章的相关评论!
  • 昵称: (为空则显示guest)
  • 评论分数: ★ ★ ★★★ ★★★★ ★★★★★
  • 评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
  • 导航
    赞助商
    文章类别
    订阅