PHP 不能正常屏蔽错误信息的问题

问题

今天 APP 突然不能正常注册了,使用 POSTMAN 检查 API 接口发现原来是服务器返回了多余的错误警告信息,导致客户端不能正常解析 JSON 格式造成注册失败。

PHP 不能正常屏蔽错误信息的问题_第1张图片

所以现在问题是要如何屏蔽这些错误或警告信息。

参考网络的方法是修改 php.ini 文件中的 display_errors 选项,将其值设置为 Off,经测试无效。又据说是 log_errors 选项如果设置为 On,则 error_log 选项必须指定,需要把 log_errors 值设置为 Off,经测试仍然无效。

解决

最后还是在 PHP 代码开头添加 error_reporting(0) 来实现屏蔽的。


补充

以下是官方对这几个配置项的说明:

  • display_errors string

该选项设置是否将错误信息作为输出的一部分显示到屏幕,或者对用户隐藏而不显示。设置 "stderr" 表示发送到 stderr 而不是 stdout。 "stderr"从 PHP 5.2.4 开始可用。在以前的版本中,该配置值的类型为 boolean.

Note:这是一个辅助开发的功能,建议永远不要在生产系统中使用 (例如系统被连接到互联网对外提供服务)。

Note:尽管 display_errors 也可以在运行时设置 (使用 ini_set()), 但是脚本出现致命错误时任何运行时的设置都是无效的。 因为在这种情况下预期运行的操作不会被执行。

  • log_errors boolean

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

Note:在生产系统中,强烈建议你使用错误日志记录 web 站点上显示的错误信息。

  • error_log string

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

不过最后还是学会了几条有用的命令:

  • 比较可以使用以下命令来查找 PHP 的配置文件位置
[root@localhost ~]# php -i|grep php.ini
#然后会输出以下信息:
Configuration File (php.ini) Path => /etcLoaded Configuration File => /etc/php.ini
  • 还有 php-fpm 的重启命令
#centos 6
[root@localhost ~]# service php-fpm restart
#centos 7
[root@localhost ~]# systemctl restart php-fpm.service
#或者使用 pid 信号方式
[root@localhost ~]# sudo kill -USR2 $(pgrep php-fpm)
#再或者先手动杀死所有 php-fpm 的进程
[root@localhost ~]# pkill php-fpm
#再手动重启
 php-fpm[root@localhost ~]# php-fpm -D # -D 参数是指以 daemon 形式在后台运行。
#最后通过 ps 命令来查看是否正常启动
[root@localhost ~]# ps aux|grep php-fpm

你可能感兴趣的:(PHP 不能正常屏蔽错误信息的问题)