>  기사  >  백엔드 개발  >  PHP 오류 처리 방법 예

PHP 오류 처리 방법 예

小云云
小云云원래의
2018-03-07 10:03:511508검색

시스템 오류 처리기:

PHP의 일반적인 상황에서는 오류가 정상적으로 출력되지만 일부 프레임워크에서는 오류 출력에 영향을 줄 수 있습니다. 프레임워크 자체에 자체 처리 메커니즘이 있거나 다음과 같은 방식으로 처리될 수 있습니다. 일반적으로 이러한 함수 설정은 다음과 같습니다.

1.error_reporting(); PHP의 오류 보고 수준을 설정하고 현재 수준을 반환합니다.

error_reporting(report_level)

매개변수 수준이 지정되지 않은 경우 현재 오류 보고 수준 반환됩니다. 다음 항목은 가능한 레벨 값입니다.

과 유사합니다. 을 사용하여 설정한 E_WARNING과 유사한 치명적이지 않은 사용자 생성 경고입니다.

상수

설명

1

E_ERROR

치명적인 런타임 오류. 이 오류는 재활용할 수 없습니다. 스크립트 실행이 중단되었습니다.

2

E_WARNING

치명적이지 않은 런타임 경고. 스크립트 실행이 중단되지 않습니다.

4

E_PARSE🎜

컴파일 시간 분석 오류입니다. 분석기는 분석기에서 생성된 오류

8

E_NOTICE

에 대해서만 런타임에 알림을 받아야 합니다. 발견된 스크립트는 버그일 수 있지만 일반적으로 스크립트를 실행할 때 PHP 시작 중에

16

E_CORE_ERROR

치명적인 오류가 발생할 수도 있습니다. 이는 PHP가 시작될 때 PHP 코어의 E_ERROR

32

E_CORE_WARNING

경고와 같습니다. 이는 E_WARNING

64

E_COMPILE_ERROR

PHP 코어의 치명적인 컴파일 시간 오류와 같습니다. 이는 Zend 스크립트 엔진에서 생성된 E_ERROR를 전달하는 것과 같습니다

128

E_COMPILE_WARNING

치명적이지 않은 컴파일 시간 경고. 이는 ZEND 스크립트 엔진이 e_warning

256

E_USER_ERROR

을 발생시키는 오류와 유사하며, 이는 프로그래머가 PHP 함수 Trigger_error() 설정을 사용하여 설정한 E_ERROR

512

E_USER_WARNING

프로그래머가 PHP 함수 Trigger_error

1024

E_USER_NOTICE

사용자 생성 알림. 이는 프로그래머가 PHP 함수 Trigger_error

2048

을 사용하여 설정한 E_NOTICE와 유사합니다.

E_STRICT

런타임 알림. PHP는 코드 상호 운용성과 호환성을 돕기 위해 코드 변경을 권장합니다

4096

E_RECOVERABLE_ERROR

캐치 가능한 치명적 오류, E_ERROR와 유사하지만 사용자 정의 프로그램 캡처로 처리할 수 있음(set_error_handler 참조) ())

8191

E_ALL

레벨 E_STRICT를 제외한 모든 오류 및 경고(PHP6.0에서 E_STRICT는 E_ALL의 일부가 됩니다)

여기서 $level이 0이면 오류 출력이 꺼진다는 점, 즉 오류가 출력되지 않는다는 점에 주목할 가치가 있습니다.

2.set_error_handler()

정의 및 사용법

set_error_handler() 함수는 사용자 정의 오류 처리 기능을 설정합니다.

런타임 중 사용자 고유의 오류 처리 방법을 생성하는 데 사용되는 함수입니다.

이 함수는 이전 오류 처리기를 반환하거나, 실패하면 null을 반환합니다.

Syntax

set_error_handler(error_function,error_types)

Parameters

Description

error_function

필수입니다. 오류가 발생할 때 실행할 함수를 지정합니다.

error_types

선택사항. 사용자 정의 오류가 표시되는 오류 보고 수준을 지정합니다. 기본값은 "E_ALL"입니다.

팁: 이 함수를 사용하면 표준 PHP 오류 처리 기능이 완전히 우회됩니다. 필요한 경우 사용자 정의 오류 처리기는 스크립트를 종료(die())해야 합니다.

참고: 스크립트가 실행되기 전에 오류가 발생합니다. 해당 시점에는 사용자 정의 프로그램이 등록되지 않았으므로 사용자 정의 오류 핸들러가 사용되지 않습니다.

테스트 코드는 다음과 같습니다.


/**
 *
 * @param type $error_level 错误级别
 * @param type $error_message    错误信息
 * @param type $error_file 可选 错误文件
 * @param type $error_line 可选 错误行
 * @param type $error_context 可选。规定一个数组,包含了当错误发生时在用的每个变量以及它们的值。
 */
function my_error($error_level, $error_message, $error_file, $error_line, $error_context) {
  echo date('Y-m-d H:i:s') . $error_level . $error_message . $error_file . $error_line;
  var_dump($error_context);
}
set_error_handler('my_error', E_ALL);
print_r($a);

//通过上案例可以得知,在注册 my_error 方法时,系统会自动覆盖原有的错误处理 error_fuction() 方法
以上程序运行结果:

自定义错误触发器

定义和用法

trigger_error() 函数创建用户定义的错误消息。

trigger_error() 用于在用户指定的条件下触发一个错误消息。它与内建的错误处理器一同使用,也可以与由 set_error_handler() 函数创建的用户自定义函数使用。

如果指定了一个不合法的错误类型,该函数返回 false,否则返回 true。

语法

trigger_error(error_message,error_types)

参数

描述

error_message

必需。规定错误消息。长度限制为 1024 个字符。

error_types

可选。规定错误消息的错误类型。 可能的值:

  • E_USER_ERROR

  • E_USER_WARNING

  • E_USER_NOTICE

测试代码如下:


/**
 *
 * @param type $level
 * @param type $msg
 */
function my_error($level, $msg) {
  switch ($level) {
  case E_USER_ERROR:
    echo "ERROR:<br data-filtered="filtered">";
    break;
  case E_USER_WARNING:
    echo "WARNING:<br data-filtered="filtered">";
    break;
  case E_USER_NOTICE:
    echo "NOTICE:<br data-filtered="filtered">";
    break;
  default:
    break;
  }
  echo "错误编号:" . $level . " <br data-filtered="filtered">";
  echo "错误信息:" . $msg;
}
//注册错误处理器
set_error_handler(&#39;my_error&#39;);
if (89 > 8) {
  //调用错误触发器
  trigger_error(&#39;这是错误啊&#39;, E_USER_WARNING);
}

运行结果如下:

WARNING:
错误编号:512
错误信息:这是错误啊

相关推荐:

php错误处理和日志记录

PHP错误与异常调试视频教程资源分享

PHP错误机制

위 내용은 PHP 오류 처리 방법 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.