php - 关于API 使用 HTTP 状态码还是全部返回 200
我想大声告诉你
我想大声告诉你 2017-05-16 13:03:19
0
6
841

现在的项目api想用restful风格,然后目前的api接口返回规范:所有成功接口返回{status:200,msg:'',data:{}},出错接口返回{status:403,msg:'',data:{}},也就是只有200和403两种状态,我感觉不太对劲,搜了下网上的

    200 OK - [GET]:服务器成功返回用户请求的数据,该操作是幂等的(Idempotent)。
    201 CREATED - [POST/PUT/PATCH]:用户新建或修改数据成功。
    202 Accepted - [*]:表示一个请求已经进入后台排队(异步任务)
    204 NO CONTENT - [DELETE]:用户删除数据成功。
    400 INVALID REQUEST - [POST/PUT/PATCH]:用户发出的请求有错误,服务器没有进行新建或修改数据的操作,该操作是幂等的。
    401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。
    403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。
    404 NOT FOUND - [*]:用户发出的请求针对的是不存在的记录,服务器没有进行操作,该操作是幂等的。
    406 Not Acceptable - [GET]:用户请求的格式不可得(比如用户请求JSON格式,但是只有XML格式)。
    410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。
    422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。
    500 INTERNAL SERVER ERROR - [*]:服务器发生错误,用户将无法判断发出的请求是否成功。

我是否是要按照这样的规范根据不同的情况去返回状态码?比如get请求成功返回200,post请求成功返回201?而不是只要成功就返回200?话说这些状态码真的是写在返回值里吗?不是应该http协议里自动判定的吗?或者在返回的header里修改?这里很迷糊,希望大神解惑!

我想大声告诉你
我想大声告诉你

모든 응답(6)
巴扎黑

두 가지 방법이 있습니다
1.status_code는 모두 200이고 응답 본문은 다음과 같습니다.
Success成功

{
  errcode: 0,
  errmsg: null,
  data: obj // 数据主体
}

失败

{
  errcode: 1, // 具体错误代码
  errmsg: '账号错误',
}

2.根据不同的status_code处理(推荐)
成功(2xx),直接返回数据,不用额外包装

[]// 或者{}

失败(4xx,5xx) 으아아아

실패🎜 으아아아 🎜2. 다양한 상태 코드에 따라 처리(권장) 🎜성공(2xx), 추가 패키징 없이 직접 데이터 반환🎜 으아아아 🎜실패(4xx, 5xx), errcode 및 errmsg🎜를 반환합니다. 으아아아
Ty80

{status:200,msg:'',data:{}} 이는 API에서 사용자가 작성한 반환 결과여야 합니다. 예를 들어 서블릿은 이러한 3개 필드가 포함된 json 문자열을 반환합니다. 즉, 프런트 엔드는 API가 성공적으로 반환될 때만 이 정보를 읽을 수 있습니다. 요청이 실패하고 읽을 수 없는 경우 프런트 엔드에서 잘못된 URL을 요청해 볼 수 있습니다

某草草

실제로 표준화된 경우에는 이렇게 반환되어야 합니다
header('HTTP/1.0 401 Unauthorized');
header('HTTP/1.0 403 Forbidden');

그러나 실제 상황에서는 많은 사람들이 그렇게 표준화되지 않을 것입니다.
GET요청과 POST요청까지 섞여 있는데 어떻게 기준을 이야기할 수 있을까요?

刘奇

원래는 규정대로 해야 하는데, 국내 통신사업자가 점프를 탈취할 수도 있습니다. 예를 들어, 404를 반환하는 경우 운영자는 귀하를 자신의 탐색 웹사이트로 리디렉션할 수 있으며 이는 당혹스러울 것입니다.

过去多啦不再A梦

인터페이스에서 반환된 데이터와 http 응답은 서로 다른 두 가지입니다

인터페이스에서 반환되는 코드는 미리 결정되어 있습니다. 원하는 대로 설정할 수 있습니다.

확인하고 있는 정보는 http 응답의 상태 코드이며 인터페이스의 반환과는 아무런 관련이 없습니다

習慣沉默

비즈니스 오류 코드 4xx
성공 200 - 204
시스템 오류 5xx

최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!