PHP 危险函数解释

所属分类: 软件教程 / 编程开发 阅读数: 686
收藏 0 赞 0 分享
  在编译 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 命令。
  危险等级:高
更多精彩内容其他人还在看

Unity3D摄像机跟随小球移动而不旋转的设置方法

Unity3D中怎样让摄像机跟随小球移动而不旋转?Unity3D中使用摄像机拍小球,它在移动的过程中,自身是不断旋转的,所以,摄像机也会跟着一起旋转,怎么让摄像机不转呢?请看下文详细介绍
收藏 0 赞 0 分享

Myeclipse断点不起作用出现斜线该怎么办呢?

Myeclipse断点不起作用出现斜线该怎么办呢?Myeclipse断点处如果出现斜线,那就说明断点不起作用了,该怎么处理这种情况呢?下面我们一起来看看详细的解决办法,需要的朋友可以参考下
收藏 0 赞 0 分享

Visual Studio中无法查找或打开PDB文件怎么办?

Visual Studio中无法查找或打开PDB文件怎么办?在VS底部的“输出”框中提示“无法查找或打开 PDB 文件”,出现这个问题该怎么解决呢?下面我们来看看详细的解决办法,需要的朋友可以参考下
收藏 0 赞 0 分享

VS2013调试代码时怎么避免加载符号?

VS2013调试代码时怎么避免加载符号?VS2013调试代码时候,当电脑接入网络后系统会自动从Microsoft 符号服务器加载PDB符号文件,一旦加载符号就会变得很慢,下面我们来看看详细的解决办法
收藏 0 赞 0 分享

eclipse怎么更换工作空间?eclipse更换工作区的方法

eclipse怎么更换工作空间?eclipse经常编辑代码,eclipse默认的的工作区在C盘,经常使用eclipse写代码会导致C盘空间缩小,该怎么更换工作区呢?下面我们来看看eclipse更换工作区的方法
收藏 0 赞 0 分享

vs2010怎么更换默认的起始页?vs2010起始页添加命令按钮的方法

vs2010怎么更换默认的起始页?vs2010起始页就是vs启动的时候默认打开的页面,当然我们可以根据自己的需要来设置起始页,下面我们来看看vs2010起始页添加命令按钮的方法
收藏 0 赞 0 分享

eclipse中sdk与adt版本不兼容该怎么解决? 三种方法帮你搞定

eclipse中sdk与adt版本不兼容该怎么解决?出现这种问题基本上是因为sdk版本过高,今天我们来看看三种比较简单的解决办法,图文教程很简单,需要的朋友可以参考下
收藏 0 赞 0 分享

vb怎么输出菱形图案?vb绘制菱形的教程

vb怎么输出菱形图案?vb编辑的代码可以实现很多功能,今天我们就来看看怎么使用vb绘制菱形图案,这篇教程很简单,适合新手学习,需要的朋友可以参考下
收藏 0 赞 0 分享

Android Studio怎么导出设置?

Android Studio怎么导出设置?Android Studio中设置了很多符合自己习惯的东西,但是如果重新安装软件,之前设置的东西都会消失,该怎么将这些设置导出来呢?下面我们一起来看看详细教程
收藏 0 赞 0 分享

怎么使用arcgis对进行地图投影?

怎么使用arcgis对进行地图投影?没有投影过的地图该怎么投影?我们想将是西安80的shp数据,但是一般的搜不带号,想转换成带号的,就需要使用arcgis对进行地图投影,详细教程请看下文
收藏 0 赞 0 分享
查看更多