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

thinkphp6 디버깅 모드 끄기(APP_DEBUG=false) 오류 보고 문제 처리

藏色散人
藏色散人앞으로
2020-12-25 16:09:525022검색

다음은 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에서 주석 기능 끄기

      e3fa5384b17edd13525c70273ec9212e [
              '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.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제