시스템 오류 처리기:
PHP의 일반적인 상황에서는 오류가 정상적으로 출력되지만 일부 프레임워크에서는 오류 출력에 영향을 줄 수 있습니다. 프레임워크 자체에 자체 처리 메커니즘이 있거나 다음과 같은 방식으로 처리될 수 있습니다. 일반적으로 이러한 함수 설정은 다음과 같습니다.
1.error_reporting(); PHP의 오류 보고 수준을 설정하고 현재 수준을 반환합니다.
error_reporting(report_level)
매개변수 수준이 지정되지 않은 경우 현재 오류 보고 수준 반환됩니다. 다음 항목은 가능한 레벨 값입니다.
값 |
상수 |
설명 |
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_WARNING과 유사한 치명적이지 않은 사용자 생성 경고입니다. 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 |
可选。规定错误消息的错误类型。 可能的值:
|
测试代码如下:
/** * * @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('my_error'); if (89 > 8) { //调用错误触发器 trigger_error('这是错误啊', E_USER_WARNING); } |
运行结果如下:
WARNING:
错误编号:512
错误信息:这是错误啊
相关推荐:
위 내용은 PHP 오류 처리 방법 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

phpsessionscanstorestrings, 숫자, 배열 및 객체 1.Strings : TextDatalikeUsernames.2.numbers : integorfloatsforcounters.3.arrays : listslikeshoppingcarts.4.objects : complexStructuresThatareserialized.

세션 재생은 세션 고정 공격의 경우 사용자가 민감한 작업을 수행 할 때 새 세션 ID를 생성하고 이전 ID를 무효화하는 것을 말합니다. 구현 단계에는 다음이 포함됩니다. 1. 민감한 작업 감지, 2. 새 세션 ID 생성, 3. 오래된 세션 ID 파괴, 4. 사용자 측 세션 정보 업데이트.

PHP 세션은 응용 프로그램 성능에 큰 영향을 미칩니다. 최적화 방법은 다음과 같습니다. 1. 데이터베이스를 사용하여 세션 데이터를 저장하여 응답 속도를 향상시킵니다. 2. 세션 데이터 사용을 줄이고 필요한 정보 만 저장하십시오. 3. 비 차단 세션 프로세서를 사용하여 동시성 기능을 향상시킵니다. 4. 사용자 경험과 서버 부담의 균형을 맞추기 위해 세션 만료 시간을 조정하십시오. 5. 영구 세션을 사용하여 데이터 읽기 및 쓰기 시간의 수를 줄입니다.

phpsessionsareser-side, whilecookiesareclient-side.1) sessions stessoredataontheserver, andhandlargerdata.2) cookiesstoredataonthecure, andlimitedinsize.usesessionsforsensitivestataondcookiesfornon-sensistive, client-sensation.

phpidifiesauser의 sssessionusessessioncookiesandssessionids.1) whensession_start () iscalled, phpgeneratesauniquessessionStoredInacookienamedPhpsSessIdonSeuser 'sbrowser.2) thisidallowsphptoretrievessessionDataTromServer.

PHP 세션의 보안은 다음 측정을 통해 달성 할 수 있습니다. 1. Session_REGENEREAT_ID ()를 사용하여 사용자가 로그인하거나 중요한 작업 일 때 세션 ID를 재생합니다. 2. HTTPS 프로토콜을 통해 전송 세션 ID를 암호화합니다. 3. 세션 _save_path ()를 사용하여 세션 데이터를 저장하고 권한을 올바르게 설정할 보안 디렉토리를 지정하십시오.

phpsessionfilesarestoredInTheRectorySpecifiedBysession.save_path, 일반적으로/tmponunix-likesystemsorc : \ windows \ temponwindows.tocustomizethis : 1) austession_save_path () toSetacustomDirectory, verlyTeCustory-swritation;


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

드림위버 CS6
시각적 웹 개발 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
