찾다
PHP 프레임워크ThinkPHPthinkphp6 디버깅 모드 끄기(APP_DEBUG=false) 오류 보고 문제 처리

다음은 thinkphp6에서 디버깅 모드(APP_DEBUG=false) 오류 처리를 끄는 방법을 소개하는 thinkphp프레임워크 튜토리얼 칼럼입니다. 그것!

소개


안녕하세요 여러분, 2009년에 PHP를 접하고 2012년에 TP 프레임워크를 사용하기 시작했으며 16년 동안 완전한 코드를 작성하지 않은 의사 엔지니어로서 저는 정말 복잡한 감정을 느낍니다. 이 LOG.를 작성하면서 시간을 많이 낭비했고 PHP나 TP의 발전에 아무런 기여도 하지 못했다고 한탄합니다.
이 글의 핵심 목적은 문제 자체가 아닙니다(이 문제는 해결하기 어렵지 않기 때문입니다). 하지만 비슷한 문제를 다룬 개인적인 경험을 공유하고자 합니다. 제 능력이 부족하다면 수정이 필요한 분들에게 조금이나마 도움이 될 수 있기를 바랍니다.

문제 설명


디버깅 문제 종료:

  • tp6이 .env 구성 모드를 추가하고 공식 환경에 문제가 나타납니다.
  • 개발 및 테스트 환경 APP_DEBUG = TRUE 모든 것이 정상입니다.
  • APP_DEBUG = FALSE로 설정합니다. 공식 릴리스 500 오류 보고

디버그 모드의 이점:

  • 디버그 모드의 이점은 다음과 같습니다. 로깅을 켜면 모든 오류 정보 및 디버깅
  • 정보가 쉽게 디버깅할 수 있도록 자세히 기록됩니다. 전체 실행 프로세스를 자세히 기록합니다.
  • 템플릿 수정 사항은 즉시 적용됩니다.
  • 추적 기능을 통해 더 나은 디버깅 및 오류 감지가 가능합니다.
  • 예외가 발생하면 자세한 예외 정보가 표시됩니다.
  • .ENV 파일 편집
// 디버깅 모드 활성화로 설정

APP_DEBUG = FASLE

// 기타 환경 변수 설정

// …


솔루션 아이디어

step1 문제를 재현하려면, 가장 간단한 대답은 테스트 환경 모드에서 디버깅을 끄는 것입니다.

APP_DEBUG = falseENV = testing.....

step2 로그를 켜고 디버깅을 끄면 오류가 인쇄되지 않으므로 PHP 파일 오류 기록을 켜야 합니다
    #编辑php.ini文件,开启log_errors = On
    error_log = /data/logs/php7/php_error.log
  • step3 문제를 확인하고 php_error.log를 확인하여 문제에 대한 구체적인 설명이 무엇인지 확인하세요
    #php error log 错误如下,路径需要换成您自己的,非必要信息略...PHP Fatal error:  Uncaught $YOUR_REAL_PATH\think\exception\ErrorException: Invalid argument supplied for foreach() in vendor/topthink/think-annotation/src/CachedReader.php:99
    Stack trace:#0 /$YOUR_REAL_PATH/vendor/topthink/think-annotation/src/CachedReader.php(99): think\initializer\Error->appError(2, 'Invalid argumen...', '...', 99, Array)
  • step4 문제를 해결하고 문제가 실제로 절반쯤 해결되었는지 확인하세요.
      既然已经找到错误信息了,那么问题就比较好处理了:
      
      option1 如果着急上线,可以先开启调试模式
      option2 如果项目没用用注解可以关掉;
      option3 如果1和2都不行,那么久仔细研究下CachedReader.php,看看bug出在哪
    • Solution
      • 옵션 1 긴급 해결 방법, 온라인 환경에서 디버깅 모드 켜기
      APP_DEBUG = trueENV = live
      옵션 2 단기 해결 방법, config/annotation.php에서 주석 기능 끄기

      <?phpreturn  [
          &#39;inject&#39; => [
              'enable'     => false,
              'namespaces' => [],
          ],
          'route'  => [
              'enable'      => false,
              'controllers' => [],
          ],
          'ignore' => [],];
      옵션 3 장기적 해결 방법, CachedReader.php 확인 코드 오류가 보고되는 이유는 무엇입니까?
      # 第8行引入错误
       use think\Cache;
       更改为========================>
       use think\cache\Driver;
       # 第143行 fetchFromCache 方法错误
        private function fetchFromCache($cacheKey, ReflectionClass $class)
         {
             if (($data = $this->cache->get($cacheKey)) !== false) {
                 if (!$this->debug || $this->isCacheFresh($cacheKey, $class)) {
                     return $data;
                 }
             }
             return false;
         }更改为========================>
         private function fetchFromCache($cacheKey, ReflectionClass $class)
         {
             if ((!$this->debug || $this->isCacheFresh($cacheKey, $class)) && $this->cache->has($cacheKey)) {
                 return $this->cache->get($cacheKey, false);
             }
             return false;
         }
      옵션 4 완메이 솔루션, 플러그인의 업데이트와 버그를 모두가 습관적으로 주의하길 바랍니다

      #解决当前问题的方式命令行更新如下,也可以用IDE更新哦$composer update topthink/think-annotation

      문제 요약

      1. ?

      코드 레벨에서 직접 ini_set(“display_errors”,1)

      2. 로드 밸런싱 머신이 여러 대 있는 경우 어떻게 해야 하나요?

      호스트를 바인딩하여 컴퓨터에서 오류를 찾을 수 있습니다




      위 내용은 thinkphp6 디버깅 모드 끄기(APP_DEBUG=false) 오류 보고 문제 처리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    • 성명
      이 기사는 csdn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제

      핫 AI 도구

      Undresser.AI Undress

      Undresser.AI Undress

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

      AI Clothes Remover

      AI Clothes Remover

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

      Undress AI Tool

      Undress AI Tool

      무료로 이미지를 벗다

      Clothoff.io

      Clothoff.io

      AI 옷 제거제

      Video Face Swap

      Video Face Swap

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

      뜨거운 도구

      mPDF

      mPDF

      mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

      SecList

      SecList

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

      VSCode Windows 64비트 다운로드

      VSCode Windows 64비트 다운로드

      Microsoft에서 출시한 강력한 무료 IDE 편집기

      SublimeText3 중국어 버전

      SublimeText3 중국어 버전

      중국어 버전, 사용하기 매우 쉽습니다.

      WebStorm Mac 버전

      WebStorm Mac 버전

      유용한 JavaScript 개발 도구