>백엔드 개발 >PHP 튜토리얼 >개발 모드 및 제품 모드의 PHP 오류 처리

개발 모드 및 제품 모드의 PHP 오류 처리

不言
不言원래의
2018-04-20 11:45:221584검색

이 기사에서는 예제 코드를 통해 개발 모드와 제품 모드에서의 PHP 오류 처리를 소개합니다. 매우 훌륭하고 참고할 가치가 있습니다. 필요한 친구가 참고할 수 있습니다.

코드를 작성하더라도 프로그램 오류 보고는 항상 불가피합니다. 특히 조심하세요.

PHP 프로그램을 개발할 때 PHP 오류가 발생하면 디버깅을 용이하게 하기 위해 가능한 한 빨리 오류가 표시될 수 있기를 바랍니다. 프로그램이 개발되어 정식 제품이 되면 이러한 오류 메시지를 사용자에게 표시하는 대신 오류 로그에 예상치 못한 오류 메시지를 기록하기를 바랍니다. 사용자는 이러한 오류 메시지를 사용하여 스크립트 경로, 데이터베이스 정보 또는 기타 오류 메시지를 노출할 가능성이 높기 때문입니다. 파괴적인 해킹 작업을 나타냅니다.

PHP의 오류 처리 방법은 다음 구성 옵션을 기반으로 합니다. 이러한 구성은 코드에서 선언하거나 php.ini 파일에서 설정할 수 있습니다. 이러한 구성을 자주 변경할 필요가 없다면 php.ini 파일에 설정하여 코드를 더 깔끔하고 간결하게 만드는 것이 좋습니다.

# 是否打印错误信息到浏览器/命令行界面# 开发模式下建议开启,产品模式下强烈建议关闭ini_set('display_errors', 'On');# 是否记录错误信息到日志# 开发模式和产品模式下都建议开启ini_set('log_errors', 'On');# 指定错误信息日志文件,若开启了 log_errors 选项,记得指定日志文件位置# 要确保执行 php 脚本的系统用户拥有该文件的 write 权限,否则日志无法被写入ini_set('error_log', '/usr/local/php/errors.log');# 该选项用以设定错误报告的等级# 等同于 error_reporting(E_ALL) # 无论开发模式还是产品模式下都建议开到E_ALL(报告所有的错误信息)# 产品模式下也需要设置此选项,因为关闭了 display_errors 并开启了 log_errors# 所以浏览器/命令行界面不会因此暴露报错信息ini_set('error_reporting', E_ALL);

또한 PHP는 개발자에게 사용자 지정 오류 메시지를 오류 로그 파일에 기록하는 내장 기능을 코드로 제공합니다.

bool error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] )
오류 메시지를 웹 서버의 오류 로그나 파일에 보냅니다.

필수 매개변수는 파일에서 message ,调用此函数会将 message 写入 php.ini 中定义的 error_log입니다.


위 내용은 개발 모드 및 제품 모드의 PHP 오류 처리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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