php 致命错误提示_PHP中的错误提示

1、打开/关闭错误提示的方法包括:a、更改php.ini文件 b、使用ini_set设置,详见下表

变量

php.ini

语法:变量=值

ini_set

语法:ini_set(“变量”,值)

说明

display_errors

On / Off

on / off,true / false , 1/ 0

开启/关闭显示错误提示,但不影响错误写入日志。即display_errors关闭,错误信息可以写入日志,仅不在客户端显示而已。

error_reporting

见下表

见下表

显示错误级别

display_startup_errors

On / Off

on / off,true / false , 1/ 0

即使 display_errors 设置为开启, PHP 启动过程中的错误信息也不会被显示。强烈建议除了调试目的以外,将 display_startup_errors 设置为关闭。和E_CORE_ERROR、E_CORE_WARNING有关

log_errors

On / Off

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

注意:如果该选项关闭,则nginx都无法获取到错误日志

error_log

日志路径

如果在php.ini中打开该日志路径,则错误信息写入该路径,而nginx则无法获取到错误信息。

log_errors_max_len

int(默认 1024)

设置 log_errors 的最大字节数,仅对错误消息写入php日志起作用,对写入nginx的错误消息不起作用.该长度设置对记录的错误,显示的错误,以及 $php_errormsg都会有限制作用。

ignore_repeated_errors

On / Off,默认off

-

不记录重复的信息。重复的错误必须出现在同一个文件中的同一行代码上,除非 ignore_repeated_source 设置为true。

ignore_repeated_source

On / Off,默认off

-

忽略重复消息时,也忽略消息的来源。当该设置开启时,重复信息将不会记录它是由不同的文件还是不同的源代码行产生的。

report_memleaks

On / Off,默认on

-

如果这个参数设置为Off,则内存泄露信息不会显示 (在 stdout 或者日志中)。这只对调试编译有效,而且需要 error_reporting 包含了 E_WARNING 才会起作用.

track_errors

On / Off,默认off

-

如果开启,最后的一个错误将永远存在于变量 $php_errormsg 中

$php_errormsg

-

-

$php_errormsg 变量包含由 PHP 生成的最新错误信息。这个变量只在错误发生的作用域内可用,并且要求 track_errors 配置项是开启的(默认是关闭的)。

html_errors

On / Off,默认on

-

在错误信息中关闭HTML标签。这种新的HTML格式的错误信息是可以点击,它引导用户前往描述该错误或者导致该错误发生的函数的参考信息页面。

xmlrpc_errors

1 / 0 ,默认0

-

关闭正常的错误报告,并将错误的格式设置为XML-RPC错误信息的格式

xmlrpc_error_number

int,默认0

用作 XML-RPC faultCode 元素的值

error_prepend_string

string

-

错误信息之前输出的内容,不写入日志,仅在客户端展示。

error_append_string

string

-

错误信息之后输出的内容,不写入日志,仅在客户端展示。

2、error_reporting的设置

设置方法包括:a、在php.ini中设置。b、在PHP中使用error_reporting()函数 c 、在PHP中使用ini_set函数

设置方法包括:a、使用int值设置。b、使用常量设置。

举例说明:

error_reporting=8

error_reporting=7 (7相当于1+2+4)

error_reporting = E_ALL & ~E_DEPRECATED & ~E_STRICT

error_reporting(0) //关闭错误

error_reporting(E_ALL) //E_STRICT出外的所有错误和警告信息

error_reporting(-1) //所有错误

ini_set("error_reporting",-1)

ini_set("error_reporting",E_WARNING)

错误级别

常量

说明

1

E_ERROR

致命的运行时错误。这类错误一般是不可恢复的情况,例如内存分配导致的问题。后果是导致脚本终止不再继续运行。

2

E_WARNING

运行时警告 (非致命错误)。仅给出提示信息,但是脚本不会终止运行。

4

E_PARSE

编译时语法解析错误。解析错误仅仅由分析器产生。

8

E_NOTICE

运行时通知。表示脚本遇到可能会表现为错误的情况,但是在可以正常运行的脚本里面也可能会有类似的通知。

16

E_CORE_ERROR

在PHP初始化启动过程中发生的致命错误。该错误类似 E_ERROR,但是是由PHP引擎核心产生的。display_startup_errors开启时,才会显示,和display_errors设置无关

32

E_CORE_WARNING

在PHP初始化启动过程中发生的警告 (非致命错误) 。类似 E_WARNING,但是是由PHP引擎核心产生的。display_startup_errors开启时,才会显示,和display_errors设置无关

64

E_COMPILE_ERROR

致命编译时错误。类似E_ERROR, 但是是由Zend脚本引擎产生的。

128

E_COMPILE_WARNING

编译时警告 (非致命错误)。类似 E_WARNING,但是是由Zend脚本引擎产生的。

256

E_USER_ERROR

用户产生的错误信息。类似 E_ERROR, 但是是由用户自己在代码中使用PHP函数trigger_error()来产生的。

512

E_USER_WARNING

用户产生的警告信息。类似 E_WARNING, 但是是由用户自己在代码中使用PHP函数trigger_error()来产生的。

1024

E_USER_NOTICE

用户产生的通知信息。类似 E_NOTICE, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。

2048

E_STRICT

启用 PHP 对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。

4096

E_RECOVERABLE_ERROR

可被捕捉的致命错误。 它表示发生了一个可能非常危险的错误,但是还没有导致PHP引擎处于不稳定的状态。 如果该错误没有被用户自定义句柄捕获 (参见 set_error_handler()),将成为一个 E_ERROR 从而脚本会终止运行

8192

E_DEPRECATED

运行时通知。启用后将会对在未来版本中可能无法正常工作的代码给出警告。

16384

E_USER_DEPRECATED

用户产少的警告信息。 类似 E_DEPRECATED, 但是是由用户自己在代码中使用PHP函数trigger_error()来产生的。

30719

E_ALL

E_STRICT除外的所有错误和警告信息

3、自定义错误和异常

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值