이 글에서는 PHP 오류 처리를 구현하는 방법을 설명합니다.
PHP에서 오류, 경고 및 예외 처리를 구현하는 방법, 해당 오류를 처리하는 데 사용되는 함수
php 예외 프롬프트는 오류/경고/알림의 세 가지 범주로 나뉩니다.
오류 보충:
치명적인 오류: 치명적인 오류 (스크립트 종료 실행)
E_ERROR // 치명적인 실행 오류, 오류를 복구할 수 없으며 스크립트 실행이 일시 중지됩니다.
E_CORE_ERROR // PHP 시작 시 초기화 과정 중 치명적인 오류
E_COMPILE_ERROR // 치명적인 오류 Zend 스크립트 엔진과 마찬가지로 컴파일하는 동안 E_ERROR
E_USER_ERROR // 사용자 정의 오류 메시지가 생성되었습니다. PHP 함수를 사용하는 것과 같습니다. 잠재적으로 위험한 오류가 발생했지만 PHP 엔진이 불안정해지지는 않았음을 나타냅니다.
Parse 오류: 컴파일 시간 구문 분석 오류, 구문 오류(스크립트 실행이 종료됨)
E_PARSE //컴파일 시간 구문 분석 오류
경고 보충: 경고 오류(프롬프트 정보만 제공되며 스크립트 실행이 종료되지 않음)
E_WARNING // 런타임 경고(치명적이지 않은 오류).
E_CORE_WARNING // PHP 초기화 시작 중에 발생한 경고(치명적이지 않은 오류)입니다.
E_COMPILE_WARNING // 컴파일 경고
E_USER_WARNING // 사용자가 생성한 경고 정보
예외 알림 보충: 알림 오류(알림 정보만 제공되며 스크립트는 작업을 종료하지 않음)
E_NOTICE // 런타임 알림. 스크립트에서 오류로 나타날 수 있는 상황이 발생했음을 나타냅니다.
E_USER_NOTICE // 사용자가 생성한 알림 정보입니다.
php 오류 처리 구현:
register_shutdown_function('funcName') // 매개변수는 오류를 캡처해야 하는 함수의 이름이지만, Register_shutdown_function은 런타임 중에 치명적인 오류만 캡처할 수 있지만 해석 중에는 실행 오류를 캡처할 수 없습니다. 프로그램입니다. 실행이 완료된 후 실행할 함수입니다. (구문 오류, 런타임 중에 발생한 오류 등은 캡처되지 않습니다.)
set_error_handler('funcName') //파라미터는 필요한 콜백의 함수 이름입니다. 이는 Register_shutdown_function 과 달리 함수 실행 중에 오류를 캡처합니다
대상 파일에 오류가 발생하면 시스템은 지정된 함수를 콜백합니다.
예:
register_shutdown_function( "fatal_handler" ); set_error_handler("error_handler"); define('E_FATAL', E_ERROR | E_USER_ERROR | E_CORE_ERROR | E_COMPILE_ERROR | E_RECOVERABLE_ERROR| E_PARSE ); //获取fatal error function fatal_handler() { $error = error_get_last(); if($error && ($error["type"]===($error["type"] & E_FATAL))) { $errno = $error["type"]; // $errfile = $error["file"]; $errline = $error["line"]; $errstr = $error["message"]; error_handler($errno,$errstr,$errfile,$errline); } }
//모든 오류 가져오기
function error_handler($errno,$errstr,$errfile,$errline){ $str=<< "errno":$errno "errstr":$errstr "errfile":$errfile "errline":$errline EOF; //获取到错误可以自己处理,比如记Log、报警等等 echo $str; } //error_get_last() 捕获到的执行错误结果 //error_clear_last() 清除最后一次产生的错误信息
//위 두 가지 방법으로 모든 오류, 경고, 예외를 캡처할 수 있지만 성능상의 이유로 경고 예외 캡처에는 사용하지 않는 것이 좋습니다.
이 글에서는 오류 처리 방법에 대해 더 자세히 알아보시기 바랍니다. PHP 중국어 웹사이트.
관련 권장 사항:
PHP는 배열의 어느 열에서 다차원 배열의 지정된 값을 어떻게 얻나요? php 기본 학습: PHP 배열 및 데이터 구조php 기본 학습: PHP 파일 시스템위 내용은 PHP 오류 처리 및 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

로드 밸런싱은 세션 관리에 영향을 미치지 만 세션 복제, 세션 끈적임 및 중앙 집중식 세션 스토리지로 해결할 수 있습니다. 1. 세션 복제 복사 서버 간의 세션 데이터. 2. 세션 끈은 사용자 요청을 동일한 서버로 안내합니다. 3. 중앙 집중식 세션 스토리지는 Redis와 같은 독립 서버를 사용하여 세션 데이터를 저장하여 데이터 공유를 보장합니다.

SessionLockingIsateChniqueSureDureauser의 SessionLockingSsessionRemainSexclusivetoOneuseratatime.itiscrucialforpreptingdatacorruptionandsecurityBreachesInmulti-userApplications.sessionLockingSogingSompletEdusingserVerver-sidelockingMegynisms, unrasprantlockinj

PHP 세션의 대안에는 쿠키, 토큰 기반 인증, 데이터베이스 기반 세션 및 Redis/Memcached가 포함됩니다. 1. Cookies는 클라이언트에 데이터를 저장하여 세션을 관리합니다. 이는 단순하지만 보안이 적습니다. 2. Token 기반 인증은 토큰을 사용하여 사용자를 확인합니다. 이는 매우 안전하지만 추가 논리가 필요합니다. 3. Database 기반 세션은 데이터베이스에 데이터를 저장하여 확장 성이 좋지만 성능에 영향을 줄 수 있습니다. 4. Redis/Memcached는 분산 캐시를 사용하여 성능 및 확장 성을 향상하지만 추가 일치가 필요합니다.

SessionHijacking은 사용자의 SessionID를 얻음으로써 사용자를 가장하는 공격자를 말합니다. 예방 방법은 다음과 같습니다. 1) HTTPS를 사용한 의사 소통 암호화; 2) SessionID의 출처를 확인; 3) 보안 세션 생성 알고리즘 사용; 4) 정기적으로 SessionID를 업데이트합니다.

이 기사는 PHP에 대해 설명하고, 전체 형식, 웹 개발의 주요 용도, Python 및 Java와의 비교 및 초보자를위한 학습 용이성을 자세히 설명합니다.

PHP는 유효성 검사, 소독 및 보안 데이터베이스 상호 작용을 통해 보안을 보장하면서 $ \ _ post 및 $ \ _를 사용하여 데이터 양식 데이터를 처리합니다.

이 기사는 PHP와 ASP.NET을 비교하여 대규모 웹 응용 프로그램, 성능 차이 및 보안 기능에 대한 적합성에 중점을 둡니다. 둘 다 대규모 프로젝트에서는 실용적이지만 PHP는 오픈 소스 및 플랫폼 독립적이며 ASP.NET,

PHP의 사례 감도는 다양합니다. 함수는 무감각하고 변수와 클래스는 민감합니다. 모범 사례에는 일관된 이름 지정 및 비교를위한 사례 감수 기능 사용이 포함됩니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

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

Dreamweaver Mac版
시각적 웹 개발 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

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