PHP代码审计-常见ini配置

配置文件

php.ini

在 PHP 启动时被读取。对于服务器模块版本的 PHP,仅在 web 服务器启动时读取一次。对于 CGI 和 CLI 版本,每次调用都会读取。

  • Apache web 服务器在启动时会把目录转到根目录,这将导致 PHP 尝试在根目录下读取 php.ini,如果存在的话。
  • 在 php.ini 中可以使用环境变量。

由扩展库处理的php.ini指令,其文档分别在各扩展库的页面。内核配置选项见附录。不过也许不是所有的 PHP 指令都在手册中有文档说明。要得到自己的 PHP 版本中的配置指令完整列表,请阅读php.ini文件,其中都有注释。此外,也许从 Git 得到的» 最新版php.ini 也有帮助。

注:php.ini的详细配置,可参见PHP官方手册:http://php.net/manual/zh/ini.php
PHP的配置文件信息,参见PHP官方手册:http://php.net/manual/zh/configuration.file.php

.user.ini 文件

自 PHP 5.3.0 起,PHP 支持基于每个目录的 .htaccess 风格的 INI 文件。此类文件仅被 CGI/FastCGI SAPI 处理。此功能使得 PECL 的 htscanner 扩展作废。如果使用 Apache,则用 .htaccess 文件有同样效果。

语法

语法非常简单。
空白字符和以分号开始的行被简单地忽略。
章节标题(例如: [php])也被简单地忽略,即使将来它们可能有某种意义。
设置指令的格式如下:directive = value
注意:指令名 directive 是大小写敏感的。要区分大小写。
值(value)可以是:

  • 用引号界定的字符串(如:"foo")
  • 一个数字(整数或浮点数,如:0, 1, 34, -1, 33.55)
  • 一个PHP常量(如:E_ALL, M_PI)
  • 一个INI常量(On, Off, none)
  • 一个表达式(如:E_ALL & ~E_NOTICE)
    一个空字符串可以用在等号后不写任何东西表示,或者用 none 关键字:
foo = ; 将foo设为空字符串
foo = none ; 将foo设为空字符串
foo = "none" ; 将foo设为字符串''none''  

INI文件中的表达式仅使用:
位运算符、逻辑非、圆括号,| 位或 、& 位与 、~ 位非 、! 逻辑非 ,布尔标志用 On 表示打开,用 Off 表示关闭。
如果你在指令值中使用动态扩展(PHP扩展或Zend扩展)中的常量,那么你只能在加载这些动态扩展的指令行之后使用这些常量。

重要配置 - 变量相关

启用全局变量

名字 默认 可修改范围 更新日志
register_globals=off "0" PHP_INI_PERDIR 在 PHP <= 4.2.3 时是 PHP_INI_ALL。 从 PHP 5.3.0 起不推荐使用。 在 PHP 5.4.0 中移除该选项。

有些程序(如OSC)需要启用全局变量。
这个设置的作用是:关闭自动注册的全局变量,
在设置为On的时候,php会将 $_POST,$_GET,$_COOKIE,$_ENV,$_SESSION数组中的$key=>$value 直接注册为变量,比如$_POST['username']就会被注册为$username。
虽然方便了调用,但是会有三个问题:

  • 不知道变量是哪里来的,$_POST来的还是$_SESSION来的呢?非常不方便别人阅读代码。
  • 变量之间互相覆盖,引起不必要的麻烦。
  • 安全问题。
    所以要设置为Off。

短标签

名字 默认 可修改范围 更新日志
short_open_tag = on “1” PHP_INI_ALL 在 PHP 4.0.0 时是 PHP_INI_ALL。 在 PHP < 5.3.0 时是 PHP_INI_PERDIR。

注:关于可修改范围,参见:http://blog.csdn.net/XavierDarkness/article/details/78031266
这个设置决定是否允许使用 PHP 代码开始标志的缩写形式(<? ?>)。如果禁用了,必须使用 PHP 代码开始
标志的完整形式(<?php ?>)。

本指令也会影响到缩写形式 <?=,它和 <? echo 等价。使用此缩写需要 short_open_tag 的值为 On。 从
PHP 5.4.0 起, <?= 总是可用的。

短标签在安全上的作用:当程序过滤<?php ?>形式的PHP代码时,可以用@int_set('short_open_tag',0) 开启短标签,用短标签形式<? ?>绕过过滤。

安全模式

安全模式

名字 默认 可修改范围 更新日志
safe_mode=off "0" PHP_INI_SYSTEM 在 PHP 5.4.0 中移除该选项。

php的安全模式是个非常重要的内嵌的安全机制,能够控制一些php中的函数,比如system(),同时把很多文件操作函数进行了权限控制,也不允许对某些关键文件的文件,比如/etc/passwd,但是默认的php.ini是没有打开安全模式的。
safe_mode 设置为 on,PHP 将通过文件函数或其目录检查当前脚本的拥有者是否和将被操作的文件的拥有者相匹配。
在 PHP 5.4.0 中移除该选项。

