PHP error and exception handling

墨辰丷
Release: 2023-03-31 06:46:01
Original
1445 people have browsed it

This article mainly introduces PHP error and exception handling. Interested friends can refer to it. I hope it will be helpful to everyone.

In the daily project development process, there will always be some unexpected exceptions and errors. If we do not deal with them relatively well, the program will look very unprofessional, and it is likely to fail. It will become effective information for others to attack the system; some error exceptions will terminate the execution of the script. If there is no error message at this time, then we can only look at the code from the beginning. We must know that hundreds of lines of code in the project are very important to us. What a scary thing it is, so how can we quickly and accurately locate exceptions and errors during the project development process, and handle them accordingly? This article uses my own understanding of errors and exception handling to share with you Everyone learns from each other and serves as a reminder.

System error handler:

PHP Under normal circumstances, the error will be output normally, but in some frameworks, it may affect the error output, maybe the framework It has its own processing mechanism, or it may be processed in the code. Generally, these function settings are:

1.error_reporting(); Set the error level of PHP and return the current level

error_reporting(report_level)

If the parameter level is not specified, the current error level will be returned. The following items are possible values ​​for level:

##fatal Runtime error. This error cannot be recycled. Script execution was interrupted. ##32## in the core of PHP#E_CORE_WARNINGWarning when ## in the core of PHP128## generated by the Zend through the ZendE_USER_ERRORFatal user-generated error, similar to how programmers use the PHPtrigger_error

Value

Constant

Description

##1

E_ERROR

2

E_WARNING

Non-fatal runtime warning. Script execution is not interrupted.

4

##E_PARSE

Compile time analysis error. Parsing should only generate errors

8

E_NOTICE

Runtime notification. The script found may be a bug, but typically when running a script, it can also happen

16

E_CORE_ERROR

Fatal error occurred when PHPstarted. This is like E_ERROR

PHP

starts. This is like E_WARNING

64

#E_COMPILE_ERROR

Fatal compile-time error. This is like E_ERROR

script engine.

#E_COMPILE_WARNING

Non-fatal compile-time warning. This is like generating

E_WARNING

##256
script engine.

function

trigger_error() Set E_ERROR

512

E_USER_WARNING

Non-fatal user-generated warning, this Similar to the E_WARNING set by the programmer using the PHP

function

1024

E_USER_NOTICE

User generated notification, this is similar to how programmers use PHP functionstrigger_error SET E_NOTICE

##2048

E_STRICT

Runtime notification. PHPRecommended changes to your code to aid interoperability and compatibility of this code

4096

E_RECOVERABLE_ERROR

Catchable fatal error, similar to E_ERROR, but can be user-defined handler Capture (see set_error_handler())

8191

E_ALL

All errors and warnings except level E_STRICT (In PHP6.0, E_STRICT will be E_ALL

#

It is worth noting here that when $level is 0, error output is turned off, that is, no errors will be output.

2.set_error_handler()

Definition and usage

The set_error_handler() function sets a user-defined error handling function.

This function is used to create the user's own error handling method during runtime.

This function will return the old error handler, or null if it fails.

Syntax

set_error_handler(error_function,error_types)

Parameters

Description

error_function

Required. Specifies the function to run when an error occurs.

error_types

Optional. Specifies at which error reporting level user-defined errors are displayed. The default is "E_ALL".

Tip: If this function is used, the standard PHP error handling function will be completely bypassed. If necessary, the user-defined error handler must terminate (die()) the script,

Note: If in An error occurs before the script is executed. Since the custom program has not been registered at that time, the custom error handler will not be used.

The test code is as follows:

/**
 *
 * @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);
Copy after login

//It can be known from the above case that when registering the my_error method, the system will automatically overwrite the original error handling error_fuction() method
The above program Running results:

Custom error trigger

Definition and usage

trigger_error() function creates a user Defined error message.

trigger_error() is used to trigger an error message under user-specified conditions. It is used with the built-in error handler or with user-defined functions created with the set_error_handler() function.

If an illegal error type is specified, this function returns false, otherwise it returns true.

Syntax

trigger_error(error_message,error_types)

Parameters

Description

error_message

Required. Specifies the error message. The length limit is 1024 characters.

##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/>";
    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(&#39;my_error&#39;);
if (89 > 8) {
  //调用错误触发器
  trigger_error(&#39;这是错误啊&#39;, E_USER_WARNING);
}
Copy after login

运行结果如下:

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

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

php字符串及流程控制的方法

PHP实现全角字符转为半角的方法

php实现针对html标签中结束标签的检测与补全功能

The above is the detailed content of PHP error and exception handling. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!