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

现在的项目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)
巴扎黑

メソッドは2つあります
1.status_codeはすべて200、レスポンスボディは次のとおりです
成功

リーリー

失败

リーリー

2. 異なる status_code に従って処理し (推奨)、追加のパッケージ化を行わずにデータを直接返します
リーリー 成功(2xx)

、errcode と errmsg を返します

リーリー

いいねを押す +0
Ty80

{status:200,msg:'',data:{}} これは、API で記述された戻り結果である必要があります。たとえば、サーブレットはこれら 3 つのフィールドを含む json 文字列を返します。つまり、フロントエンドは、API が正常に返された場合にのみこの情報を読み取ることができます。リクエストが失敗して読み取れない場合は、フロントエンドから間違った URL をリクエストしてみてください

いいねを押す +0
某草草

実際、標準化されている場合は次のように返されるはずです
header('HTTP/1.0 401 Unauthorized');
header('HTTP/1.0 403 Forbidden');

しかし、実際の状況では、多くの人はそれほど標準化されません。
GET リクエストと POST リクエストさえ混在しているのに、標準についてどうやって語ればよいのでしょうか?

いいねを押す +0
刘奇

本来は規制に従って行われるべきですが、国内の通信事業者がジャンプを乗っ取る可能性があります。たとえば、404 を返すと、オペレーターが独自のナビゲーション Web サイトにリダイレクトする可能性がありますが、これは当惑することになります。

いいねを押す +0
过去多啦不再A梦

インターフェースから返されるデータと http レスポンスは 2 つの異なるものです

インターフェースによって返されるコードは事前に設定できます。

あなたがチェックしている情報はhttpレスポンスのステータスコードであり、インターフェースからの戻りとは何の関係もありません

いいねを押す +0
習慣沉默

ビジネス エラー コード 4xx
成功 200 - 204
システム エラー 5xx

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!