安全模式下执行程序主目录

名字 默认 可修改范围 更新日志
safe_mode_exec_dir=/var/www/html NULL PHP_INI_SYSTEM 自 PHP 4.1.0 起可用

如果 PHP 使用了安全模式,system() 和其它程序执行函数将拒绝启动不在此目录中的程序。必须使用 / 作为目录分隔符,包括 Windows 中。
简单来说,就是这个目录下可以执行。

禁用类/函数

名字 默认 可修改范围 更新日志
disable_class= "" php.ini only 从 PHP 4.3.2 起可用。
disable_functions= "" php.ini only 从 PHP 4.0.1 起可用。
disable_functions=opendir,readdir,scandir,fopen,unlink

禁用某些类,禁止某些函数。接受逗号分隔的函数名列表作为参数。只能设置在 php.ini 中。

  • disable_classes string
    本指令可以使你出于安全的理由禁用某些类。用逗号分隔类名。disable_classes 不受安全模式的影响。 本指令只能设置在 php.ini 中。例如不能将其设置在 httpd.conf。
  • disable_functions string
    本指令允许你基于安全原因禁止某些函数。接受逗号分隔的函数名列表作为参数。 disable_functions 不受安全模式的影响。 本指令只能设置在 php.ini 中。例如不能将其设置在 httpd.conf。

上传文件及目录权限

设置上传文件大小

名字 默认 可修改范围 更新日志
file_uploads = on "1" PHP_INI_SYSTEM 在 PHP <= 4.2.3 时是 PHP_INI_ALL。 从 PHP 4.0.3 起可用。
upload_max_filesize = 8M "2M" PHP_INI_PERDIR 在 PHP <= 4.2.3 时是 PHP_INI_ALL。
post_max_size = 8M "8M" PHP_INI_PERDIR 在 PHP <= 4.2.3 时是 PHP_INI_SYSTEM。 从 PHP 4.0.3 起可用。

POST的数值要大于等于upload,否则upload不起作用。
详见:http://php.net/manual/zh/ini.core.php#ini.file-uploads

文件上传临时目录

名字 默认 可修改范围 更新日志
upload_tmp_dir = NULL PHP_INI_SYSTEM

上传临时文件保存的目录,需要可写,如果不设置,则采用系统临时目录。(/tmp)

用户访问目录限制

名字 默认 可修改范围 更新日志
open_basedir = .:/tmp/ NULL PHP_INI_ALL 在 PHP < 5.2.3 时是 PHP_INI_SYSTEM。

