[php] 
; php还是一个不断发展的工具,其功能还在不断地删减 
; 而php.ini的设置更改可以反映出相当的变化, 
; 在使用新的php版本前,研究一下php.ini会有好处的

;;;;;;;;;;;;;;;;;;; 
; 关于这个文件 ; 
;;;;;;;;;;;;;;;;;;;

; 这个文件控制了php许多方面的观点。为了让php读取这个文件,它必须被命名为 
; ‘php.ini’。php 将在这些地方依次查找该文件:当前工作目录;环境变量phprc 
; 指明的路径;编译时指定的路径。 
; 在windows下,编译时的路径是windows安装目录。 
; 在命令行模式下,php.ini的查找路径可以用 -c 参数替代。

; 该文件的语法非常简单。空白字符和用分号’;’开始的行被简单地忽略(就象你可能 
; 猜到的一样)。 章节标题(例如 : [foo])也被简单地忽略,即使将来它们可能 
; 有某种的意义。 

; 指示被指定使用如下语法: 
; 指示标识符 = 值 
; directive = value 
; 指示标识符 是 *大小写敏感的* – foo=bar 不同于 foo = bar。 

; 值可以是一个字符串,一个数字,一个 php 常量 (如: e_all or m_pi), ini 常量中的 
; 一个 (on, off, true, false, yes, no and none) ,或是一个表达式 
; (如: e_all & ~e_notice), 或是用引号括起来的字符串(” foo” ). 

; ini 文件的表达式被限制于位运算符和括号。 
; | bitwise or 
; & bitwise and 
; ~ bitwise not 
; ! boolean not 

; 布尔标志可用 1, on, true or yes 这些值置于开的状态。 
; 它们可用 0, off, false or no 这些值置于关的状态。 

; 一个空字符串可以用在等号后不写任何东西表示,或者用 none 关键字: 

; foo = ; 将foo置为空字符串 
; foo = none ; 将foo置为空字符串 
; foo = ” none” ; 将foo置为字符串’none’ 

; 如果你值设置中使用常量,而这些常量属于动态调入的扩展库(不是 php 的扩展,就是 
; zend 的扩展),你仅可以调入这些扩展的行*之后*使用这些常量。 

; 所有在 php.ini-dist 文件里设定的值与内建的默认值相同(这是说,如果 php.ini 
; 没被使用或者你删掉了这些行,默认值与之相同)。

;;;;;;;;;;;;;;;;;;;; 
; 语言选项 ; 
;;;;;;;;;;;;;;;;;;;;

engine = on 
; 使 php scripting language engine(php 脚本语言引擎)在 apache下有效。 
short_open_tag = on 
; 允许 tags 将被识别。 
asp_tags = off 
; 允许asp-style tags 
precision = 14 
; 浮点类型数显示时的有效位数

y2k_compliance = off 
; 是否打开 2000年适应 (可能在非y2k适应的浏览器中导致问题)

output_buffering = off 
; 输出缓存允许你甚至在输出正文内容之后发送 header(标头,包括cookies)行 
; 其代价是输出层减慢一点点速度。你可以使用输出缓存在运行时打开输出缓存, 
; 或者在这里将指示设为 on 而使得所有文件的输出缓存打开。 
output_handler = ; 你可以重定向你的脚本的所有输出到一个函数, 
; 那样做可能对处理或以日志记录它有用。 
; 例如若你将这个output_handler 设为” ob_gzhandler” , 
; 则输出会被透明地为支持gzip或deflate编码的浏览器压缩。 
; 设一个输出处理器自动地打开输出缓冲。

implicit_flush = off 
; 强制flush(刷新)让php 告诉输出层在每个输出块之后自动刷新自身数据。 
; 这等效于在每个 print() 或 echo() 调用和每个 html 块后调用flush()函数。 
; 打开这项设置会导致严重的运行时冲突,建议仅在debug过程中打开。

