PHP 코드를 개발하다보면 PHP 코드상의 에러 메세지나 웹 서버의 에러 로그를 확인하면서 다음과 같은 내용이 기록되어 있는 경우가 있습니다.
2018/10/27 23:02:37 [error] 503#0: *2708 FastCGI sent in stderr: "PHP message: PHP Notice: Undefined index: HTTP_REFERER in /home/nginx/public_html/index.html on line 58" while reading response header from upstream, client: 192.168.xxx.xxx, server: mydomain.com, request: "GET /index.html HTTP/2.0", upstream: "fastcgi://unix:/var/run/php-fpm.sock:", host: "mydomain.com"
정의되지 않은 인덱스라고 해석할 수 있는 이 에러는 해당 페이지에서 확인해보려 해도 특별한 문제가 없는 경우가 많습니다.
어떤 이유로 위 에러 메세지가 표시되는 것일까요?
이는 현재 로드된 웹페이지에서 PHP의 특정 환경변수의 값이 존재하지 않아 발생하는 문제입니다.
다음 에러 내용에서 확인할 수 있듯이 HTTP_REFERER
변수에서 문제가 발생한 것으로 의심됩니다.
Undefined index: HTTP_REFERER
이제 해당 코드를 수정해보도록 하겠습니다.
PHP 코드 내에서 $_SERVER['HTTP_REFERER']
를 사용한 부분을 찾습니다. 아래 예시에서는 echo
를 사용하여 환경변수를 사용했습니다.
echo "HTTP REFERER : " . $_SERVER['HTTP_REFERER'];
이제 이 부분에 변수 값이 존재하는지 확인하는 코드를 추가해줍니다. isset()
함수를 사용하면 해당 변수의 값이 존재하는지 확인하여 만약 존재하지 않을 경우 false
를 반환하게 됩니다.
if (isset($_SERVER['HTTP_REFERER'])) { ... echo "HTTP REFERER : " . $_SERVER['HTTP_REFERER']; ... }
이렇게 코드를 수정하면 더 이상 에러 로그에 메세지가 나타나지 않을 것입니다.
사실 이러한 에러는 중요성이 낮은 알림 메세지에 가깝습니다.
만약 PHP의 에러 메세지를 완전히 끄고 싶다면 다음 포스트를 참고해보세요.
Xcode에서 iOS 애플리케이션을 빌드(Archive)하고 App Store Connect에 앱을 업로드하는 도중, 아래와 같은 에러가 발생하면서 더…
INSTALL_FAILED_INSUFFICIENT_STORAGE 문제 안드로이드 스튜디오에서 에뮬레이터를 실행하고 개발중인 애플리케이션을 실행하려 하면 로그 창에 아래와 같이 표시되면서…
리눅스 명령어 - kill, killall 리눅스 kill 명령어는 특정 프로세스를 종료해주는 명령어입니다. 백그라운드에서 실행되고 있는…
JavaScript는 역사가 긴 스크립트 프로그래밍 언어입니다. 세월이 흐르면서 많은 자바스크립트 표준이 만들어졌고, 현재는 많은 문법적…
NodeJS 테스트 프레임워크인 Mocha는 비동기 테스트를 지원합니다. 간혹 특정 테스트 스크립트를 작성하고 실행하면 아래와 같이…
View Comments
감사합니다
도움되셨다니 기쁘네요!