refactor(exception): 重构异常处理逻辑

- 移除自定义 MyBusinessException 类
- 统一使用 support\exception\BusinessException
- 在 ExceptionHandler 中增加日志记录
- 更新相关文件中的异常处理逻辑
This commit is contained in:
mkm 2025-01-04 12:09:11 +08:00
parent 95334b874a
commit c82b6ade42
6 changed files with 6 additions and 26 deletions

View File

@ -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());
} }
} }

View File

@ -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());
}
}

View File

@ -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;

View File

@ -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;
/** /**

View File

@ -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;
/** /**

View File

@ -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;