allow_call_time_pass_reference = on 
; 是否让强迫函数调用时按引用传递参数。这一方法遭到抗议, 
; 并可能在将来版本的php/zend里不再支持。 
; 受到鼓励的指定哪些参数按引用传递的方法是在函数声明里。 
; 你被鼓励尝试关闭这一选项并确认你的脚本仍能正常工作,以保证在将来版本的语言里 
; 它们仍能工作。(你将在每次使用该特点时得到一个警告,而参数将按值而不是按引用 
; 传递)。

; safe mode 安全模式 
safe_mode = off 
safe_mode_exec_dir = 
safe_mode_allowed_env_vars = php_ 
; ?setting certain environment variables 
; ?may be a potential security breach. 
; 该指示包含用逗号分隔的前缀列表。安全模式中,用户仅可以替换 
; 以在此列出的前缀开头的环境变量的值。 
; 默认地,用户将仅能 设定以php_开头的环境变量,(如: php_foo=bar)。 
; 注意: 如果这一指示为空,php 将让用户更改任意环境变量!

safe_mode_protected_env_vars = ld_library_path 
; 这条指示包含一个用逗号分隔的环境变量列表,那是最终用户将不能用putenv () 更改的。 
; 这些变量甚至在safe_mode_allowed_env_vars 设置为允许的情况下得到保护。

disable_functions = 
; 这条指示让你可以为了安全的原因让特定函数失效。 
; 它接受一个用逗号分隔的函数名列表。 
; 这条指示 *不受* 安全模式是否打开的影响。

; 语法高亮模式的色彩。 
; 只要能被接受的东西就能工作。

highlight.string = #dd0000 
highlight.comment = #ff8000 
highlight.keyword = #007700 
highlight.bg = #ffffff 
highlight.default = #0000bb 
highlight.html = #000000

; misc 杂项 
expose_php = off 
; 决定 php 是否标示它装在服务器上的事实(例如:加在它 — php— 给web服务 
; 发送的信号上)。 
; (我个人的意见,在出现什么power-by的header的时候,把这关掉。) 
; 它不会有安全上的威胁, 但它使检查你的服务器上是否安装了php成为了可能。

;;;;;;;;;;;;;;;;;;; 
; resource limits ; 
;;;;;;;;;;;;;;;;;;;

