广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >PHP的错误机制总结
  • 754
分享到

PHP的错误机制总结

2023-06-17 04:06:10 754人浏览 安东尼
摘要

本篇内容介绍了“PHP的错误机制总结”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!特别说明:文章的php版本使用5.5.32PHP的错误级别

本篇内容介绍了“PHP的错误机制总结”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

特别说明:文章的php版本使用5.5.32

PHP的错误级别

首先需要了解php有哪些错误。截至到php5.5,一共有16个错误级别

注意:尝试下面的代码的时候请确保打开error_log:

error_reporting(E_ALL);  ini_set('display_errors', 'On');

E_ERROR

这种错误是致命错误,会在页面显示Fatal Error, 当出现这种错误的时候,程序就无法继续执行下去了

错误示例:

// Fatal error: Call to undefined function hpinfo() in /tmp/php/index.php on line 5  hpinfo(); //E_ERROR

注意,如果有未被捕获的异常,也是会触发这个级别的。

// Fatal error: Uncaught exception 'Exception' with message 'test exception' in /tmp/php/index.php:5 Stack trace: #0 {main} thrown in /tmp/php/index.php on line 5  throw new Exception("test exception");

E_WARNING

这种错误只是警告,不会终止脚本,程序还会继续进行,显示的错误信息是Warning。比如include一个不存在的文件。

//Warning: include(a.php): failed to open stream: No such file or directory in /tmp/php/index.php on line 7  //Warning: include(): Failed opening 'a.php' for inclusion (include_path='.:/usr/share/pear:/usr/share/php') in /tmp/php/index.php on line 7  include("a.php"); //E_WARNING

E_NOTICE

这种错误程度更为轻微一些,提示你这个地方不应该这么写。这个也是运行时错误,这个错误的代码可能在其他地方没有问题,只是在当前上下文情况下出现了问题。

比如$b变量不存在,我们把它赋值给另外一个变量

//Notice: Undefined variable: b in /tmp/php/index.php on line 9  $a = $b; //E_NOTICE

E_PARSE

这个错误是编译时候发生的,在编译期发现语法错误,不能进行语法分析。

比如下面的z没有设置为变量。

// Parse error: syntax error, unexpected '=' in /tmp/php/index.php on line 20  z=1; // E_PARSE

E_STRICT

这个错误是PHP5之后引入的,你的代码可以运行,但是不是PHP建议的写法。

比如在函数形参传递++符号

// Strict Standards: Only variables should be passed by reference in /tmp/php/index.php on line 17  function change (&$var) {  $var += 10;  }  $var = 1;  change(++$var);  // E_STRICT

E_RECOVERABLE_ERROR

这个级别其实是ERROR级别的,但是它是期望被捕获的,如果没有被错误处理捕获,表现和E_ERROR是一样的。

经常出现在形参定义了类型,但调用的时候传入了错误类型。它的错误提醒也比E_ERROR的fatal  error前面多了一个Catachable的字样。

//Catchable fatal error: Argument 1 passed to testCall() must be an instance of A, instance of B given, called in /tmp/php/index.php on line 37 and defined in /tmp/php/index.php on line 33  class A {  }  class B {  }  function testCall(A $a) {  }  $b = new B();  testCall($b);

E_DEPRECATED

这个错误表示你用了一个旧版本的函数,而这个函数后期版本可能被禁用或者不维护了。

比如curl的CURLOPT_POSTFIELDS使用@FILENAME来上传文件的方法

// Deprecated: curl_setopt(): The usage of the @filename api for file uploading is deprecated. Please use the CURLFile class instead in /tmp/php/index.php on line 42  $ch = curl_init("Http://www.remotesite.com/upload.php");  curl_setopt($ch, CURLOPT_POSTFIELDS, array('fileupload' => '@'. "test"));

E_CORE_ERROR, E_CORE_WARNING

