一些需要禁用的PHP危险函数(disable_functions)


Posted in PHP onFebruary 23, 2012

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 命令。
危险等级:高

禁用方法如下:
打开/etc/php.ini文件,
查找到 disable_functions ,添加需禁用的函数名,如下:
phpinfo,eval,passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,pfsockopen,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket,fsockopen

PHP 相关文章推荐
手把手教你使用DedeCms V3的在线采集图文教程
Apr 03 PHP
php 对输入信息的进行安全过滤的函数代码
Jun 29 PHP
完美解决PHP中的Cannot modify header information 问题
Aug 12 PHP
兼容PHP和Java的des加密解密代码分享
Jun 26 PHP
Laravel框架学习笔记(一)环境搭建
Oct 15 PHP
php静态文件生成类实例分析
Jan 03 PHP
Zend Framework动作助手Json用法实例分析
Mar 05 PHP
php仿微信红包分配算法的实现方法
May 13 PHP
php实现评论回复删除功能
May 23 PHP
[原创]php正则删除img标签的方法示例
May 27 PHP
Thinkphp 框架扩展之Widget扩展实现方法分析
Apr 23 PHP
PHP xpath提取网页数据内容代码解析
Jul 16 PHP
PHP面向对象法则
Feb 23 #PHP
优化PHP程序的方法小结
Feb 23 #PHP
数据库中排序的对比及使用条件详解
Feb 23 #PHP
PHP中几个常用的魔术常量
Feb 23 #PHP
PHP教程之PHP中shell脚本的使用方法分享
Feb 23 #PHP
php tp验证表单与自动填充函数代码
Feb 22 #PHP
PHP 设计模式之观察者模式介绍
Feb 22 #PHP
You might like
3个PHP多维数组转为一维数组的方法实例
2014/03/13 PHP
php实现Mongodb自定义方式生成自增ID的方法
2015/03/23 PHP
详解no input file specified 三种解决方法
2019/11/29 PHP
javascript 获取select下拉列表值的代码
2009/09/07 Javascript
javascript onmouseout 解决办法
2010/07/17 Javascript
JavaScript中关于indexOf的使用方法与问题小结
2010/08/05 Javascript
通过jquery还原含有rowspan、colspan的table的实现方法
2012/02/10 Javascript
jquery 操作DOM的基本用法分享
2012/04/05 Javascript
JavaScript实现点击按钮后变灰避免多次重复提交
2013/07/15 Javascript
c#+jquery实现获取radio和checkbox的值
2020/09/12 Javascript
javascript常用正则表达式汇总
2015/07/31 Javascript
js跨浏览器的事件侦听器和事件对象的使用方法
2015/12/17 Javascript
php基于redis处理session的方法
2016/03/14 Javascript
JS中Json数据的处理和解析JSON数据的方法详解
2016/06/29 Javascript
微信小程序 删除项目工程实现步骤
2016/11/10 Javascript
微信小程序 省市区选择器实例详解(附源码下载)
2017/01/05 Javascript
jQuery.cookie.js实现记录最近浏览过的商品功能示例
2017/01/23 Javascript
利用JavaScript对中文(汉字)进行排序实例详解
2017/06/18 Javascript
bootstrap table实现双击可编辑、添加、删除行功能
2017/09/27 Javascript
Vue-cli项目获取本地json文件数据的实例
2018/03/07 Javascript
微信小程序实现带放大效果的轮播图
2020/05/26 Javascript
Vue 按照创建时间和当前时间显示操作(刚刚,几小时前,几天前)
2020/09/10 Javascript
JavaScript数组常用的增删改查与其他属性详解
2020/10/13 Javascript
实用的 vue tags 创建缓存导航的过程实现
2020/12/03 Vue.js
Python 探针的实现原理
2016/04/23 Python
python中找出numpy array数组的最值及其索引方法
2018/04/17 Python
Python中py文件转换成exe可执行文件的方法
2019/06/14 Python
Django 实现admin后台显示图片缩略图的例子
2019/07/28 Python
对Django url的几种使用方式详解
2019/08/06 Python
tensorflow指定CPU与GPU运算的方法实现
2020/04/21 Python
一篇文章搞懂python的转义字符及用法
2020/09/03 Python
CSS3利用text-shadow属性实现多种效果的文字样式展现方法
2016/08/25 HTML / CSS
Dockers美国官方网站:卡其裤、男士服装、鞋及配件
2016/11/22 全球购物
菜篮子工程实施方案
2014/03/08 职场文书
学生鉴定评语大全
2014/05/05 职场文书
借钱欠条怎么写
2015/07/03 职场文书