使用open_basedir选项能够控制PHP脚本只能访问指定的目录,这样能避免PHP脚本访问不应该访问的文件,一定程度上限制了phpshell的危害。我们一般可以设置为只能访问网站目录,表示允许访问当前目录(即PHP脚本文件所在之目录)和/tmp/目录,有效防止php木马跨站运行。
将 PHP 所能打开的文件限制在指定的目录树,包括文件本身。本指令不受安全模式打开或者关闭的影响。
特殊值 . 指明脚本的工作目录将被作为基准目录。但这有些危险,因为脚本的工作目录可以轻易被 chdir() 而改变。
在 httpd.conf 文件中中,open_basedir 可以像其它任何配置选项一样用“php_admin_value open_basedir none”[方法关闭(例如某些虚拟主机中)。
在 Windows 中,用分号(;)分隔目录。在任何其它系统中用冒号(:)分隔目录。作为 Apache 模块时,父目录中的 open_basedir 路径自动被继承。

注意:用 open_basedir 指定的限制实际上是前缀,不是目录名。也就是说“open_basedir = /dir/incl”也会允许访问“/dir/include”和“/dir/incls”,如果它们存在的话。如果要将访问限制在仅为指定的目录,用斜线结束路径名。例如:“open_basedir = /dir/incl/”。
默认是允许打开所有文件。

错误信息

错误信息控制

名字 默认 可修改范围 更新日志
display_error = On "1" PHP_INI_ALL

该选项设置是否将错误信息作为输出的一部分显示到屏幕,或者对用户隐藏而不显示。
站点发布后应该关闭这项功能,以免暴露信息。调试的时候当然是要On的,不然就什么错误信息也看不到了。
设置 "stderr" 表示发送到 stderr 而不是 stdout"stderr"从 PHP 5.2.4 开始可用。在以前的版本中,该配置值的类型为 boolean。
Note:
尽管 display_errors 也可以在运行时设置 (使用 ini_set()), 但是脚本出现致命错误时任何运行时的设置都是无效的。 因为在这种情况下预期运行的操作不会被执行。

设置错误报告级别

名字 默认 可修改范围 更新日志
error_reporting = E_ALL NULL PHP_INI_ALL

这个设置的作用是将错误级别设置为最高,可以显示所有的问题,方便查错,也有利于写出高质量的代码。
日志级别是一些常量,在php.ini中有写,推荐使用 E_ALL | E_STRICT,即所有级别。

设置错误报告的级别。该参数可以是一个任意的表示二进制位字段的整数,或者常数名称。错误级别和常数是在 预定义常量定义的,在php.ini 之中也有专门的说明。在程序运行时,还可以通过 error_reporting() 函数进行设置。
在PHP 4和PHP 5之中,其默认值为 E_ALL & ~E_NOTICE。 该设置表示除了 E_NOTICE 其他都显示的错误级别。在开发过程中很有必要显示它们。
详见:http://php.net/manual/zh/errorfunc.configuration.php#ini.error-reporting

错误日志

名字 默认 可修改范围 更新日志
error_log = NULL PHP_INI_ALL

错误日志的位置,必须对web用户可写入,如果不定义则默认写入到web服务器的错误日志中去 。

设置脚本错误将被记录到的文件。该文件必须是web服务器用户可写的。如果特殊值 syslog 被设置,则将错误信息发送到系统日志记录器。在Unix以及类似系统上,使用的是 syslog(3) ,而在 Windows NT 类系统上则为事件日志。Windows 95上不支持系统日志记录。参见:syslog(). 如果该配置没有设置,则错误信息会被发送到 SAPI 错误记录器。例如,出现在Apache的错误日志中,或者在CLI中发送到 stderr

名字 默认 可修改范围 更新日志
log_errors = on NULL PHP_INI_ALL

设置是否将脚本运行的错误信息记录到服务器错误日志或者error_log之中。注意,这是与服务器相关的特定配置项。

魔术引号及远程文件

魔术引号 【Warning:本特性已自 PHP 5.3.0 起废弃并将自 PHP 5.4.0 起移除。】

名字 默认 可修改范围 更新日志
magic_quotes_gpc = On “1” PHP_INI_PERDIR 在 PHP <= 4.2.3 时是 PHP_INI_ALL。 从 PHP 5.3.0 起不推荐使用。 在 PHP 5.4.0 中移除该选项
magic_quotes_runtime = Off “0” PHP_INI_ALL 在 PHP 5.4.0 中移除该选项

为 GPC (Get/Post/Cookie) 操作设置 magic_quotes 状态。 当 magic_quotes 为 on,所有的 ' (单引号)、"
(双引号)、\(反斜杠)和 NULL 被一个反斜杠自动转义。

Note:
在 PHP 4,$_ENV也会被转义。

Note:
如果 magic_quotes_sybase 也是 ON,它会完全覆盖 magic_quotes_gpc。 两个指令都启用意味着只有单引号被转义为 ''。 双引号、反斜杠和 NUL's 不会被转义。

如果启用了 magic_quotes_runtime,大多数返回任何形式外部数据的函数,包括数据库和文本段将会用反斜线转义引号。 如果启用了magic_quotes_sybase,单引号会被单引号转义而不是反斜线。

受 magic_quotes_runtime 影响的函数(不包括 PECL 里的函数):
参见:http://blog.csdn.net/XavierDarkness/article/details/78032716

是否允许打开远程文件

名字 默认 可修改范围 更新日志
allow_url_fopen = on "1" PHP_INI_SYSTEM 在 PHP <= 4.3.4 时是 PHP_INI_ALL。

本选项激活了 URL 形式的 fopen 封装协议使得可以访问 URL 对象例如文件。默认的封装协议提供用 ftp 和 http 协议来访问远程文件,一些扩展库例如 zlib可能会注册更多的封装协议。

Note:
出于安全性考虑,此选项只能在 php.ini 中设置。

Note:
此选项是紧接着版本 4.0.3 发布后引进的。版本 4.0.3 以及之前的版本只能在编译时通过配置项 --disable-url-fopen-wrapper
来取消此特性。

Warning:Windows 版在 PHP 4.3.0 之前,以下函数不支持远程文件访问:includeinclude_once, requirerequire_onceGD 和图像处理 函数中的 imagecreatefromXXX 函数。

是否允许包含远程文件

名字 默认 可修改范围 更新日志
allow_url_include = off “0” PHP_INI_ALL 在 PHP 5 时是 PHP_INI_SYSTEM。 从 PHP 5.2.0 起可用。

本选项激活允许 include, include_once, require, require_once等函数使用 URL 形式的 fopen 封装协议。简
单来说就是可以包含远程文件。

Note
此选项要求开启 allow_url_fopen 。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,117评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,963评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,897评论 0 240
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,805评论 0 203
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,208评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,535评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,797评论 2 311
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,493评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,215评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,477评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,988评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,325评论 2 252
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,971评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,055评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,807评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,544评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,455评论 2 266

推荐阅读更多精彩内容