logger = $logger; } public function handle(Throwable $throwable, ResponseInterface $response) { $this->logger->error(sprintf('%s[%s] in %s', $throwable->getMessage(), $throwable->getLine(), $throwable->getFile())); $this->logger->error($throwable->getTraceAsString()); $isDev = config('app_env') == 'dev'; $data = json_encode([ 'code' => ResponseCode::SERVER_ERROR, 'error' => $isDev ? $throwable->getMessage() : 'Internal Server Error.', 'traces' => $isDev ? $throwable->getTrace() : [], ], JSON_UNESCAPED_UNICODE); !$isDev && $this->sendAdminEmail($throwable); return $response->withHeader('Server', 'Lumen IM')->withStatus(500)->withBody(new SwooleStream($data)); } /** * @param Throwable $throwable * @return bool */ public function isValid(Throwable $throwable): bool { return true; } /** * 发送系统报错通知邮件 * * @param Throwable $throwable */ public function sendAdminEmail(Throwable $throwable) { $error = implode(':', [ 'error', md5($throwable->getFile() . $throwable->getCode() . $throwable->getLine()), ]); $adminEmail = config('admin_email'); if ($adminEmail && LockRedis::getInstance()->lock($error, 60 * 30)) { try { email()->send( $adminEmail, '系统报错通知', di()->get(MailerTemplate::class)->errorNotice($throwable) ); } catch (\Exception $exception) { } } } }