Cree el método show en el public common.php, y el cliente llama a la interfaz del lado del servidor para devolver datos json
/*
* 通用化API接口数据输出
*/
function show($status, $message, $data = [], $httpCode = 200){
$data = [
'status' => $status,
'message' => $message,
'data' => $data,
];
return json($data, $httpCode);
}
Cree la clase ApiException en la aplicación / common / lib / exception /
<?php
namespace app\common\lib\exception;
use think\Exception;
class ApiException extends Exception
{
public $message = '';
public $httpCode = 500;
public $code = 0;
public function __construct($message = "", $httpCode = 0, $code = 0)
{
$this->httpCode = $httpCode;
$this->message = $message;
$this->code = $code;
}
}
Cree una clase ApiHandleException en app / common / lib / exception / para permitir que el servidor devuelva un error en formato json
<?php
namespace app\common\lib\exception;
use think\exception\Handle;
class ApiHandleException extends Handle
{
/*
* http状态码
*/
public $httpCode = 500;
public function render(\Exception $e)
{
if(config('app_debug') == true){
return parent::render($e);
}
if($e instanceof ApiException){
$this->httpCode = $e->httpCode;
}
return show(0, $e->getMessage(), [], $this->httpCode);
}
}
Modificar el archivo de configuración config.php
prueba:
Ingrese el siguiente código en el controlador:
public function save(){
$data = input('post.');
if($data['mt'] != 1){
throw new ApiException('您提交的数据不合法', 400);
}
return show(1, 'OK', input('post.'), 201);
}
Llamar a este método en cartero
Cuando app_debug es verdadero, el código entrará en vigor cuando se devuelva la siguiente figura
Cuando app_debug es falso, el código entrará en vigor cuando se devuelva la siguiente figura