gpt4 book ai didi

Laravel API 响应对象格式化

转载 作者:行者123 更新时间:2023-12-04 13:16:09 28 4
gpt4 key购买 nike

我已经创建了一个基本的 Laravel REST API,它将为一些使用 axios 发出请求的 JavaScript 应用程序提供服务。

我的应用程序使用基本 Controller 来确保所有响应都以相同的格式发送:

class BaseController extends Controller
{
/**
* success response method.
*
* @param $result
* @param $message
*
* @return JsonResponse
*/
public function sendResponse($result, $message)
{
$response = [
'success' => true,
'data' => $result,
'message' => $message,
];

return response()->json($response, 200);
}

/**
* return error response.
*
* @param $error
* @param array $errorMessages
* @param int $code
*
* @return JsonResponse
*/
public function sendError($error, $errorMessages = [], $code = 200)
{
$response = [
'success' => false,
'message' => $error,
];

if (!empty($errorMessages)) {
$response['data'] = $errorMessages;
}

return response()->json($response, $code);
}
}

当我从 API URL 检索响应并将其记录到控制台时,我得到以下输出:

enter image description here

目前,我的响应对象包含它自己的数据对象,然后又包含另一个数据对象。因此,要访问数据,我必须使用 response.data.data。

我想知道这是否真的是正确的方法。由于 response.data.data 的命名约定似乎不是一种非常干净的方法。我已经在网上看到了一些指南,它们是通过这种方式完成的,但我想知道是否有任何我遗漏的通常遵循的约定。也许这是正确的,但我只是想从更有经验的程序员那里得到一些见解。

最佳答案

在我看来,您的处理方式很好:

  • response 是通过 axios 的完整响应对象
  • response.data 是返回的完整响应主体
  • response.data.data是返回的响应体的data节点

一些建议:

  • 不是在您的响应中使用 success,而是可以从返回的状态代码中暗示:200-299 内的任何内容都是成功的,300-399 中的任何内容都是重定向,400-499 中的任何内容都是重定向客户端错误,任何超过 500 的都是服务器错误(请参阅 here)
  • 在我看来,应该为成功数据保留节点,而不是在错误实例中使用 data,而应该使用 errors 之类的节点
  • 您的sendError 方法应该默认状态代码为500 而不是200,因为200 是一个成功状态码

关于Laravel API 响应对象格式化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60311372/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com