这两个错误是由PHP的引擎产生的,在PHP初始化过程中发生。

E_COMPILE_ERROR, E_COMPILE_WARNING

这两个错误是由PHP引擎产生的,在编译过程中发生。

E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE, E_USER_DEPRECATED,

这些错误都是用户制造的,使用trigger_error,这里就相当于一个口子给用户触发出各种错误类型。这个是一个很好逃避try  catch异常的方式。

trigger_error("Cannot divide by zero", E_USER_ERROR);  // E_USER_ERROR  // E_USER_WARING  // E_USER_NOTICE  // E_USER_DEPRECATED

E_ALL

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

错误控制

php中有很多配置和参数是可以控制错误,以及错误的日志显示的。***步,我们需要了解的是php中的有关错误的配置有哪些?

我们按照php+php-fpm的模型来说,会影响php错误显示的其实是有两个配置文件,一个是php本身的配置文件php.ini,另外一个是php-fpm的配置文件,php-fpm.conf。

php.ini中的配置

error_reporting = E_ALL // 报告错误级别,什么级别的  error_log = /tmp/php_errors.log // php中的错误显示的日志位置  display_errors = On // 是否把错误展示在输出上,这个输出可能是页面,也可能是stdout  display_startup_errors = On // 是否把启动过程的错误信息显示在页面上,记得上面说的有几个Core类型的错误是启动时候发生的,这个就是控制这些错误是否显示页面的。  log_errors = On // 是否要记录错误日志  log_errors_max_len = 1024 // 错误日志的***长度  ignore_repeated_errors = Off // 是否忽略重复的错误  track_errors = Off // 是否使用全局变量$php_errORMsg来记录***一个错误  xmlrpc_errors = 0 //是否使用XML-RPC的错误信息格式记录错误  xmlrpc_error_number = 0 // 用作 XML-RPC faultCode 元素的值。  html_errors = On // 是否把输出中的函数等信息变为HTML链接  docref_root = http://manual/en/ // 如果html_errors开启了,这个链接的根路径是什么  fastcgi.logging = 0 // 是否把php错误抛出到fastcgi中

我们经常会被问到,error_reporting和display_errors有什么区别呢?这两个函数是完全不一样的。

PHP默认是会在日志和标准输出(如果是fpm模式标准输出就是页面)

error_reporting的参数是错误级别。表示什么样子的级别才应该触发错误。如果我们告诉PHP,所有错误级别都不需要触发错误,那么,不管是日志,还是页面,都不会显示这个错误,就相当于什么都没有发生。

display_errors是控制是否要在标准输出展示错误信息

log_errors则是控制是否要在日志中记录错误信息。

error_log是显示错误日志的位置,这个在php-fpm中往往会被重写,于是往往会发现的是cli和fpm的错误日志竟然不是在同一个文件中。

ignore_repeated_errors这个标记控制的是如果有重复的日志,那么就只会记录一条,比如下面的程序:

error_reporting(E_ALL);  ini_set('ignore_repeated_errors', 1);  ini_set('ignore_repeated_source', 1);  $a = $c; $a = $c; //E_NOTICE  //Notice: Undefined variable: c in /tmp/php/index.php on line 20

本来会出现两次NOTICE的,但是现在,只会出现一次了…

track_errors开启会把***一个错误信息存储到变量里面去,这个可能在对记日志的时候会有一些用处吧。不过我觉得真是没啥用…

html_errors 和 docref_root  两个是个挺有人性化的配置,配置了这两个参数以后,我们返回的错误信息中如果有一些在文档中有的信息,就会变成链接形式。

error_reporting(E_ALL);  ini_set('html_errors', 1);  ini_set('docref_root', "https://secure.php.net/manual/zh/");  include("a2.php"); //E_WARNING

能让你快速定位到我们出现错误的地方。是不是很人性~

php-fpm中的配置