max_execution_time = 30 ; 每个脚本的最大执行时间, 按秒计 
memory_limit = 8388608 ; 一个脚本最大可使用的内存总量 (这里是8mb)

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 
; error handling and logging ; 
; 出错控制和登记 ; 
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 
; 错误报告是按位的。或者将数字加起来得到想要的错误报告等级。 
; e_all – 所有的错误和警告 
; e_error – 致命性运行时错 
; e_warning – 运行时警告(非致命性错) 
; e_parse – 编译时解析错误 
; e_notice – 运行时提醒(这些经常是是你的代码的bug引起的, 
;也可能是有意的行为造成的。(如:基于未初始化的变量自动初始化为一个 
;空字符串的事实而使用一个未初始化的变量)

; e_core_error – 发生于php启动时初始化过程中的致命错误 
; e_core_warning – 发生于php启动时初始化过程中的警告(非致命性错) 
; e_compile_error – 编译时致命性错 
; e_compile_warning – 编译时警告(非致命性错) 
; e_user_error – 用户产生的出错消息 
; e_user_warning – 用户产生的警告消息 
; e_user_notice – 用户产生的提醒消息 
; 例子: 
; error_reporting = e_all & ~e_notice ; 显示所有的错误,除了提醒 
; error_reporting = e_compile_error|e_error|e_core_error ; 仅显示错误 
error_reporting = e_all & ~e_notice ; 显示所有的错误,除了提醒 
display_errors = on ; 显示出错误信息(作为输出的一部分) 
; 在最终发布的web站点上,强烈建议你关掉这个特性,并使用 
; 错误日志代替(参看下面)。 
; 在最终发布的web站点继续让 display_errors 有效可能 
; 暴露一些有关安全的信息,例如你的web服务上的文件路径、 
; 你的数据库规划或别的信息。 
display_startup_errors = off ; 甚至当display_erroes打开了,发生于php的启动的步骤中 
; 的错误也不会被显示。 
; 强烈建议保持使 display_startup_errors 关闭, 
; 除了在改错过程中。 
log_errors = off ; 在日志文件里记录错误(服务器指定的日志,stderr标准错误输出,或error_log(下面的)) 
; 正如上面说明的那样,强烈建议你在最终发布的web站点以日志记录错误 
; 取代直接错误输出。

track_errors = off ; 保存最近一个 错误/警告 消息于变量 $php_errormsg (boolean) 
;error_prepend_string = ” ” ; 于错误信息前输出的字符串 
;error_append_string = ” ” ; 于错误信息后输出的字符串 
;error_log = filename ; 记录错误日志于指定文件 
;error_log = syslog ; 记录错误日志于系统日志 syslog (nt 下的事件日志, windows 95下无效) 
warn_plus_overloading = off ; 当将‘ +’ 用于字符串时警告

;;;;;;;;;;;;;;;;; 
; data handling ; 
;;;;;;;;;;;;;;;;; 
variables_order = ” egpcs” ; 这条指示描述了php 记录 
; get, post, cookie, environment and built-in 这些变量的顺序。 
; (以 g, p, c, e & s 代表,通常以 egpcs 或 gpc 的方式引用)。 
; 按从左到右记录,新值取代旧值。

register_globals = on ; 是否将这些 egpcs 变量注册为全局变量。 
; 若你不想让用户数据不在全局范围内混乱的话,你可能想关闭它。 
; 这和 track_vars 连起来用更有意义 — 这样你可以通过 
; $http_*_vars[] 数组访问所有的gpc变量。

register_argc_argv = on ; 这条指示告诉 php 是否声明 argv和argc 变量 
; (注:这里argv为数组,argc为变量数) 
; (其中包含用get方法传来的数据)。 
; 若你不想用这些变量,你应当关掉它以提高性能。

track_vars = on ; 使$http_*_vars[]数组有效,这里*在使用时用 
; env, post, get, cookie or server替换 
post_max_size = 8m ; php将接受的post数据最大大小。

gpc_order = ” gpc” ; 这条指示被人反对。用 variables_order 代替。

; magic quotes 
magic_quotes_gpc = on ; 在输入的get/post/cookie数据里使用魔术引用 
; (原文就这样,呵呵,所谓magic quotes 应该是指用转义符加在引用性的控制字符上,如 ‘….) 
magic_quotes_runtime= off ; 对运行时产生的数据使用魔术引用, 
; 例如:用sql查询得到的数据,用exec()函数得到的数据,等等 
magic_quotes_sybase = off ; 采用 sybase形式的魔术引用(用 ” 脱出 ‘ 而不用 ‘)

; 自动在 php 文档之前和之后添加文件 
auto_prepend_file = 
auto_append_file =

; 象4.04b4一样,php 默认地总是在 “ content-type:” 头标输出一个字符的编码方式。 
; 让输出字符集失效,只要设置为空。 
; php 的内建默认值是 text/html 
default_mimetype = ” text/html” 
;default_charset = ” iso-8859-1″

;;;;;;;;;;;;;;;;;;;;;;;;; 
; paths and directories ; 
;;;;;;;;;;;;;;;;;;;;;;;;; 
include_path = ; include 路径设置,unix: ” /path1:/path2″ windows: ” \path1;\path2″ 
doc_root = ; php 页面的根路径,仅在非空时有效 
user_dir = ; 告知 php 在使用 /~username 打开脚本时到哪个目录下去找,仅在非空时有效 
;upload_tmp_dir = ; 存放用http协议上载的文件的临时目录(在没指定时使用系统默认的) 
upload_max_filesize = 2097152 ; 文件上载默认地限制为2 meg 
extension_dir = c:\php\ ; 存放可加载的扩充库(模块)的目录 
enable_dl = on ; 是否使dl()有效。 
; 在多线程的服务器上 dl()函数*不能*很好地工作, 
; 例如iis or zeus,并在其上默认为禁止

;;;;;;;;;;;;;;;; 
; file uploads ; 
;;;;;;;;;;;;;;;; 
file_uploads = on ; 是否允许http方式文件上载 
;upload_tmp_dir = ; 用于http上载的文件的临时目录(未指定则使用系统默认) 
upload_max_filesize = 2m ; 上载文件的最大许可大小

; fopen wrappers ; 
;;;;;;;;;;;;;;;;;; 
allow_url_fopen = on ; 是否允许把urls当作http:.. 或把文件当作ftp:…

;;;;;;;;;;;;;;;;;;;;;; 
; 动态扩展 ; 
; dynamic extensions ; 
;;;;;;;;;;;;;;;;;;;;;; 
; 若你希望一个扩展库自动加载,用下面的语法: 
; extension=modulename.extension 
; 例如,在windows上, 
; extension=msql.dll 
; or 在unix下, 
; extension=msql.so 
; 注意,这只应当是模块的名字,不需要目录信息放在里面。 
; 用上面的 extension_dir 指示指定扩展库的位置。

;windows 扩展 
;extension=php_nsmail.dll 
extension=php_calendar.dll 
;extension=php_dbase.dll 
;extension=php_filepro.dll 
extension=php_gd.dll 
;extension=php_dbm.dll 
;extension=php_mssql.dll 
;extension=php_zlib.dll 
;extension=php_filepro.dll 
;extension=php_imap4r2.dll 
;extension=php_ldap.dll 
;extension=php_crypt.dll 
;extension=php_msql2.dll 
;extension=php_odbc.dll 
; 注意, mysql的支持现在是内建的,因此,不需要用它的dll

;;;;;;;;;;;;;;;;;;; 
; 模块设定 ; 
; module settings ; 
;;;;;;;;;;;;;;;;;;;

[syslog] 
define_syslog_variables = off ; 是否定义各种的系统日志变量 
; 如:$log_pid, $log_cron, 等等。 
; 关掉它是个提高效率的好主意。 
; 运行时,你可以调用函数define_syslog_variables(),来定义这些变量

[mail function] 
smtp = localhost ;仅用于win32系统 
sendmail_from = me@localhost.com ;仅用于win32系统 
;sendmail_path = ;仅用于unix, 也可支持参数(默认的是’sendmail -t -i’)

[debugger] 
debugger.host = localhost 
debugger.port = 7869 
debugger.enabled = false

[logging] 
; 这些配置指示用于示例的日志记录机制。 
; 看 examples/readme.logging 以得到更多的解释 
;logging.method = db 
;logging.directory = /path/to/log/directory

[java] 
;java.class.path = .\php_java.jar 
;java.home = c:\jdk 
;java.library = c:\jdk\jre\bin\hotspot\jvm.dll 
;java.library.path = .\

[sql] 
sql.safe_mode = off

[odbc] 
;uodbc.default_db = not yet implemented 
;uodbc.default_user = not yet implemented 
;uodbc.default_pw = not yet implemented 
uodbc.allow_persistent = on ; 允许或禁止 持久连接 
uodbc.check_persistent = on ; 在重用前检查连接是否还可用 
uodbc.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
uodbc.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制 
uodbc.defaultlrl = 4096 ; 控制 long 类型的字段。返回变量的字节数,0 代表通过(?)0 means passthru 
uodbc.defaultbinmode = 1 ; 控制 二进制数据。0 代表?????handling of binary data. 0 means passthru, 1 return as is, 2 convert to char 
; 见有关 odbc_binmode 和 odbc_longreadlen 的文档以得到 uodbc.defaultlrl 和 uodbc.defaultbinmode 的解释。

[mysql] 
mysql.allow_persistent = on ; 允许或禁止 持久连接 
mysql.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
mysql.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制 
mysql.default_port = ; mysql_connect() 使用的默认端口,如不设置,mysql_connect() 
; 将使用变量 $mysql_tcp_port,或在/etc/services 下的mysql-tcp 条目(unix), 
; 或在编译是定义的 mysql_port(按这样的顺序) 
; win32环境,将仅检查mysql_port。 
mysql.default_socket = ; 用于本地 mysql 连接的默认的套接字名。为空,使用 mysql 内建值

mysql.default_host = ; mysql_connect() 默认使用的主机(安全模式下无效) 
mysql.default_user = ; mysql_connect() 默认使用的用户名(安全模式下无效) 
mysql.default_password = ; mysql_connect() 默认使用的密码(安全模式下无效) 
; 注意,在这个文件下保存密码通常是一个*坏*主意 
; *任何*可以使用php访问的用户可以运行 
; ‘echo cfg_get_var(” mysql.default_password” )’来显示那个密码! 
; 而且当然地,任何有读该文件权力的用户也能看到那个密码。

[msql] 
msql.allow_persistent = on ; 允许或禁止 持久连接 
msql.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
msql.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制

[postgressql] 
pgsql.allow_persistent = on ; 允许或禁止 持久连接 
pgsql.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
pgsql.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制

[sybase] 
sybase.allow_persistent = on ; 允许或禁止 持久连接 
sybase.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
sybase.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制 
;sybase.interface_file = ” /usr/sybase/interfaces” 
sybase.min_error_severity = 10 ; 显示的错误的最低严重性 
sybase.min_message_severity = 10 ; 显示的消息的最低重要性 
sybase.compatability_mode = off ; 与旧版的php 3.0 兼容的模式。若打开,这将导致 php 自动地 
; 把根据结果的 sybase 类型赋予它们, 
; 而不是把它们全当成字符串。 
; 这个兼容模式不会永远留着, 
; 因此,将你的代码进行需要的修改, 
; 并将该项关闭。

[sybase-ct] 
sybct.allow_persistent = on ; 允许或禁止 持久连接 
sybct.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
sybct.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制 
sybct.min_server_severity = 10 ; 显示的错误的最低严重性 
sybct.min_client_severity = 10 ; 显示的消息的最低重要性

[bcmath] 
bcmath.scale = 0 ; 用于所有bcmath函数的10十进制数数字的个数number of decimal digits for all bcmath functions

[browscap] 
;browscap = extra/browscap.ini 
browscap = c:\win\system\inetsrv\browscap.ini 
[informix] 
ifx.default_host = ; ifx_connect() 默认使用的主机(安全模式下无效) 
ifx.default_user = ; ifx_connect() 默认使用的用户名(安全模式下无效) 
ifx.default_password = ; ifx_connect() 默认使用的密码(安全模式下无效) 
ifx.allow_persistent = on ; 允许或禁止 持久连接 
ifx.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
ifx.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制 
ifx.textasvarchar = 0 ; 若打开,select 状态符返回一个 ‘ text blob’ 字段的内容,而不是它的id 
ifx.byteasvarchar = 0 ; 若打开,select 状态符返回一个 ‘ byte blob’ 字段的内容,而不是它的id 
ifx.charasvarchar = 0 ; 追踪从固定长度的字符列里剥离的空格。 
; 可能对 informix se 用户有效。 
ifx.blobinfile = 0 ; 若打开,text和byte blobs 的内容被导出到一个文件 
; 而不是保存到内存。 
ifx.nullformat = 0 ; null(空)被作为空字段返回,除非,这里被设为1。 
; 这种情况下(为1),null作为字串null返回。

[session] 
session.save_handler = files ; 用于保存/取回数据的控制方式 
session.save_path = c:\win\temp ; 在 save_handler 设为文件时传给控制器的参数, 
; 这是数据文件将保存的路径。 
session.use_cookies = 1 ; 是否使用cookies 
session.name = phpsessid 
; 用在cookie里的session的名字 
session.auto_start = 0 ; 在请求启动时初始化session 
session.cookie_lifetime = 0 ; 为按秒记的cookie的保存时间, 
; 或为0时,直到浏览器被重启 
session.cookie_path = / ; cookie的有效路径 
session.cookie_domain = ; cookie的有效域 
session.serialize_handler = php ; 用于连接数据的控制器 
; php是 php 的标准控制器。 
session.gc_probability = 1 ; 按百分比的’garbage collection(碎片整理)’进程 
; 在每次 session 初始化的时候开始的可能性。 
session.gc_maxlifetime = 1440 ; 在这里数字所指的秒数后,保存的数据将被视为 
; ‘碎片(garbage)’并由gc 进程清理掉。 
session.referer_check = ; 检查 http引用以使额外包含于urls中的ids无效 
session.entropy_length = 0 ; 从文件中读取多少字节 
session.entropy_file = ; 指定这里建立 session id 
; session.entropy_length = 16 
; session.entropy_file = /dev/urandom 
session.cache_limiter = nocache ; 设为{nocache,private,public},以决定 http 的 
; 缓存问题 
session.cache_expire = 180 ; 文档在 n 分钟后过时 
session.use_trans_sid = 1 ; 使用过渡性的 sid 支持,若编译时许可了 
; –enable-trans-sid 
url_rewriter.tags = ” a=href,area=href,frame=src,input=src,form=fakeentry”

[mssql] 
;extension=php_mssql.dll 
mssql.allow_persistent = on ; 允许或禁止 持久连接 
mssql.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
mssql.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制 
mssql.min_error_severity = 10 ; 显示的错误的最低严重性 
mssql.min_message_severity = 10 ; 显示的消息的最低重要性 
mssql.compatability_mode = off ; 与旧版的php 3.0 兼容的模式。

[assertion] 
; ????? 
;assert.active = on ; ?assert(expr); active by default 
;assert.warning = on ; issue a php warning for each failed assertion. 
;assert.bail = off ; don’t bail out by default. 
;assert.callback = 0 ; user-function to be called if an assertion fails. 
;assert.quiet_eval = 0 ; eval the expression with current error_reporting(). set to true if you want error_reporting(0) around the eval().

[ingres ii] 
ii.allow_persistent = on ; 允许或禁止 持久连接 
ii.max_persistent = -1 ; 持久连接的最大数。-1 代表无限制 
ii.max_links = -1 ; 连接的最大数目(持久和非持久)。-1 代表无限制 
ii.default_database = ; 默认 database (format : [node_id::]dbname[/srv_class] 
ii.default_user = ; 默认 user 
ii.default_password = ; 默认 password

[verisign payflow pro] 
pfpro.defaulthost = ” test.signio.com” ; 默认的 signio 服务器 
pfpro.defaultport = 443 ; 连接的默认端口 
pfpro.defaulttimeout = 30 ; 按秒计的默认超时时间

; pfpro.proxyaddress = ; 默认的代理的 ip 地址(如果需要) 
; pfpro.proxyport = ; 默认的代理的端口 
; pfpro.proxylogon = ; 默认的代理的登录(logon 用户名) 
; pfpro.proxypassword = ; 默认的代理的密码

[sockets] 
sockets.use_system_read = on ; 使用系统的read() 函数替代 php_read()封装 
; local variables: (局部变量) 
; tab-width: 4 
; end

到此这篇关于php之php.ini配置文件讲解案例的文章就介绍到这了,更多相关php之php.ini配置文件内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!