PHP 危险函数全解析


Posted in PHP onSeptember 09, 2009

在编译 PHP 时,如无特殊需要,一定禁止编译生成 CLI 命令行模式的 PHP 解析支持。可在编译时使用 ?disable-CLI。一旦编译生成 CLI 模式的PHP,则可能会被入侵者利用该程序建立一个WEB Shell 后门进程或通过PHP 执行任意代码。
phpinfo()
功能描述:输出 PHP 环境信息以及相关的模块、WEB 环境等信息。
危险等级:中
passthru()
功能描述:允许执行一个外部程序并回显输出,类似于 exec()。
危险等级:高
exec()
功能描述:允许执行一个外部程序(如 UNIX Shell 或 CMD 命令等)。
危险等级:高
system()
功能描述:允许执行一个外部程序并回显输出,类似于 passthru()。
危险等级:高
chroot()
功能描述:可改变当前 PHP 进程的工作根目录,仅当系统支持 CLI 模式PHP 时才能工作,且该函数不适用于 Windows 系统。
危险等级:高
scandir()
功能描述:列出指定路径中的文件和目录。
危险等级:中
chgrp()
功能描述:改变文件或目录所属的用户组。
危险等级:高
chown()
功能描述:改变文件或目录的所有者。
危险等级:高
shell_exec()
功能描述:通过 Shell 执行命令,并将执行结果作为字符串返回。
危险等级:高
proc_open()
功能描述:执行一个命令并打开文件指针用于读取以及写入。
危险等级:高
proc_get_status()
功能描述:获取使用 proc_open() 所打开进程的信息。
危险等级:高
error_log()
功能描述:将错误信息发送到指定位置(文件)。
安全备注:在某些版本的 PHP 中,可使用 error_log() 绕过 PHP safe mode,
执行任意命令。
危险等级:低
ini_alter()
功能描述:是 ini_set() 函数的一个别名函数,功能与 ini_set() 相同。具体参见 ini_set()。
危险等级:高
ini_set()
功能描述:可用于修改、设置 PHP 环境配置参数。
危险等级:高
ini_restore()
功能描述:可用于恢复 PHP 环境配置参数到其初始值。
危险等级:高
dl()
功能描述:在 PHP 进行运行过程当中(而非启动时)加载一个 PHP 外部模块。
危险等级:高
pfsockopen()
功能描述:建立一个 Internet 或 UNIX 域的 socket 持久连接。
危险等级:高
syslog()
功能描述:可调用 UNIX 系统的系统层 syslog() 函数。
危险等级:中
readlink()
功能描述:返回符号连接指向的目标文件内容。
危险等级:中
symlink()
功能描述:在 UNIX 系统中建立一个符号链接。
危险等级:高
popen()
功能描述:可通过 popen() 的参数传递一条命令,并对 popen() 所打开的文件进行执行。
危险等级:高
stream_socket_server()
功能描述:建立一个 Internet 或 UNIX 服务器连接。
危险等级:中
putenv()
功能描述:用于在 PHP 运行时改变系统字符集环境。在低于 5.2.6 版本的 PHP 中,可利用该函数修改系统字符集环境后,利用 sendmail 指令发送特殊参数执行系统 SHELL 命令。
危险等级:高

PHP 相关文章推荐
php+mysql实现无限级分类 | 树型显示分类关系
Nov 19 PHP
生成php程序的php代码
Apr 07 PHP
shopex主机报错误请求解决方案(No such file or directory)
Dec 27 PHP
深入理解用mysql_fetch_row()以数组的形式返回查询结果
Jun 05 PHP
php curl选项列表(超详细)
Jul 01 PHP
php一些错误处理的方法与技巧总结
Aug 10 PHP
WampServer下安装多个版本的PHP、mysql、apache图文教程
Jan 07 PHP
Yii中CArrayDataProvider和CActiveDataProvider区别实例分析
Mar 02 PHP
php生成酷炫的四个字符验证码
Apr 22 PHP
php压缩文件夹最新版
Jul 18 PHP
PHP array_reverse() 函数原理及实例解析
Jul 14 PHP
linux mint下安装phpstorm2020包括JDK部分的教程详解
Sep 17 PHP
php 获取远程网页内容的函数
Sep 08 #PHP
php 遍历数据表数据并列表横向排列的代码
Sep 05 #PHP
不要轻信 PHP_SELF的安全问题
Sep 05 #PHP
php中$_SERVER[PHP_SELF] 和 $_SERVER[SCRIPT_NAME]之间的区别
Sep 05 #PHP
php getsiteurl()函数
Sep 05 #PHP
PHP 内存缓存加速功能memcached安装与用法
Sep 03 #PHP
用PHP读取flv文件的播放时间长度
Sep 03 #PHP
You might like
ajax缓存问题解决途径
2006/12/06 PHP
浅析php变量修饰符static的使用
2013/06/28 PHP
php blowfish加密解密算法
2016/07/02 PHP
php使用Jpgraph创建折线图效果示例
2017/02/15 PHP
加载 Javascript 最佳实践
2011/10/30 Javascript
jQuery Tools Dateinput使用介绍
2012/07/14 Javascript
javascript预加载图片、css、js的方法示例介绍
2013/10/14 Javascript
基于jQuery实现复选框的全选 全不选 反选功能
2014/11/24 Javascript
JQuery动画与特效实例分析
2015/02/02 Javascript
Javascript数据结构与算法之列表详解
2015/03/12 Javascript
javascript封装简单实现方法
2015/08/11 Javascript
静态页面html中跳转传值的JS处理技巧
2016/06/22 Javascript
D3.js实现柱状图的方法详解
2016/09/21 Javascript
JS作用域深度解析
2016/12/29 Javascript
Vue Cli与BootStrap结合实现表格分页功能
2017/08/18 Javascript
node.js自动上传ftp的脚本分享
2018/06/16 Javascript
解决layui中table异步数据请求不支持自定义返回数据格式的问题
2018/08/19 Javascript
解决vue中虚拟dom,无法实时更新的问题
2018/09/15 Javascript
JavaScript 预解析的4种实现方法解析
2019/09/03 Javascript
解决VUEX的mapState/...mapState等取值问题
2020/07/24 Javascript
基于ant design日期控件使用_仅月份的操作
2020/10/27 Javascript
python保存网页图片到本地的方法
2018/07/24 Python
Pyqt5如何让QMessageBox按钮显示中文示例代码
2019/04/11 Python
python turtle 绘制太极图的实例
2019/12/18 Python
Python发送手机动态验证码代码实例
2020/02/28 Python
Python如何实现在字符串里嵌入双引号或者单引号
2020/03/02 Python
如何在windows下安装配置python工具Ulipad
2020/10/27 Python
英国家庭珠宝商:T. H. Baker
2018/02/08 全球购物
JAVA和C++的区别
2013/10/06 面试题
2014三八妇女节活动总结范文四篇
2014/03/09 职场文书
结对共建协议书
2014/08/20 职场文书
西安导游词
2015/02/12 职场文书
教师评职称工作总结2015
2015/04/20 职场文书
学校计划生育责任书
2015/05/09 职场文书
2016教师六五普法学习心得体会
2016/01/21 职场文书
关于windows server 2012 DC 环境 重启后蓝屏代码:0xc00002e2的问题
2022/05/25 Servers