久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

由php中字符offset特征造成的繞過(guò)漏洞詳解

這篇文章主要給大家介紹了關(guān)于由php中字符offset特征造成的繞過(guò)漏洞的相關(guān)資料,文中不僅詳細(xì)介紹了該漏洞的形成,更重要的是介紹了修復(fù)方式,對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需

php中的字符offset特性

php中的字符串存在一個(gè)非常有趣的特性,php中的字符串也可以像數(shù)組一樣進(jìn)行取值。

$test = "hello world";
echo $test[0];

最后的結(jié)果就是h。

但是上述的這種特性有時(shí)會(huì)有意想不到的效果,看下面這段代碼

$mystr = "hello world";
echo $mystr["pass"];

上述的代碼的輸出結(jié)果是h.這是為什么呢?其實(shí)很簡(jiǎn)單,和很多其他的語(yǔ)言一樣,字符串在php中也像數(shù)組一樣可以使用下標(biāo)取值。$mystr["pass"]中pass會(huì)被進(jìn)行隱性類型轉(zhuǎn)換為0,這樣$mystr[0]的輸出結(jié)果就是首字母h.
同樣地,如果嘗試如下的代碼:

$mystr = "hello world";
echo $mystr["1pass"];

輸出結(jié)果就是e.因?yàn)?pass會(huì)被隱性類型轉(zhuǎn)換為1,$mystr[1]的輸出結(jié)果就是第二個(gè)字母e.

字符特性造成的漏洞

下面這段代碼是在在phpspy2006中用于判斷登錄時(shí)所使用的代碼。

$admin['check'] = "1";
$admin['pass'] = "angel";
......
if($admin['check'] == "1") {
....
}

這樣的驗(yàn)證邏輯如果利用上述的特性就很容易地就可以被繞過(guò)。$admin沒有被初始定義為數(shù)組類型,那么當(dāng)我們用字符串提交時(shí)phpsyp.php?admin=1abc時(shí),php會(huì)取字符串1xxx的第一位,成功繞過(guò)if的條件判斷。

上面那段代碼是一個(gè)代碼片段,接下來(lái)的這段代碼是一段完整的邏輯代碼,來(lái)自于php4fun中第5題,比較有意思。

<?php
# GOAL: overwrite password for admin (id=1)
#  Try to login as admin
# $yourInfo=array( //this is your user data in the db
# 'id' => 8,
# 'name' => 'jimbo18714',
# 'pass' => 'MAYBECHANGED',
# 'level' => 1
# );
require 'db.inc.php';

function mres($str)
{
 return mysql_real_escape_string($str);
}

$userInfo = @unserialize($_GET['userInfo']);

$query = 'SELECT * FROM users WHERE id = \'' . mres($userInfo['id']) . '\' AND pass = \'' . mres($userInfo['pass']) . '\';';

$result = mysql_query($query);
if (!$result || mysql_num_rows($result) < 1) {
 die('Invalid password!');
}

$row = mysql_fetch_assoc($result);
foreach ($row as $key => $value) {
 $userInfo[$key] = $value;
}

$oldPass = @$_GET['oldPass'];
$newPass = @$_GET['newPass'];
if ($oldPass == $userInfo['pass']) {
 $userInfo['pass'] = $newPass;
 $query = 'UPDATE users SET pass = \'' . mres($newPass) . '\' WHERE id = \'' . mres($userInfo['id']) . '\';';
 mysql_query($query);
 echo 'Password Changed.';
} else {
 echo 'Invalid old password entered.';
}

這道題目網(wǎng)上也僅僅只是給了一個(gè)最終的答案,其中的原理都沒有說(shuō)或者沒有說(shuō)得很詳細(xì)。其實(shí)原理就是上面講到的php的字符特性。

題目要求很簡(jiǎn)單就是修改admin的密碼,admin的id為1。我們需要思考以下幾個(gè)問(wèn)題:

  • 如何在更新的時(shí)候?qū)d修改為1
  • $userInfo['pass'] = $newPass;這行代碼有什么作用,為什么會(huì)在if判斷語(yǔ)句中存在這種的代碼