error_log = /var/log/php-fpm/error.log // php-fpm自身的日志  log_level = notice // php-fpm自身的日志记录级别  php_flag[display_errors] = off // 覆盖php.ini中的某个配置变量,可被程序中的ini_set覆盖  php_value[display_errors] = off // 同php_flag  php_admin_value[error_log] = /tmp/www-error.log // 覆盖php.ini中的某个配置变量,不可被程序中的ini_set覆盖  php_admin_flag[log_errors] = on // 同php_admin_value  catch_workers_output = yes // 是否抓取fpmworker的输出  request_slowlog_timeout = 0 // 慢日志时长  slowlog = /var/log/php-fpm/www-slow.log // 慢日志记录

php-fpm的配置中也有一个error_log配置,这个很经常会和php.ini中的error_log配置弄混。但他们记录的东西是不一样的,php-fpm的error_log只记录php-fpm本身的日志,比如fpm启动,关闭。

而php.ini中的error_log是记录php程序本身的错误日志。

那么在php-fpm中要覆盖php.ini中的error_log配置,就需要使用到下面几个函数:

  • php_flag

  • php_value

  • php_admin_flag

  • php_admin_value

这四个函数admin的两个函数说明这个变量设置完之后,不能在代码中使用ini_set把这个变量重新赋值了。而php_flag/value就仍然以php代码中的ini_set为准。

slowlog是fpm记录的,可以使用request_slowlog_timeout设置判断慢日志的时长。

“PHP的错误机制总结”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: PHP的错误机制总结

