| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 | <?phpnamespace app;use app\dict\sys\AppTypeDict;use core\exception\AdminException;use core\exception\AuthException;use core\exception\ServerException;use think\db\exception\DataNotFoundException;use think\db\exception\DbException;use think\db\exception\ModelNotFoundException;use think\exception\Handle;use think\exception\HttpException;use think\exception\HttpResponseException;use think\exception\ValidateException;use think\facade\Log;use think\Response;use Throwable;use UnexpectedValueException;/** * 应用异常处理类 */class ExceptionHandle extends Handle{    /**     * 不需要记录信息(日志)的异常类列表     * @var array     */    protected $ignoreReport = [        HttpException::class,        HttpResponseException::class,        ModelNotFoundException::class,        DataNotFoundException::class,        ValidateException::class,    ];    /**     * 记录异常信息(包括日志或者其它方式记录)     *     * @access public     * @param  Throwable $e     * @return void     */    public function report(Throwable $e): void    {        // 使用内置的方式记录异常日志//        parent::report($exception);        if (!$this->isIgnoreReport($e)) {            $data = [                'file' => $e->getFile(),                'line' => $e->getLine(),                'message' => $e->getMessage(),                'trace' => $e->getTrace(),                'previous' => $e->getPrevious(),            ];            //这个类可能会分开拆成两个            $app_type = request()->appType() ;            $app_type = empty($app_type) ? str_replace('/', '', request()->rootUrl()) : $app_type;            //写入日志内容            $log = [                '服务主体:'.($app_type == AppTypeDict::ADMIN ? request()->uid() : request()->memberId()),//服务发起者                                                                     //用户ID                'IP:'.request()->ip(),//ip                '耗时(毫秒):'.ceil((microtime(true) * 1000) - (request()->time(true) * 1000)),//耗时(毫秒)                '请求类型:'.request()->method(),//请求类型                '应用:'.$app_type,//应用                '路由:'.request()->baseUrl(),//路由                '请求参数:'.json_encode(request()->param() ?? []),//请求参数                '错误信息:'.json_encode($data),//错误信息            ];            Log::write('DEBUG:>>>>>>>>>'.PHP_EOL.implode(PHP_EOL, $log).PHP_EOL.'---------', 'error');        }    }    /**     * Render an exception into an HTTP response.     * @access public     * @param \think\Request   $request     * @param Throwable $e     * @return Response     */    public function render($request, Throwable $e): Response    {        // 添加自定义异常处理机制        $massageData = env('app_debug', false) ? [            'file' => $e->getFile(),            'line' => $e->getLine(),            'message' => $e->getMessage(),            'trace' => $e->getTrace(),            'previous' => $e->getPrevious(),        ] : [];        // 添加自定义异常处理机制        if (strpos($e->getMessage(), 'open_basedir') !== false) {            return fail('OPEN_BASEDIR_ERROR');        }        if ($e instanceof DbException) {            return fail(get_lang('DATA_GET_FAIL').':'.$e->getMessage(), [                'file' => $e->getFile(),                'line' => $e->getLine(),                'message' => $e->getMessage(),                'trace' => $e->getTrace(),                'previous' => $e->getPrevious(),            ]);        } elseif ($e instanceof ValidateException) {            return fail($e->getMessage());        } else if($e instanceof UnexpectedValueException){            return fail($e->getMessage(), [], 401);        }else if($e instanceof AuthException){            return fail($e->getMessage(), [], $e->getCode() ?: 400);        }else if($e instanceof ServerException){            return fail($e->getMessage(), http_code:$e->getCode());        }else {            return fail($e->getMessage(), $massageData);        }    }}
 |