다음은 thinkphp6에서 디버깅 모드(APP_DEBUG=false) 오류 처리를 끄는 방법을 소개하는 thinkphp프레임워크 튜토리얼 칼럼입니다. 그것!
소개
안녕하세요 여러분, 2009년에 PHP를 접하고 2012년에 TP 프레임워크를 사용하기 시작했으며 16년 동안 완전한 코드를 작성하지 않은 의사 엔지니어로서 저는 정말 복잡한 감정을 느낍니다. 이 LOG.를 작성하면서 시간을 많이 낭비했고 PHP나 TP의 발전에 아무런 기여도 하지 못했다고 한탄합니다.
이 글의 핵심 목적은 문제 자체가 아닙니다(이 문제는 해결하기 어렵지 않기 때문입니다). 하지만 비슷한 문제를 다룬 개인적인 경험을 공유하고자 합니다. 제 능력이 부족하다면 수정이 필요한 분들에게 조금이나마 도움이 될 수 있기를 바랍니다.
문제 설명
// 디버깅 모드 활성화로 설정
- 디버그 모드의 이점은 다음과 같습니다. 로깅을 켜면 모든 오류 정보 및 디버깅
- 정보가 쉽게 디버깅할 수 있도록 자세히 기록됩니다. 전체 실행 프로세스를 자세히 기록합니다.
템플릿 수정 사항은 즉시 적용됩니다.- 추적 기능을 통해 더 나은 디버깅 및 오류 감지가 가능합니다.
- 예외가 발생하면 자세한 예외 정보가 표시됩니다.
- .ENV 파일 편집
// …
step1 문제를 재현하려면, 가장 간단한 대답은 테스트 환경 모드에서 디버깅을 끄는 것입니다.
솔루션 아이디어
APP_DEBUG = falseENV = testing.....
#编辑php.ini文件,开启log_errors = On error_log = /data/logs/php7/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)
既然已经找到错误信息了,那么问题就比较好处理了: option1 如果着急上线,可以先开启调试模式 option2 如果项目没用用注解可以关掉; option3 如果1和2都不行,那么久仔细研究下CachedReader.php,看看bug出在哪
APP_DEBUG = trueENV = live
<?phpreturn [ 'inject' => [ 'enable' => false, 'namespaces' => [], ], 'route' => [ 'enable' => false, 'controllers' => [], ], 'ignore' => [],];
# 第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; }
#解决当前问题的方式命令行更新如下,也可以用IDE更新哦$composer update topthink/think-annotation
호스트를 바인딩하여 컴퓨터에서 오류를 찾을 수 있습니다
위 내용은 thinkphp6 디버깅 모드 끄기(APP_DEBUG=false) 오류 보고 문제 처리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!