PHP 오류 처리 메커니즘_php 기술

WBOY
풀어 주다: 2016-05-16 20:11:45
원래의
1030명이 탐색했습니다.

일상적인 프로젝트 개발 과정에서는 예상치 못한 비정상적인 오류가 항상 발생하기 마련입니다. 이를 비교적 잘 처리하지 않으면 프로그램이 매우 비전문적으로 보일 수 있으며, 이는 다른 사람의 공격에 유효한 정보가 될 가능성이 높습니다. 일부 오류 예외는 스크립트 실행을 종료합니다. 이때 오류 메시지가 없으면 처음부터 코드만 볼 수 있습니다. 정말 무서운 일인데, 어떻게 하면 프로젝트 개발 과정에서 예외와 오류를 빠르고 정확하게 찾아 적절하게 처리할 수 있을까요? 이 글에서는 오류와 예외 처리에 대해 제가 이해한 내용을 모두와 공유하여 서로에게서 배울 수 있습니다. 그리고 알림 역할을 합니다.

시스템 오류 처리기:

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

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

error_reporting(보고서_수준)

매개변수 수준을 지정하지 않으면 현재 오류 수준이 반환됩니다. 레벨에 가능한 값은 다음과 같습니다.

1024E_USER_NOTICE

가치

상시

설명

1

E_ERROR

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

2

주의_경고

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

4

E_PARSE

컴파일 시간 분석 오류입니다. 구문 분석 오류는 구문 분석기에 의해서만 생성되어야 합니다

8

E_NOTICE

런타임 알림. 발견된 스크립트는 버그일 수도 있지만, 스크립트 실행 시 정상적으로 발생할 수도 있습니다

16

E_CORE_ERROR

PHP가 시작될 때 치명적인 오류가 발생했습니다. PHP의 핵심에 있는 E_ERROR

과 같습니다.

32

E_CORE_경고

PHP가 시작될 때 경고합니다. PHP 핵심에 있는 E_WARNING

과 같습니다.

64

E_COMPILE_ERROR

심각한 컴파일 시간 오류. 이는 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 E_WARNING

프로그래머가 PHP 함수 trigger_error E_NOTICE

를 사용하여 설정한 것과 유사한 사용자 생성 알림

2048

E_STRICT

런타임 알림. PHP해당 코드의 상호 운용성과 호환성에 도움이 되도록 코드 변경 제안

4096

E_RECOVERABLE_ERROR

잡을 수 있는 치명적인 오류, E_ERROR과 비슷하지만 사용자 정의 핸들러로 잡을 수 있습니다(set_error_handler() 참조)

8191

E_ALL

E_STRICT 레벨을 제외한 모든 오류 및 경고(PHP6.0에서 E_STRICTE_ALL 부분입니다)

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

2.set_error_handler()

정의 및 사용법

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

런타임 중 사용자가 직접 오류 처리 방법을 만들 때 사용하는 함수입니다.

이 함수는 이전 오류 핸들러를 반환하거나, 실패할 경우 null을 반환합니다.

문법

set_error_handler(error_function,error_types)

매개변수

参数

描述

error_function

必需。规定发生错误时运行的函数。

error_types

可选。规定在哪个错误报告级别会显示用户定义的错误。默认是 "E_ALL"。

설명
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)

매개변수

설명

오류 메시지

필수입니다. 오류 메시지를 지정합니다. 길이 제한은 1024 자입니다.

오류_유형

선택사항. 오류 메시지의 오류 유형을 지정합니다. 가능한 값:

  • 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/>";
    break;
  case E_USER_WARNING:
    echo "WARNING:<br/>";
    break;
  case E_USER_NOTICE:
    echo "NOTICE:<br/>";
    break;
  default:
    break;
  }
  echo "错误编号:" . $level . " <br/>";
  echo "错误信息:" . $msg;
}
//注册错误处理器
set_error_handler('my_error');
if (89 > 8) {
  //调用错误触发器
  trigger_error('这是错误啊', E_USER_WARNING);
}
로그인 후 복사

运行结果如下:

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

以上所述就是本文的全部内容了,希望大家能够喜欢。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