PHPStudy中INT常见配置

常见INI配置

PHP的配置 - 配置文件

php.ini

在 PHP 启动时被读取。对于服务器模块版本的 PHP,仅在 web 服务器启动时读取
一次。对于 CGI 和 CLI 版本,每次调用都会读取。
* Apache web 服务器在启动时会把目录转到根目录,这将导致 PHP 尝试在根目录
下读取 php.ini,如果存在的话。
* 在 php.ini 中可以使用环境变量。

PHP的配置 - 语法

该文件的语法非常简单。空白字符和以分号开始的行被简单地忽略。章节标题(例如: [php])也被简单地忽略,即使将来它们可能有某种意义。
设置指令的格式如下:
directive = value
指令名(directive)是大小写敏感的!
所以”foo=bar”不同于”FOO=bar”。
值(value)可以是:
用引号界定的字符串(如:”foo”)
一个数字(整数或浮点数,如:0, 1, 34, -1, 33.55)
一个PHP常量(如:E_ALL, M_PI)
一个INI常量(On, Off, none)
一个表达式(如:E_ALL & ~E_NOTICE)
INI文件中的表达式仅使用:
位运算符、逻辑非、圆括号,
| 位或 、& 位与 、~ 位非 、! 逻辑非 ,
布尔标志用 On 表示打开,用 Off 表示关闭
http://php.net/manual/zh/configuration.file.php

一个空字符串可以用在等号后不写任何东西表示,或者用 none 关键字:
foo = ; 将foo设为空字符串
foo = none ; 将foo设为空字符串
foo = “none” ; 将foo设为字符串”none”
如果你在指令值中使用动态扩展(PHP扩展或
Zend扩展)中的常量,那么你只能在加载这些动态扩展的指令行之后使用这些常量。

常见重要配置 - 变量相关

启用全局变量
register_globals = on
有些程序例如OSC需要启用全局变量.这个设置的作用是关闭自动注册的全局变量,
在设置为On的时候,php会将 POST _GET, COOKIE _ENV, SESSION key=> value _POST[‘username’]就会被注册为 username便 _POST来的还是$_SESSION来的呢?非常不方便别人阅读代码。
• 变量之间互相覆盖,引起不必要的麻烦。
• 安全问题。所以要设置为Off。
register_globals 为 on 的情况,PHP4 之前默认开启,PHP5 以后默认关闭。
短标签
short_open_tag = On 可以使用短标签变形一句话绕过检测

常见重要配置 - 安全模式

安全模式
safe_mode = off
php的安全模式是个非常重要的内嵌的安全机制,能够控制一些php中的函数,比如system(),同时把很多文件操作函数进行了权限控制,也不允许对某些关键文件的文件,比如/etc/passwd,但是默认的php.ini是没有打开安全模式的。
禁用类/函数
disable_classes=,disable_functions=,disable_functions=opendir,readdir,scandir,fopen,unlink禁用某些类,禁止某些函数。接受逗号分隔的函数名列表作为参数。只能设置在 php.ini 中。

常见重要配置 - 上传文件及目录权限

设置上传文件大小
file_uploads = on
upload_max_filesize = 8M

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

用户访问目录限制
open_basedir = .:/tmp/
使用open_basedir选项能够控制PHP脚本只能访问指定的目录,这样能够避免PHP脚本访问不应该访问的文件,一定程度上限制了phpshell的危害.我们一般可以设置为只能访问网站目录,表示允许访问当前目录(即PHP脚本文件所在之目录)和/tmp/目录,有效防止php木马跨站运行。linux用冒号分隔,windows下用分号分隔

常见重要配置 - 错误信息

错误信息控制
display_error = On
是否将错误信息作为输出的一部分,站点发布后应该关闭这项功能,以免暴露信息。调试的时候当然是要On的,不然就什么错误信息也看不到了。
设置错误报告级别
error_reporting = E_ALL
这个设置的作用是将错误级别设置为最高,可以显示所有的问题,方便查错,也有利于写出高质量的代码。日志级别是一些常量,在php.ini中有写,推荐使用 E_ALL | E_STRICT,即所有级别。
错误日志
error_log =
错误日志的位置,必须对web用户可写入,如果不定义则默认写入到web服务器的错误日志中去 。
log_errors = on
如上所说,建议将错误日志输出到文件,而不是直接输出到前端。
log_errors_max_length = 1024
错误日志关联信息的最大长度,设为0表示无限长度

常见重要配置 - 魔术引号及远程文件

魔术引号 【Warning:本特性已自 PHP 5.3.0 起废弃并将自 PHP 5.4.0 起移除。】
magic_quotes_gpc = On
为 GPC (Get/Post/Cookie) 操作设置 magic_quotes 状态。 当 magic_quotes 为 on,所有的 ’ (单引号)、” (双引号)、\(反斜杠)和 NULL 被一个反斜杠自动转义。转义耗时,浪费资源
是否允许打开远程文件
allow_url_fopen = on
本选项激活了 URL 形式的fopen封装协议使得可以访问URL对象例如文件。默认的封装协议提供用 ftp 和http协议来访问远程文件,一些扩展库例如zlib可能会注册更多的封装协议。
是否允许包含远程文件
allow_url_include = off
本选项激活允许 include, include_once, require, require_once等函数使用 URL 形式的 fopen 封装协议。简单来说就是可以包含远程文件。

扫描二维码关注公众号,回复: 1031011 查看本文章

猜你喜欢

转载自blog.csdn.net/u011215939/article/details/79010147
今日推荐