oracle IF_Oracle登陆状态码研究及代码实现

179885947fddfe89c1631b561c4d3b0a.png

浑水摸鱼,也不过是为了能得过且过。

517981f8a75e4733f59bfbcf96fee972.png

0x00前言

常见的数据库端口服务爆破中,Oracle比其他数据库更为复杂一些,

主要是由于Oracle登录时需要指定实例名or服务名+账号+密码+登陆权限。

本文属于日常基础研究,主要对Oracle登陆状态码进行分析,及实现一个简单的python脚本用于Oracle SID及口令爆破。

517981f8a75e4733f59bfbcf96fee972.png

0x01 Oracle SID与SERVICE_NAME

Navicat连接方式

需求参数

Basic SID连接

IP,SID,用户名,密码

Basic ServerName连接

IP,ServerName,用户名,密码

TNS Name连接

tnsnames.ora,用户名,密码

实例名(SID)与服务名(SERVICE_NAME)的介绍和区别

ce0614084226eb19cd1c746bd0fa00e6.png

经过实际测试发现,默认安装的(oracle11g)中,Navicat上使用sid和ServerName相同,都可以成功连接数据库。

517981f8a75e4733f59bfbcf96fee972.png

0x02 Navicat15下常见Oracle连接报错状态码

ORA-12170: (连接超时,端口无法通信)

TNS: Connect timeout occurred

ORA-12505: (SID错误,能够通信)

TNS:listener does not currently know of SID given in connect descriptor

ORA-12504: (没有提供SERVICE_NAME)

TNS:listener was not given the SERVICE_NAME in CONNECT_DATA

ORA-12514: (SID或服务名错误,能够通信)

TNS: listener does not currently know of service requested in connect descriptor

ORA-28000: (该账户锁定,不判断密码是否正确)

the account is locked

ORA-01017: (用户名或密码错误)

invalid username/password logon denied

ORA-28009: (此时密码正确,需切换DBA角色登陆)

connection as SYS should be as SYSDBA or SYSOPER

ORA-01031: (该账户不是DBA权限,不保证账户存在)

insufficient privileges

ORA-28547:(连接的oci.dll版本文件版本或配置不正确)

默认角色下,Oracle登陆判断顺序

网络连接—>SID/服务名—>账号锁定判断—>账户密码判断—>权限判断

DBA角色下,Oracle登陆判断顺序

网络连接—>SID/服务名—>账号权限判断—>账号密码判断

517981f8a75e4733f59bfbcf96fee972.png

0x03 现有SID及服务名爆破工具测试

默认安装的SID及服务名一般为orcl,但是也有很多时候不是默认名称,此时就需要对sid进行爆破尝试

已有SID爆破工具测试: oracle11g

MSF模块admin/oracle/sid_brute

可行

Nmap脚本 --script=oracle-sid-brute

可行

Sidguess (kali)

可行

Nmap脚本 --script=oracle-enum-users

不可行

Oscanner (kali)

不可行

517981f8a75e4733f59bfbcf96fee972.png

0x04 Python开发Oracle SID爆破脚本

实现思路:

输入任意账号密码连接,判断响应是否包含ORA-12514。

963e98b01fdac2cc6830fc94c6e64783.png

下载地址: 

https://github.com/winezer0/Oracle_Brute

PS:windows下需要配置instantclient环境变量

517981f8a75e4733f59bfbcf96fee972.png

0x05 Oracle连接配置注意事项

1、连接 oracle基础需要下载配置instantclient, Navicat15自带instantclient_11.2, 目前新版本有instantclient_19.8,经过测试,高版本号instantclient可用于连接低版本号Oracle。

2、部分windows下的Oracle爆破脚本基于instantclient实现,因此最好将instantclient加入PATH环境变量。

3、使用tns方式连接Oracle数据库需要配置tnsnames.ora文件,然后新建环境变量TNS_ADMIN并配置目录,将文件放置在该目录下。在Navicat连接类型中选择tns,若tnsnames.ora配置正确,此时网络服务名会有下拉框会显示配置好的服务名,然后输入账号密码登录。(常见于内网CS程序的的客户端机器使用)

4、使用sys账号登陆时,如果账号密码正确,会提示ORA-28009: connection as SYS should be as SYSDBA or SYSOPER,需要在高级设置里指定登录角色为SYSDBA or SYSOPER。

5、其他Oracle脚本推荐(未测试):Oracle12c密码暴破

SpiderLabs/oracle_pwd_tools:

https://github.com/SpiderLabs/oracle_pwd_tools

517981f8a75e4733f59bfbcf96fee972.png

0x06 结束语

感谢大哥们的对NOVASEC的支持点赞和关注,加入我们与萌新一起成长吧

4fa32c8d20b33903d054b582d4718085.png

如有任何问题、建议、投稿请加NOVASEC-MOYU,以方便及时回复。

517981f8a75e4733f59bfbcf96fee972.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值