配置文件修改
config/app.php
自定义异常接管类出处
'exception_handle' => ‘\app\common\exception\ExceptionHandle',
自定义处理异常方法
寡人的存放目录为 app/common/exception
ApiException.php
namespace app\common\exception;
use Exception;
class ApiException extends Exception
{
public function __construct(array $ApiErrConst, Throwable $previous = null)
{
$code = $ApiErrConst[0];
$message = $ApiErrConst[1];
parent::__construct($message, $code, $previous);
}
}
ExceptionHandle.php
namespace app\common\exception;
use Exception;
use think\exception\Handle;
use app\common\exception\ApiException;
use app\common\err\ApiErrCode;
class ExceptionHandle extends Handle
{
// 引入复用模块:JSON返回格式
use \app\common\traits\ResponseJson;
public function render(Exception $e)
{
if($e instanceof ApiException) {
$code = $e->getCode();
$message = $e->getMessage();
}else{
$code = $e->getCode();
if(!$code || $code < 0) {
$code = ApiErrCode::ERROR_UNKNOW[0];
}
$message = $e->getMessage() ? $e->getMessage() : ApiErrCode::ERROR_UNKNOW[1];
}
echo $this->jsonErrorData($code,$message); //该方法在下方
// 其他错误交给系统处理
// return parent::render($e);
}
}
错误码文件
存放目录:app/common/err
namespace app\common\err;
class ApiErrCode
{
const ERROR_UNKNOW = [0, "未知错误"];
const ERROR_URL = [1, "接口不存在"];
.......
}
复用模块
针对API接口返回格式
存放目录:app/common/traits
namespace app\common\traits;
trait ResponseJson
{
public function jsonErrorData($code,$message,$data = [])
{
return $this->jsonResponse($code, $message, $data);
}
public function jsonSuccessData($data = [])
{
return $this->jsonResponse(200, "Sucess", $data);
}
private function jsonResponse($code,$message,$data)
{
$content = [
'code' => $code,
'msg' => $message,
'data' => $data
];
return json_encode($content);
}
}
页面调用
// 文件头部引入
use app\common\exception\ApiException;
use app\common\err\ApiErrCode;
// 引入复用模块:JSON返回格式
use \app\common\traits\ResponseJson;
// 示例
public function index() {
throw new ApiException(ApiErrCode::ERROR_URL); // 自定义异常抛出
}
到此这篇关于thinkphp5.1 中使用自定义异常处理类进行接管的文章就介绍到这了,更多相关thinkphp5.1 自定义异常处理类内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!