refactor(exception): 重构异常处理逻辑
- 移除自定义 MyBusinessException 类 - 统一使用 support\exception\BusinessException - 在 ExceptionHandler 中增加日志记录 - 更新相关文件中的异常处理逻辑
This commit is contained in:
parent
95334b874a
commit
c82b6ade42
@ -7,6 +7,7 @@ use Next\VarDumper\Dumper;
|
|||||||
use Next\VarDumper\DumperHandler;
|
use Next\VarDumper\DumperHandler;
|
||||||
use support\exception\BusinessException;
|
use support\exception\BusinessException;
|
||||||
use support\exception\Handler;
|
use support\exception\Handler;
|
||||||
|
use support\Log;
|
||||||
use Throwable;
|
use Throwable;
|
||||||
use Webman\Http\Request;
|
use Webman\Http\Request;
|
||||||
use Webman\Http\Response;
|
use Webman\Http\Response;
|
||||||
@ -22,6 +23,7 @@ class ExceptionHandler extends Handler
|
|||||||
return \response(self::convertToHtml($exception));
|
return \response(self::convertToHtml($exception));
|
||||||
}elseif ($exception instanceof BusinessException) {
|
}elseif ($exception instanceof BusinessException) {
|
||||||
if ($request->expectsJson()) {
|
if ($request->expectsJson()) {
|
||||||
|
Log::error('BusinessException:',['msg'=>$exception->getMessage(),'file'=>$exception->getFile(),'line'=>$exception->getLine()]);
|
||||||
return json(['code' => 0, 'msg' => $exception->getMessage(),'show'=>1]);
|
return json(['code' => 0, 'msg' => $exception->getMessage(),'show'=>1]);
|
||||||
}
|
}
|
||||||
return response($exception->getMessage());
|
return response($exception->getMessage());
|
||||||
@ -35,9 +37,12 @@ class ExceptionHandler extends Handler
|
|||||||
$error['file'] = $exception->getFile();
|
$error['file'] = $exception->getFile();
|
||||||
$error['line'] = $exception->getLine();
|
$error['line'] = $exception->getLine();
|
||||||
}
|
}
|
||||||
|
Log::error('Exception:',['msg'=>$exception->getMessage(),'file'=>$exception->getFile(),'line'=>$exception->getLine()]);
|
||||||
return response(json_encode($error, JSON_UNESCAPED_UNICODE));
|
return response(json_encode($error, JSON_UNESCAPED_UNICODE));
|
||||||
}
|
}
|
||||||
// 非json请求则返回一个页面
|
// 非json请求则返回一个页面
|
||||||
|
Log::error('other:',['msg'=>$exception->getMessage(),'file'=>$exception->getFile(),'line'=>$exception->getLine()]);
|
||||||
|
|
||||||
return new Response(200, [], 'msg:'.$exception->getMessage().'。line:'.$exception->getLine().'。file:'.$exception->getFile());
|
return new Response(200, [], 'msg:'.$exception->getMessage().'。line:'.$exception->getLine().'。file:'.$exception->getFile());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,20 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace app;
|
|
||||||
|
|
||||||
use support\exception\BusinessException;
|
|
||||||
use Webman\Http\Request;
|
|
||||||
use Webman\Http\Response;
|
|
||||||
|
|
||||||
class MyBusinessException extends BusinessException
|
|
||||||
{
|
|
||||||
public function render(Request $request): ?Response
|
|
||||||
{
|
|
||||||
// json请求返回json数据
|
|
||||||
if ($request->expectsJson()) {
|
|
||||||
return json(['code' => $this->getCode() ?: 500, 'msg' => $this->getMessage(),'show'=>1]);
|
|
||||||
}
|
|
||||||
// 非json请求则返回一个页面
|
|
||||||
return new Response(200, [], $this->getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
@ -9,7 +9,6 @@ use app\common\enum\AdminTerminalEnum;
|
|||||||
use app\common\model\auth\Admin;
|
use app\common\model\auth\Admin;
|
||||||
use app\common\service\ConfigService;
|
use app\common\service\ConfigService;
|
||||||
use app\common\validate\BaseValidate;
|
use app\common\validate\BaseValidate;
|
||||||
use app\MyBusinessException;
|
|
||||||
use support\exception\BusinessException;
|
use support\exception\BusinessException;
|
||||||
use Webman\Config;
|
use Webman\Config;
|
||||||
|
|
||||||
|
@ -9,8 +9,7 @@ use app\common\model\order\Cart;
|
|||||||
use app\common\model\store_branch_product\StoreBranchProduct;
|
use app\common\model\store_branch_product\StoreBranchProduct;
|
||||||
use app\common\model\system_store\SystemStore;
|
use app\common\model\system_store\SystemStore;
|
||||||
use app\common\lists\ListsSearchInterface;
|
use app\common\lists\ListsSearchInterface;
|
||||||
use app\MyBusinessException;
|
|
||||||
use think\Exception;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -20,8 +20,6 @@ use app\common\model\system_store\SystemStoreStaff;
|
|||||||
use app\store\service\AdminTokenService;
|
use app\store\service\AdminTokenService;
|
||||||
use app\common\model\auth\AdminRole;
|
use app\common\model\auth\AdminRole;
|
||||||
use app\common\service\FileService;
|
use app\common\service\FileService;
|
||||||
use app\MyBusinessException;
|
|
||||||
use think\facade\Db;
|
|
||||||
use Webman\Config;
|
use Webman\Config;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -9,7 +9,6 @@ use app\common\model\store_product\StoreProduct;
|
|||||||
use app\common\logic\BaseLogic;
|
use app\common\logic\BaseLogic;
|
||||||
use app\common\model\store_category\StoreCategory;
|
use app\common\model\store_category\StoreCategory;
|
||||||
use app\common\model\store_product_attr_value\StoreProductAttrValue;
|
use app\common\model\store_product_attr_value\StoreProductAttrValue;
|
||||||
use app\MyBusinessException;
|
|
||||||
use support\exception\BusinessException;
|
use support\exception\BusinessException;
|
||||||
use think\facade\Db;
|
use think\facade\Db;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user