방법: 1. 오류 제어 연산자 "@"를 PHP 표현식 앞에 배치하면 생성될 수 있는 모든 오류 메시지가 무시됩니다. 2. error_reporting() 함수를 사용하십시오. 3. "php.ini" 파일에서 "display_errors" 항목의 값을 "Off"로 설정하십시오.
이 튜토리얼의 운영 환경: Windows 7 시스템, PHP 버전 7.1, DELL G3 컴퓨터
PHP에는 오류를 차단하는 3가지 방법이 있습니다.
오류 제어 연산자 사용: @
@
使用 error_reporting() 函数屏蔽错误
通过 display_errors 参数屏蔽错误
1、使用错误控制运算符:@
PHP 支持使用错误控制运算符@
。将其放置在一个 PHP 表达式之前,该表达式可能产生的任何错误信息都将被忽略掉。
如果用 set_error_handler() 设定了自定义的错误处理函数,这个错误处理函数仍然会被调用,而如果在出错语句前使用了@
的话,错误处理函数将返回 0。
需要注意的是,@
运算符只对表达式有效。简单来说就是,如果能从某处得到值,就能在它前面加上 @
运算符。例如可以在变量、函数、include 调用、常量等等之前使用 @
运算符,但不能把它放在函数或类的定义之前,也不能用于条件结构例如 if 和 foreach 等语句前。
@
运算符对于可以导致程序终止的严重错误也是有效的,这意味着如果在某个不存在或者敲错了字母的函数调用前用了@来抑制错误信息,那么程序将没有任何提示的死在那里。
【示例】使用 @
错误控制运算符屏蔽代码中的错误。
<?php $link = @mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db") or die('数据库连接失败!'); ?>
运行结果如下:
数据库连接失败!
2、使用 error_reporting()
display_errors 매개변수를 통해 오류를 마스크하세요
1. 제어 연산자:@
🎜🎜🎜PHP는 오류 제어 연산자 @
사용을 지원합니다. PHP 표현식 앞에 배치하면 표현식에서 생성될 수 있는 모든 오류 메시지가 무시됩니다. 🎜🎜set_error_handler()를 사용하여 사용자 정의 오류 처리 함수를 설정하면 이 오류 처리 함수가 계속 호출되고 오류 문 앞에 @
가 사용되면 오류 처리 함수가 0을 반환합니다. 🎜🎜@
연산자는 표현식에만 유효하다는 점에 유의하세요. 간단히 말해서, 어딘가에서 값을 얻을 수 있다면 값 앞에 @
연산자를 추가할 수 있습니다. 예를 들어 변수, 함수, 포함 호출, 상수 등 앞에 @
연산자를 사용할 수 있지만 함수나 클래스 정의 앞에 놓을 수 없으며 조건부에서도 사용할 수 없습니다. 명령문 앞에 if 및 foreach 등과 같은 구조를 추가합니다. 🎜🎜@
연산자는 프로그램 종료를 유발할 수 있는 심각한 오류에도 효과적입니다. 즉, 존재하지 않거나 잘못된 문자가 있는 함수 호출 앞에 @를 사용하면 오류 메시지가 나타납니다. 그러면 프로그램이 아무런 메시지도 없이 종료됩니다. 🎜🎜【예제】코드의 오류를 마스킹하려면 @
오류 제어 연산자를 사용하세요. 🎜error_reporting([int $level])🎜실행 결과는 다음과 같습니다. 🎜
<?php error_reporting(0); $link = mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db") or die('数据库连接失败!'); ?>🎜🎜2. 오류를 보호하려면
error_reporting()
함수를 사용하세요.🎜🎜🎜PHP에는 error_reporting() 함수를 사용하여 무엇을 설정할지 설정합니다. PHP가 보고하는 오류 종류는 다음과 같습니다. 🎜; This directive controls whether or not and where PHP will output errors, ; notices and warnings too. Error output is very useful during development, but ; it could be very dangerous in production environments. Depending on the code ; which is triggering the error, sensitive information could potentially leak ; out of your application such as database usernames and passwords or worse. ; For production environments, we recommend logging errors rather than ; sending them to STDOUT. ; Possible Values: ; Off = Do not display any errors ; stderr = Display errors to STDERR (affects only CGI/CLI binaries!) ; On or stdout = Display errors to STDOUT ; Default Value: On ; Development Value: On ; Production Value: Off ; http://php.net/display-errors display_errors = Off🎜 $level 매개변수는 오류 수준을 설정하는 것입니다. $level이 0으로 설정되면 모든 PHP 오류 보고서가 꺼집니다. -1로 설정하면 모든 오류 보고서가 반환됩니다. 🎜🎜PHP의 오류 유형은 아래 표에 나와 있습니다. 🎜
值 | 常量 | 说明 |
---|---|---|
1 | E_ERROR | 致命的运行时错误,一般是不可恢复的情况,例如内存分配导致的问题,后果是导致脚本终止、不再继续运行。 |
2 | E_WARNING | 运行时警告(非致命错误),仅给出提示信息,但是脚本不会终止运行。 |
4 | E_PARSE | 编译时语法解析错误,仅由分析器产生。 |
8 | E_NOTICE | 运行时通知,表示脚本遇到可能会表现为错误的情况,但是在可以正常运行的脚本里面也可能会有类似的通知。 |
16 | E_CORE_ERROR | 在 PHP 初始化启动过程中发生的致命错误,类似 E_ERROR,但是是由 PHP 引擎核心产生的。 |
32 | E_CORE_WARNING | PHP 初始化启动过程中发生的警告(非致命错误),类似 E_WARNING ,但是是由 PHP 引擎核心产生的。 |
64 | E_COMPILE_ERROR | 致命编译时错误,类似 E_ERROR,但是是由 Zend 脚本引擎产生的。 |
128 | E_COMPILE_WARNING | 编译时警告(非致命错误),类似 E_WARNING,但是是由 Zend 脚本引擎产生的。 |
256 | E_USER_ERROR | 用户产生的错误信息,类似 E_ERROR,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
512 | E_USER_WARNING | 用户产生的警告信息,类似 E_WARNING,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
1024 | E_USER_NOTICE | 用户产生的通知信息,类似 E_NOTICE,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
1024 | E_STRICT | 启用 PHP 对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。 |
2048 | E_RECOVERABLE_ERROR | 可被捕捉的致命错误,表示发生了一个可能非常危险的错误,但是还没有导致 PHP 引擎处于不稳定的状态。如果该错误没有被用户自定义句柄捕获,将成为一个 E_ERROR,从而使脚本终止运行。 |
8192 | E_DEPRECATED | 运行时通知,启用后将会对在未来版本中可能无法正常工作的代码给出警告。 |
16384 | E_USER_DEPRECATED | 用户产生的警告信息,类似 E_DEPRECATED,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
30719 | E_ALL | E_STRICT 除外的所有错误和警告信息。 |
【示例】使用 error_reporting() 函数屏蔽代码中的错误。
<?php error_reporting(0); $link = mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db") or die('数据库连接失败!'); ?>
3、通过 display_errors
参数屏蔽错误
这种方法应该是最彻底的一种解决办法,因为前两种方法只能作用于单行或者单个文件,而这个则是作用于所有的 PHP 文件。
具体的操作方法就是,打开 php.ini 配置文件,在其中搜索 display_errors,然后将 display_errors 的值设置为 Off 即可关闭所有的 PHP 错误报告。如下所示:
; This directive controls whether or not and where PHP will output errors, ; notices and warnings too. Error output is very useful during development, but ; it could be very dangerous in production environments. Depending on the code ; which is triggering the error, sensitive information could potentially leak ; out of your application such as database usernames and passwords or worse. ; For production environments, we recommend logging errors rather than ; sending them to STDOUT. ; Possible Values: ; Off = Do not display any errors ; stderr = Display errors to STDERR (affects only CGI/CLI binaries!) ; On or stdout = Display errors to STDOUT ; Default Value: On ; Development Value: On ; Production Value: Off ; http://php.net/display-errors display_errors = Off
推荐学习:《PHP视频教程》
위 내용은 PHP에서 오류 메시지를 차단하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!