问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

Oracle数据库基本知识

发布网友 发布时间:2022-08-20 04:40

我来回答

1个回答

热心网友 时间:2023-10-31 12:05

Oracle数据库基本知识

  Oracle Database,又名OracleRDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。本文为大家分享的是Oracle数据库的基本知识,希望对大家有所帮助!

  它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的适应高吞吐量的数据库解决方案。

  介绍

  ORACLE数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一。比如SilverStream就是基于数据库的一种中间件。ORACLE数据库是目前世界上使用最为广泛的数据库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库,它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能。但它的所有知识,只要在一种机型上学习了ORACLE知识,便能在各种类型的机器上使用它。

  Oracle数据库最新版本为OracleDatabase 12c。Oracle数据库12c引入了一个新的多承租方架构,使用该架构可轻松部署和管理数据库云。此外,一些创新特性可最大限度地提高资源使用率和灵活性,如Oracle Multitenant可快速整合多个数据库,而Automatic Data Optimization和Heat Map能以更高的密度压缩数据和对数据分层。这些独一无二的技术进步再加上在可用性、安全性和大数据支持方面的主要增强,使得Oracle数据库12c 成为私有云和公有云部署的理想平台。

  就业前景

  从就业与择业的角度来讲,计算机相关专业的大学生从事oracle方面的技术是职业发展中的最佳选择。

  其一、就业面广:ORACLE帮助拓展技术人员择业的广度,全球前100强企业99家都在使用ORACLE相关技术,中国*机构,大中型企事业单位都能有ORACLE技术的工程师岗位,大学生在校期间兴趣广泛,每个人兴趣特长各异,不论你想进入金融行业还是电信行业或者*机构,ORACLE都能够在你的职业发展中给你最强有力的支撑,成为你最贴身的金饭碗。

  其二、技术层次深:如果期望进入IT服务或者产品公司,Oracle技术能够帮助提高就业的深度。Oracle技术已经成为全球每个IT公司必选的软件技术之一,熟练掌握Oracle技术能够为从业人员带来技术应用上的优势,同时为IT技术的深入应用起到非常关键的作用。掌握 Oracle技术,是IT从业人员了解全面信息化整体解决方案的基础。

  其三、职业方向多:Oracle数据库管理方向、Oracle开发及系统架构方向、Oracle数据建模数据仓库等方向。

  Oracle数据库漏洞分析:无需用户名和密码进入你的数据库

  一般性的数据库漏洞,都是在成功连接或登录数据库后实现入侵;本文介绍两个在2012年暴露的Oracle漏洞,通过这两种漏洞的结合,可以在不掌握用户名/密码的情况下入侵Oracle,从而完成对数据的窃取或者破坏。这两个漏洞就是CVE-2012-1675和CVE-2012-3137。

  引言

  国内外很多重要的系统都采用Oracle作为数据存储的数据库;在Oracle中存储着企业或*大量敏感的信息,在金钱或*的诱导下,内外部黑客会想法利用管理、网络、主机或数据库的自身漏洞尝试入侵到数据库中,以达到自身的目的。

  本文的作者通过对Oracle俩种漏洞的组合研究,设计了一套在不掌握用户名/密码的方式入侵到Oracle中;这种方法,比传统的需要登录到数据库中的入侵方法,具有更大的安全隐患和破坏性。

  本文希望通过对这两个漏洞和攻击方法的介绍,能够引起相关人员的重视,完善对数据库安全的措施。

  1、概要介绍

  本文提供的方法是基于漏洞CVE-2012-1675和CVE-2012-3137对oracle数据库的攻击测试的方法。

  CVE-2012-1675漏洞是Oracle允许攻击者在不提供用户名/密码的'情况下,向远程“TNS Listener”组件处理的数据投毒的漏洞。攻击者可利用此漏洞将数据库服务器的合法“TNS Listener”组件中的数据转向到攻击者控制的系统,导致控制远程组件的数据库实例,造成组件和合法数据库之间的中间人攻击、会话劫持或拒绝服务攻击。

  CVE-2012-3137漏洞是Oracle Database 10g/11g身份验证协议实现中存在一个设计缺陷,攻击者无需认证即可远程获取数据库用户密码哈希相关数据,从而可以离线暴力破解用户密码,进一步控制数据库系统。

  我们通过如下的步骤和过程可以实现对Oracle的入侵:

  (1)利用CVE-2012-1675进行TNS劫持,在监听下利用远程注册,注册同名数据库实例;

  (2)新登陆的用户,在TNS的负载均衡策略下,有可能流量登录到伪造的监听服务上;

  (3)该监听服务对用户的登陆过程进行监控,并将相关数据流量转发到真实的数据库上;

  (4)利用CVE-2012-3137获得通讯过程中的认证相关信息;

  (5)对认证相关信息进行离线的暴力破解,获得登陆的密码;

  (6)试用破解的用户名/密码登陆Oracle,完成对Oracle中数据的访问;

  2、通过CVE-2012-1675进行TNS劫持

  该漏洞存在于Oracle的所有版本,并且Oracle至今仅是发布了警告性通知,并未提供解决方案。

  要想利用CVE-2012-1675漏洞做TNS劫持,首先需要了解TNS机制。如下图所示oracle 通过在本地解析网络服务名到目标主机IP地址,服务端口号,目标数据库名,把这些信息发送到oracle服务器端监听程序,最后再由监听程序递送DBMS。

  其中关键点在于监听会按照目标数据库名递送到名称正确的数据库。那么如果一个监听下有2个同名数据库。监听将自动按照负载均衡把这次访问发送到负载低的数据库上,进行连接访问。数据库注册到监听的方法就决定了,能否同时注册同名数据库在同一个监听下。注册方式分为本地注册和远程注册,通过修改参数可以调整为远程注册。

  下面是一段可用的TNS劫持的过程:

  1.在劫持机上创建一个和目标数据库实例同名的数据库实例。

  2.在劫持机上修改 tnsnames.ora 文件

  添加

  listener_name=

  (DESCRIPTION=

  (ADDRESS=(PROTOCOL=tcp)(HOST=目标机器IP)(PORT=目标机器端口)))

  3.在劫持机上用SQL*Plus 顺序执行下面步骤。

  1.$ sqlplus / as sysdba

  2. SQL> ALTER SYSTEM SETREMOTE_LISTENER='LISTENER_NAME';

  3. SQL> ALTER SYSTEM REGISTER;

  4.多个客户端,向数据库发起登录。会劫持到一部分客户端的登录信息。

  最终达到效果如下图所示:

  按照猜想同一个监听下有2个同名实例。客户端访问监听,监听按照客户端中的数据库名信息分配数据库,由于监听下有2个同名数据库,客户端链接很可能会被分配到劫持者的数据库实例下,再通过配置劫持者的本地监听把客户端请求指回原数据库。结构图如下:

  测试客户端链接196次。目标数据库实例获得113次,劫持数据库实例获得83次基本满足负载均衡的假设。(注上面实例是local server 下面实例是 remote server)

  通过以上方式我们可以截获约一半左右客户端发送到服务器的合法链接。其中获得了服务器IP、端口号、数据库位置、实例名、登录用户名等一系列明文信息和4组密文信息(AUTH_SESSKEY,AUTH_SESSKEY_CLIENT,AUTH_PASSWORD,AUTH_VFR_DATA)。

  3、通过CVE-2012-3137进行密码破解

  CVE-2012-3137受影响的数据库版本有11.2.0.3,11.2.0.2,11.1.0.7,有使用了SHA-1加密算法的10.2.0.5和10.2.0.4,还有使用了SHA-1的10.2.0.3(运行在z/OS下)版本。

  虽然这个漏洞在11.2.0.3中已经解决,但是仅仅数据库客户端和服务器都升级到11.2.0.3并且sqlnet.ora文件中增加SQLNET.ALLOWED_LOGON_VERSION=12才有效。

  正如CVE-2012-3137所描述Oracle为了防止第三方通过网络获取登录信息包。而对密码进行了加密处理。本部分只以oracle11.1密码如何破解为例进行说明。

  在发起连接之后(oracle牵手完成),客户端和服务器经过协商确定要使用的验证协议。要完成这个任务,客户端首先向数据库发送一个包。包中包含客户端主要信息和所请求的加密方式。数据库确认加密方式有效后,发送一个确认服务包如下图所示:

  在通过安全网络服务完成任何所要求的协议之后,数据库用户被O3logon(oracle验证方式) 进行验证,这个协议执行一个序列来向数据库证明客户端拥有密码。为了避免网络第三方截获到密码。首先客户端发送用户名到数据库来表明用户身份。数据库端根据加密协议,其中96位的作为数据库端密钥,20位的作为偏移量,它对每个连接都是不同的。一个典型的数据库端发给客户端的密钥如下:

  AUTH_SESSKEY.....COCDD89FIGODKWASDF……………………

  客户端根据加密算法向服务器端发送96位的客户端密钥和64位的密码密钥。服务器端计算客户端传入的密码密钥。如果计算后密码密文和数据库中存储的16位密码密文一致则验证通过。

  根据这个过程可知上面TNS劫持包中取得的加密信息:AUTH_SESSKEY,AUTH_SESSKEY_CLIENT,AUTH_PASSWORD,AUTH_VFR_DATA这四个值是解密的关键。我们把他们按照SHA1,MD5,AES192进行一系列处理。最终通过数据字典碰撞得到密码明文。

  下面这段网上公布的一段示例代码,这段代码与笔者的思路不完全相同,但也能大概地说明这个漏洞的攻击过程:

  import hashlib

  from Crypto.Cipher import AES

  def decrypt(session,salt,password):

  pass_hash= hashlib.sha1(password+salt)

  key =pass_hash.digest() + '\x00\x00\x00\x00'

  decryptor= AES.new(key,AES.MODE_CBC)

  plain =decryptor.decrypt(session)

  returnplain

  session_hex ='EA2043CB8B46E3864311C68BDC161F8CA170363C1E6F57F3EBC6435F541A8239B6DBA16EAAB5422553A7598143E78767'

  salt_hex = 'A7193E546377EC56639E'

  passwords = ['test','password',''oracle','demo']

  for password in passwords:

  session_id= decrypt(session_hex.decode('hex'),salt_hex.decode('hex'),password)

  print'Decrypted session_id for password "%s" is %s' %(password,session_id.encode('hex'))

  ifsession_id[40:] == '\x08\x08\x08\x08\x08\x08\x08\x08':

  print'PASSWORD IS "%s"' % password

  break

  4、建议的预防措施

  根据以上两段分析,我们可以有如下的预防措施:

  (1)在条件许可的情况下,对Oracle进行补丁升级,对Oracle打cpuoct2012-1515893补丁;注意对于cpuoct2012-1515893补丁要求服务器端和应用服务器端同时升级,否则应用系统将无法访问Oracle;

  (2)若无法对Oracle升级,要购买或安装具备虚拟补丁功能的数据库安全产品,防止对CVE-2012-3137和CVE-2012-1675的利用;

  (3)建立足够强健的口令,不要使用8位以下密码,或者字典库中的口令。

;
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
从焦作市到郑州快递一个羽毛球拍需用多少钱 iPhone X还能坚挺两年,升级到ios 15发热严重要靠红魔冰磁散热器 Peltier Module散热方式 一加18W冰点散热背夹-超强散热,极速降温 2015年春晚有哪些明星 新闻 如何评价央视主持人朱军?以及如何评价朱军所主持的《艺术 纯粮食白酒品牌大全,让你喝得放心(真正的纯粮食白酒有哪些品牌)_百度... ...工作单位要辞退并提出会给出相应赔偿,但合同马上到期,如到期后... ABC外语培训学校ABC教育集团总裁——刘成 abc是国产品牌吗?口碑如何? 立项申请报告的报告用途 怎样运用已下载下来的QQ皮肤? 如何应用已下载的QQ皮肤???!! 美团月付可以最低还吗?和花呗哪个好? 花呗通用额度可以分期吗?最全支付宝分期攻略大全! 蚂蚁花呗当面花怎么还款?试试这些花式还款大法! 花呗当面花在哪里还款?什么时候还款? 绝热材料一般是指导热系数小的材料 什么材料火烧不会烫 时尚买手是一种什么样的职业 帝王蟹为什么叫帝王蟹 莲子炖猪蹄的家常做法大全怎么做好 小品报幕词有哪些? 做梦梦见放生了一个田螺,然后田螺变成了一个小男孩,而且我又不舍得放生了,决心带回家? 财务整合的核心是什么? 财务整合的财务整合的内容 企业支付宝账户存在风险,刷脸不通过,可以选择别的方式去验证吗?要怎么做? 五岭的介绍 贷款进度突然没了是已放款么?有这几种可能 跪求一个大眼睛闭着流泪的图片,我要放到QQ头像上的,越好看越好 边玩英魂之刃怎么发消息 英魂之刃快手女主播怎样发送分享截图至yhzrol 请问游戏英魂之刃怎么发消息?怎么找不到! 韩国的石锅拌饭怎么做耐心解答下! 以为不好看结果熬夜追的几部剧,除了《灵魂摆渡》,你还看过几部? 焊接变形怎么预防? 收视率爆表的作品,《我和僵尸有个约会》堪称经典,你看过几部? 谁有《华胥引》(中国音乐大全·古琴卷·卷五)这首古乐曲?要MP3格式的。 “播出前以为能大火,结果却凉凉”的电视剧,你都看过哪几部呢? 均衡汇率理论的类别 梦见已故老师 启动迅雷7时报错:没有找到dbgeng.dll,因此这个应用程序未能启动。重新安装应用程序可能会修复此问题。 1000个奥特曼你看过几个??? 不思议迷宫罗杰的宝藏怎么过?通关攻略 不思议迷宫罗杰的宝藏挑战技巧讲解 不思议迷宫罗杰的宝藏怎么打 不思议迷宫罗杰的宝藏怎么过 《不思议迷宫》罗杰的宝藏怎么过 不思议迷宫天空战罗杰的宝藏通关攻略 罗杰的宝藏怎么打 不思议迷宫罗杰的宝藏怎么打 罗杰的宝藏关卡攻略