오늘 CI 프레임워크를 배우다가 문제가 발생했습니다.
A PHP 오류가 발생했습니다.
심각도: 공지
메시지: 정의되지 않은 변수: 사용자
일반적으로 기본 일반 PHP 파일에는 정의되지 않은 문이 출력됩니다. 변수는 오류를 보고하지 않지만 코드이그나이터 프레임워크에서는 오류를 보고합니다. 이는 페이지 추가 및 수정을 통합하려는 "게으른 사람들"에게는 초보자이기 때문에 여전히 이를 차단하고 싶어합니다. 이 오류 메시지는 어떻습니까? @까지 사용했는데 많은 분들이 @를 사용하면 성능이 크게 저하된다고 하더군요...
문득, 코드이그나이터가 의도적으로 이 오류 메시지를 표시하게 한 건 아닐까 하는 생각이 들었습니다. ? 이런 유형의 오류는 "codeigniter가 공지 정보를 표시하는 것을 방지하는 방법은 무엇입니까?"라고 검색했는데 갑자기 index.php 항목의 error_reporting(E_ALL)이 문제를 일으키는 것으로 나타났습니다.
error_reporting(E_ALL) ^ E_NOTICE);
이 오류는 다른 오류 보고서에 영향을 주지 않고 차단될 수 있습니다.
다음은 발견된 정보 중 일부입니다.
error_reporting()은 PHP의 오류 수준을 설정하고 현재 레벨을 반환합니다.
구문
error_reporting(report_level)
매개변수 수준이 지정되지 않은 경우 현재 오류 보고 수준이 반환됩니다. 다음 항목은 가능한 레벨 값입니다.
1 E_ERROR
2 E_WARNING
4 E_PARSE
8 E_NOTICE
16 E_CORE_ERROR
32 E_CORE_WARNING
64 E_COMPILE_ERROR
128 E_COMPILE_WARNING
256 E_USER_ERROR
512 E_USER_WARNING
1024 E_USER_NOTICE
2047 E_ALL
2048 E_STRICT
E_NOTICE는 프로그램에 오류가 있는 경우에만 사용되며, 알 수 없는 개체에 액세스하려고 하거나, 존재하지 않는 파일을 보려면 stat() 함수를 호출하는 등의 작업을 수행합니다.
E_WARNING은 일반적으로 표시되지만 프로그램 실행을 중단하지는 않습니다. 이는 디버깅에 유용합니다. 예: 문제가 있는 정규 표기법으로 ereg()를 호출합니다.
E_ERROR는 일반적으로 표시되며 프로그램 실행을 중단시킵니다. 즉, 이 마스크를 사용하면 메모리 구성이나 기타 오류를 추적할 수 없습니다.
E_PARSE 구문의 오류를 구문 분석합니다.
E_CORE_ERROR E_ERROR와 비슷하지만 PHP 코어로 인해 발생한 오류는 제외됩니다.
E_CORE_WARNING E_WARNING과 비슷하지만 PHP 핵심 오류 경고를 포함하지 않습니다.
PHP 오류 보고
php.ini 파일에는 많은 구성 설정이 있습니다. Linux에 PHP 및 Apache 2 설치에 대한 설명서에 표시된 대로 php.ini 파일을 이미 설정하여 적절한 디렉터리에 배치했어야 합니다. PHP 애플리케이션을 디버깅할 때 알아야 할 두 가지 구성 변수가 있습니다. 이 두 변수와 기본값은 다음과 같습니다.
display_errors = Off
error_reporting = E_ALL
이 두 변수의 현재 기본값은 php.ini 파일에서 검색하여 확인할 수 있습니다. display_errors 변수의 목적은 분명합니다. 이는 PHP에 오류를 표시할지 여부를 알려줍니다. 기본값은 끄기입니다. 하지만 개발 과정을 더 쉽게 하려면 이 값을 On으로 설정하세요:
display_errors = On
error_reporting 변수의 기본값은 E_ALL입니다. 이 설정은 잘못된 코딩 관행부터 무해한 팁, 오류까지 모든 것을 보여줍니다. E_ALL은 브라우저의 출력을 엉망으로 만드는 작은 일(예: 변수가 초기화되지 않음)에 대한 힌트도 화면에 표시하므로 개발 목적에 비해 너무 세분화되어 있습니다. 오류와 잘못된 코딩 관행만 보고 싶고 무해한 팁은 보고 싶지 않습니다. 따라서 error_reporting의 기본값을 다음 값으로 바꾸십시오.
error_reporting = E_ALL & ~E_NOTICE
Apache를 다시 시작하면 모든 설정이 완료됩니다. 다음으로 Apache에서 동일한 작업을 수행하는 방법을 알아봅니다.
서버 오류 보고
Apache가 수행하는 작업에 따라 컴퓨터에 여러 버전의 PHP가 있을 수 있으므로 PHP에서 오류 보고를 설정하지 못할 수도 있습니다. Apache는 하나의 php.ini 파일만 볼 수 있기 때문에 Apache가 어떤 PHP 버전을 사용하고 있는지 알기 어려울 때가 있습니다. Apache가 자체 구성을 위해 어떤 php.ini 파일을 사용하는지 모르는 것은 보안 문제입니다. 그러나 올바른 오류 수준이 설정되도록 Apache에서 PHP 변수를 구성하는 방법이 있습니다.
또한 서버 측에서 이러한 구성 변수를 설정하여 php.ini 파일을 재정의하거나 선점하여 더 높은 수준의 보안을 제공하는 방법을 아는 것이 좋습니다.
Apache를 구성할 때 /conf/httpd.conf의 http.conf 파일에 기본 구성이 이미 노출되어 있어야 합니다.
php.ini 파일에서 이미 수행한 작업을 수행하려면 httpd.conf에 다음 줄을 추가하여 모든 php.ini 파일을 덮어씁니다.
php_flag display_errors on
php_value error_reporting 2039
이는 다음과 같습니다. php.ini 파일에 이미 설정된 display_errors 플래그와 error_reporting 값을 덮어씁니다. 값 2039는 E_ALL & ~E_NOTICE를 나타냅니다. E_ALL을 사용하려면 값을 2047로 설정하세요. 이번에도 Apache를 다시 시작해야 합니다.
다음으로 서버에서 오류 보고를 테스트합니다.
error_reporting() 함수와 관련하여 일부 오류 메시지를 보호할 수 있지만 PHP 코어로 인해 발생한 오류는 보호할 수 없습니다. 왜냐하면 PHP 코어로 인해 발생한 오류는 직접적으로 PHP 파일 컴파일 실패를 초래하기 때문입니다. 따르지 않음 PHP 코딩 규칙 작성으로 인한 오류는 차단할 수 없습니다
코드 복사 코드는 다음과 같습니다.
* 지금은 E_STRICT 모드 경고를 피하세요
* (함수 정의 전에 수행해야 함)
*/
if (defined('E_STRICT')) {
$old_error_reporting = error_reporting(0);
if ($old_error_reporting & E_STRICT) {
error_reporting($old_error_reporting ^ E_STRICT);
} else {
error_reporting($old_error_reporting)
}
unset($old_error_reporting);
코드 복사 코드는 다음과 같습니다.
// 모든 오류 보고 끄기
error_reporting(0);
// 단순 실행 오류 보고
error_reporting(E_ERROR | E_WARNING | E_PARSE); / E_NOTICE를 보고하는 것도 좋을 수 있습니다(초기화되지 않은 변수를 보고하거나
// 변수 이름 철자 오류를 포착하기 위해…). 여기에는 초기화되지 않은 일부 변수를 보고하거나 변수 이름의 철자 오류를 포착하는 것이 포함됩니다.
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
// E_NOTICE를 제외한 모든 오류 보고
// 이는 php.ini에 설정된 기본값입니다. E_NOTICE를 제외한 모든 오류 보고 이는 php.ini의 기본 설정이기도 합니다.
error_reporting(E_ALL ^ E_NOTICE);
// 모든 PHP 오류 보고(PHP 3에서는 비트 단위 63 사용 가능); 모든 오류 보고
error_reporting(E_ALL);// error_reporting(E_ALL)과 동일; 🎜>ini_set( 'error_reporting', E_ALL)
위 내용은 Crystal Report의 내용을 포함하여 PHP Shielding 오류를 수정하기 위한 Crystal Report PHP의 error_reporting 함수 사용법을 소개한 내용입니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.