想通了這兩個(gè)問(wèn)題,那么最終的解決方法也有了。將id為8的用戶的密碼修改為8,然后傳入一個(gè)userInfo的字符串‘8',突破查詢防護(hù),最后利用$userInfo['pass'] = $newPass將id修改為1。

最終的payload就是;

第一次提交, index.php?userInfo=a:2:{s:2:"id";i:8;s:4:"pass";s:12:"MAYBECHANGED";}&oldPass=MAYBECHANGED&newPass=8,目的是將id為8的用戶的密碼修改為8

第二次提交,index.php?userInfo=s:1:"8";&oldPass=8&newPass=1,這樣序列化$userInfo得到的就是字符串‘8',即$userInfo = ‘8' ,這樣數(shù)據(jù)庫(kù)查詢驗(yàn)證就可以通過(guò)。之后的if驗(yàn)證也可以通過(guò),通過(guò)這行代碼$userInfo['pass'] = $newPass;,由于$newpass的值為1,那么上述代碼變?yōu)榱?code>$userInfo['pass'] = 1; ,$userInfo由于一個(gè)字符串類型,最后得到的是$userInfo='1' ,最后就可以更新id為1的用戶的密碼了。

修復(fù)方式

這種漏洞的修復(fù)方式也很簡(jiǎn)單,事先定義好數(shù)據(jù)類型同時(shí)在使用時(shí)最好檢查一下所使用的數(shù)據(jù)類型是否和預(yù)期的一致。否則就會(huì)出現(xiàn)上述的繞過(guò)的問(wèn)題。同時(shí)要控制好輸入,對(duì)輸入的數(shù)據(jù)要進(jìn)行檢查不要隨意地使用。

參考

https://github.com/80vul/webzine/blob/master/webzine_0x06/PSTZine_0x06_0x03.txt

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)的支持。

【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP定義字符串的四種方式,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
下面小編就為大家分享一篇php 替換文章中的圖片路徑,下載圖片到本地服務(wù)器的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇PHP給源代碼加密的幾種方法匯總(推薦),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇php打開本地exe程序,js打開本地exe應(yīng)用程序,并傳遞相關(guān)參數(shù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
這篇文章主要介紹了PHP類的反射來(lái)實(shí)現(xiàn)依賴注入過(guò)程以及相關(guān)知識(shí)點(diǎn)分享,對(duì)此有興趣的朋友跟著小編學(xué)習(xí)下吧。
php遍歷一個(gè)文件夾內(nèi)的所有文件和文件夾,并刪除所有文件夾和子文件夾下的所有文件的代碼,通過(guò)遞歸方式實(shí)現(xiàn)達(dá)到清空一個(gè)目錄的效果。本文給大家分享實(shí)例代碼,需要的朋友參考
主站蜘蛛池模板: 久久久久成人精品 | 九九精品在线 | 日韩在线播放av | 国产精品免费大片 | 国产96在线 | 久草成人 | 久久免费精品视频 | 日韩欧美中文字幕在线观看 | 精品一区二区av | 精精国产xxxx视频在线播放 | 精品国产乱码久久久久久中文 | 欧美日韩淫片 | 国产精品亚洲综合 | 欧美日韩国产高清视频 | 午夜日韩视频 | 99色综合 | 国产精品久久精品 | 91亚洲国产成人久久精品网站 | 国产欧美精品 | 国产高清在线精品 | 99爱国产 | 91五月天 | 日韩免费网站 | 亚洲高清久久 | 国产激情精品一区二区三区 | 在线色网站 | 日韩在线视频免费观看 | 国产一区二区免费在线 | 国内久久 | av片在线观看 | 国产精品久久久久久久久久久久 | 中国人pornoxxx麻豆 | 国产亚韩| 欧美成人精品一区二区男人看 | 欧美偷偷操 | 91一区二区三区在线观看 | 亚洲精品视频网站在线观看 | 久草免费在线视频 | 国产乱码精品一区二区三区中文 | 精品伊人久久 | 奇米四色在线观看 |