本文链接: https://www.lsjlt.com/news/287067.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • PHP的错误机制总结
    本篇内容介绍了“PHP的错误机制总结”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!特别说明:文章的PHP版本使用5.5.32PHP的错误级别...
    99+
    2023-06-17
  • PHP屏蔽错误的方法总结
    1、@屏蔽法 @在php中一个抑制错误的符号,即便是你开启了报错功能,只要在错误语句之前加上@符号,便可屏蔽了错误信息。使用@抑制错误之前,会出现一个警告错误。 2、error_re...
    99+
    2022-11-12
  • PLSQL错误总结
    "" is null为true,""和null是同一个东西。 神经病写法:无论vc_itemids是null还是"",or后面的那一句都为false,判空只能使用is null 或者 is not null。下面的vc_itemi...
    99+
    2016-06-19
    PLSQL错误总结
  • 【总结】iis7上常见的php错误提示
    PHP是一种非常流行的服务器端脚本语言,经常用于Web开发中。而IIS7则是一个非常流行的微软的Web服务器。在PHP运行于IIS7之上时,有时候可能会遇到错误提示,这篇文章将探讨一些常见的错误提示以及如何解决这些问题。FastCGI安装问...
    99+
    2023-05-14
    iis php
  • IE中JavaScript错误总结
    这篇文章将为大家详细讲解有关IE中JavaScript错误总结,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。IE中JavaScript错误有:1、【error # 5】无效的过程调用或参数;2、【erro...
    99+
    2023-06-14
  • PHP中最低级别的错误类型总结
    序言:php错误就是会使脚本运行不正常的情况。 php的错误有很多种,包括warning、notice、deprecated、fetal error等。其中notice不叫通知,而叫通知级别的错误,warning也不叫警告,而叫警告级别的错...
    99+
    2019-07-10
    PHP 低级错误
  • 常见的socket error错误总结
    常见的socket error错误总结如下:1. ConnectionRefusedError:连接被拒绝。可能是目标主机拒绝了连接...
    99+
    2023-08-24
    错误
  • 常见php错误和诊断方法【总结】
    PHP是一种流行的Web编程语言,已被广泛应用于开发和维护各种网站和Web应用程序。然而,PHP编程时难免会出现一些错误,其中之一就是PHP错误。PHP错误可能是由代码中的语法错误、未定义的变量、执行超时或内存不足等问题导致的。以下是关于P...
    99+
    2023-05-14
    php
  • 总结PHP屏蔽返回错误信息的方法
    在进行 PHP 开发的过程中,我们难免会遇到一些程序运行出错的情况。此时,系统默认的错误提示信息可能会给攻击者带来机会。因此,在实际的开发过程中,我们需要对错误信息进行屏蔽,以加强网站的安全性。本文将通过介绍 PHP 屏蔽返回错误信息的方法...
    99+
    2023-05-14
  • 总结PHP的一些常见错误和提示信息
    PHP是广泛使用的语言,许多网站和应用程序都使用它来实现功能和交互性。然而,PHP作为一种解释性语言,在代码编写和运行时会面临各种问题,特别是错误和异常的情况。在本文中,我们将介绍PHP的一些常见错误和提示信息,并提供关于如何解决这些问题的...
    99+
    2023-05-14
  • Python错误+异常+模块总结
    目录错误和异常语法错误异常异常处理抛出异常模块前言: 本篇主要讲两方面,错误和异常以及模块。在编程时遇见错误信息在所难免,Python中会也有很多种错误信息,常见的两种就是语法错误和...
    99+
    2022-11-11
  • 总结Node.js中的一些错误类型
    前言 Node.js应用中可能会发生多种类型的错误。如:当出现语法错误或运行时错误时,会触发JavaScript错误;当试图试访问一个不存在或没有访问的文件时,会触发系统错误;除JavaScript错误和系...
    99+
    2022-06-04
    错误 类型 Node
  • PHP中的错误及其处理机制
    目录什么是错误?Fatal Error:致命错误(脚本终止运行)Parse Error:编译时解析错误,语法错误(脚本终止运行)Warning Error:警告错误(仅给出提示信息,...
    99+
    2022-11-12
  • linux安装oracle常见错误 总结
    PS:新手,没装过数据库,各种错误基本都碰上了。。。血泪史1,打开11.2.0.3安装脚本报错,查看日志。造成错误的原因可能是dns没有返回服务名的IP,可能是hosts原因   经查看...
    99+
    2022-10-18
  • Python错误和异常总结详细
    目录1、语法错误2、异常3、try...except...语句4、多个except子句5、try...except Exception as e语句6、try...except......
    99+
    2022-11-12
  • ios xcode警告与错误的分析总结
    1.相同具有外部链接的静态变量 可能是文件重复,两个类当中都声明了具有相同名字的具有外部链接的静态变量。 由于枚举类型导致的1 duplicate symbol for arch...
    99+
    2022-05-20
    xcode 警告 错误
  • php异常和错误处理机制
    文章目录 基本概念标准异常处理自定义异常处理 异常处理最佳使用场景控制异常代码影响范围保证数据统一性 错误处理错误等级定义标准错误处理自主处理非致命错误自主处理致命错误抛出自定义错误 ...
    99+
    2023-09-13
    php
  • PHP中的错误处理机制是什么?
    PHP是一种流行而强大的服务器端编程语言,可以用来开发各种Web应用程序。就像其他编程语言一样,PHP也有可能会出现错误和异常。这些错误和异常可能由各种原因引起,如程序错误、服务器错误、用户输入错误等等。为了确保程序的运行稳定性和可靠性,P...
    99+
    2023-05-14
    PHP错误处理 异常处理 错误日志记录
  • PHP中有哪些常见的错误机制
    今天就跟大家聊聊有关PHP中有哪些常见的错误机制,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。PHP的错误级别首先需要了解php有哪些错误。截至到php5.5,一共有16个错误级别注...
    99+
    2023-06-17
  • Java反射机制的学习总结
    一、什么是反射机制 简单的来说,反射机制指的是程序在运行时能够获取自身的信息。在java中,只要给定类的名字,那么就可以通过反射机制来获得类的所有信息。 二、哪里用到反射机制 有些...
    99+
    2022-11-15
    Java 反射机制
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作