105 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			105 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?php
							 | 
						|||
| 
								 | 
							
								// +----------------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
							 | 
						|||
| 
								 | 
							
								// +----------------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								// | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
							 | 
						|||
| 
								 | 
							
								// +----------------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
							 | 
						|||
| 
								 | 
							
								// +----------------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								// | Author: CRMEB Team <admin@crmeb.com>
							 | 
						|||
| 
								 | 
							
								// +----------------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								namespace app\adminapi;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								use crmeb\exceptions\AdminException;
							 | 
						|||
| 
								 | 
							
								use crmeb\exceptions\ApiException;
							 | 
						|||
| 
								 | 
							
								use crmeb\exceptions\AuthException;
							 | 
						|||
| 
								 | 
							
								use think\db\exception\DbException;
							 | 
						|||
| 
								 | 
							
								use think\exception\Handle;
							 | 
						|||
| 
								 | 
							
								use think\exception\HttpResponseException;
							 | 
						|||
| 
								 | 
							
								use think\exception\ValidateException;
							 | 
						|||
| 
								 | 
							
								use think\facade\Env;
							 | 
						|||
| 
								 | 
							
								use think\facade\Log;
							 | 
						|||
| 
								 | 
							
								use think\Response;
							 | 
						|||
| 
								 | 
							
								use Throwable;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								class AdminApiExceptionHandle extends Handle
							 | 
						|||
| 
								 | 
							
								{
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 不需要记录信息(日志)的异常类列表
							 | 
						|||
| 
								 | 
							
								     * @var array
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    protected $ignoreReport = [
							 | 
						|||
| 
								 | 
							
								        ValidateException::class,
							 | 
						|||
| 
								 | 
							
								        AuthException::class,
							 | 
						|||
| 
								 | 
							
								        AdminException::class,
							 | 
						|||
| 
								 | 
							
								        ApiException::class,
							 | 
						|||
| 
								 | 
							
								    ];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 记录异常信息(包括日志或者其它方式记录)
							 | 
						|||
| 
								 | 
							
								     * @access public
							 | 
						|||
| 
								 | 
							
								     * @param Throwable $exception
							 | 
						|||
| 
								 | 
							
								     * @return void
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function report(Throwable $exception): void
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        if (!$this->isIgnoreReport($exception)) {
							 | 
						|||
| 
								 | 
							
								            try {
							 | 
						|||
| 
								 | 
							
								                $data = [
							 | 
						|||
| 
								 | 
							
								                    'file' => $exception->getFile(),
							 | 
						|||
| 
								 | 
							
								                    'line' => $exception->getLine(),
							 | 
						|||
| 
								 | 
							
								                    'message' => $this->getMessage($exception),
							 | 
						|||
| 
								 | 
							
								                    'code' => $this->getCode($exception),
							 | 
						|||
| 
								 | 
							
								                ];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                //日志内容
							 | 
						|||
| 
								 | 
							
								                $log = [
							 | 
						|||
| 
								 | 
							
								                    request()->adminId(),                                                                 //管理员ID
							 | 
						|||
| 
								 | 
							
								                    request()->ip(),                                                                      //客户ip
							 | 
						|||
| 
								 | 
							
								                    ceil(msectime() - (request()->time(true) * 1000)),                               //耗时(毫秒)
							 | 
						|||
| 
								 | 
							
								                    request()->rule()->getMethod(),                                                       //请求类型
							 | 
						|||
| 
								 | 
							
								                    str_replace("/", "", request()->rootUrl()),                             //应用
							 | 
						|||
| 
								 | 
							
								                    request()->baseUrl(),                                                                 //路由
							 | 
						|||
| 
								 | 
							
								                    json_encode(request()->param(), JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES),//请求参数
							 | 
						|||
| 
								 | 
							
								                    json_encode($data, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES),             //报错数据
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                ];
							 | 
						|||
| 
								 | 
							
								                Log::write(implode("|", $log), "error");
							 | 
						|||
| 
								 | 
							
								            } catch (\Throwable $e) {
							 | 
						|||
| 
								 | 
							
								                Log::write($e->getMessage(), "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
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        if ($e instanceof HttpResponseException) {
							 | 
						|||
| 
								 | 
							
								            return parent::render($request, $e);
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        $massageData = Env::get('app_debug', false) ? [
							 | 
						|||
| 
								 | 
							
								            'message' => $e->getMessage(),
							 | 
						|||
| 
								 | 
							
								            'file' => $e->getFile(),
							 | 
						|||
| 
								 | 
							
								            'line' => $e->getLine(),
							 | 
						|||
| 
								 | 
							
								            'trace' => $e->getTrace(),
							 | 
						|||
| 
								 | 
							
								            'previous' => $e->getPrevious(),
							 | 
						|||
| 
								 | 
							
								        ] : [];
							 | 
						|||
| 
								 | 
							
								        $message = $e->getMessage();
							 | 
						|||
| 
								 | 
							
								        // 添加自定义异常处理机制
							 | 
						|||
| 
								 | 
							
								        if ($e instanceof AuthException || $e instanceof AdminException || $e instanceof ApiException || $e instanceof ValidateException) {
							 | 
						|||
| 
								 | 
							
								            return app('json')->make($e->getCode() ?: 400, $message, $massageData);
							 | 
						|||
| 
								 | 
							
								        } else {
							 | 
						|||
| 
								 | 
							
								            return app('json')->fail($message, $massageData);
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								}
							 |