PHP7和PHP5在安全上有什么区别


本篇内容主要讲解“PHP7和PHP5在安全上有什么区别”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP7和PHP5在安全上有什么区别”吧!函数修改1. preg_replace()不再支持/e修饰符利用e修饰符执行代码的后门大家也用了不少了,具体看官方的这段描述:很不幸,在PHP7以上版本不在支持e修饰符,同时官方给了我们一个新的函数preg_replace_callback:这里我们稍微改动一下就可以利用它当我们的后门:2. create_function()被废弃少了一种可以利用当后门的函数,实际上它是通过执行eval实现的。可有可无。3. mysql_*系列全员移除如果你要在PHP7上面用老版本的mysql_*系列函数需要你自己去额外装了,官方不在自带,现在官方推荐的是mysqli或者pdo_mysql。这是否预示着未来SQL注入漏洞在PHP上的大幅减少呢~4. unserialize()增加一个可选白名单参数其实就是一个白名单,如果反序列数据里面的类名不在这个白名单内,就会报错。像这样的报错!可以是类名也可以是布尔数据,如果是FALSE就会将所有的对象都转换为__PHP_Incomplete_Class对象。TRUE是没有限制的。也可以传入类名实现白名单。还好现在是可选不是必选,要是默认FALSE逼程序员弄白名单那就真的吐血了。5. assert()默认不在可以执行代码这就是众多马不能用的罪魁祸首了,太多的马用assert()来执行代码了,这个更新基本就团灭,一般情况下修改成eval即可正常运行了~提一下,菜刀在实现文件管理器的时候用的恰好也是assert函数,这导致菜刀没办法在PHP7上正常运行。语法修改1. foreach不再改变内部数组指针这样的代码在php5中,是这样的执行结果:因为数组最后一个元素的 $value 引用在 foreach 循环之后仍会保留,在第二个循环的时候实际上是对之前的指针不断的赋值。php7中通过值遍历时,操作的值为数组的副本,不在对后续操作进行影响。这个改动影响了某些cms的洞在PHP7上无法利用了….你知道我指的是哪个洞的。这个问题在PHP7.0.0以后的版本又被改回去了,只影响这一个版本。2. 8进制字符容错率降低在php5版本,如果一个八进制字符如果含有无效数字,该无效数字将被静默删节。比如这样的代码在php5中的执行结果如下:但是在php7里面会触发一个解析错误。这个问题同样在PHP7.0.0以后的版本又被改回去了,只影响这一个版本。3. 十六进制字符串不再被认为是数字这个修改一出,以后CTF套路会少很多啊~很多骚操作都不能用了~这个没什么好说的,大家都懂。以上代码在PHP5运行结果如下:PHP7运行结果如下:你以为我要说这个在后续版本被改回去了?不,目前截至PHP7.3版本依然没有改回去的征兆,官方称不会在改了。这个讲道理还是蛮伤的。4. 移除了 ASP 和 script PHP 标签现在只有这样的标签能在php7上运行了。字面免费云主机域名意思,影响其实不是很大(只是以后骚套路会少一点)。5. 超大浮点数类型转换截断将浮点数转换为整数的时候,如果浮点数值太大,导致无法以整数表达的情况下, 在PHP5的版本中,转换会直接将整数截断,并不会引发错误。 在PHP7中,会报错。CTF又少一个出题套路,这个问题我只在CTF上见过,影响应该不大。到此,相信大家对“PHP7和PHP5在安全上有什么区别”有了更深的了解,不妨来实际操作一番吧!这里是云编程开发博客网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

相关推荐: 远程访问虚拟专用网——EASY虚拟专用网

1.Easy 虚拟专用网需要解决的问题阶段1—-建立管理连接阶段2—-建立数据连接2.使用XAUTH做用户验证(1) XAUTH(2)AAA的定义AAA是Authentication(验证),Authorization(授权),Accounting(统…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 02/02 12:17
下一篇 02/02 12:17