现在的项目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里修改?这里很迷糊,希望大神解惑!
Il existe deux méthodes
1.status_code vaut tous 200, le corps de la réponse est le suivant :
Succès
成功
失败
2.根据不同的status_code处理(推荐)
成功(2xx)
,直接返回数据,不用额外包装失败(4xx,5xx)
Échec
rrreee 2. Traiter selon différents status_code (recommandé)Succès (2xx)
, renvoyer les données directement sans emballage supplémentaire rrreeeÉchec (4xx, 5xx)
, renvoie errcode et errmsg rrreee{status:200,msg:'',data:{}}
Cela devrait être le résultat de retour écrit par vous dans l'API. Par exemple, la servlet renvoie une chaîne json contenant ces 3 champs. En d’autres termes, le frontal ne peut lire ces informations que lorsque votre API est renvoyée avec succès. Si la requête échoue et ne peut pas être lue, vous pouvez essayer de demander une mauvaise URL depuis le front-endEn fait, s'il est standardisé, il doit être renvoyé comme ceci
header('HTTP/1.0 401 Unauthorized');
header('HTTP/1.0 403 Forbidden');
Cependant, dans les situations réelles, de nombreuses personnes ne seront pas aussi standardisées.
Même les requêtes GET et les requêtes POST sont mélangées, alors comment pouvons-nous parler de standards ?
À l'origine, cela devrait être fait conformément à la réglementation, mais les opérateurs de télécommunications nationaux pourraient détourner le saut. Par exemple, si vous renvoyez 404, l’opérateur risque de vous rediriger vers son propre site de navigation, ce qui serait embarrassant.
Les données renvoyées par votre interface et la réponse http sont deux choses différentes
Le code renvoyé par l'interface est prédéterminé. Vous pouvez le définir comme vous le souhaitez.
L'information que vous vérifiez est le code d'état de la réponse http et n'a rien à voir avec le retour de votre interfaceCode d'erreur commerciale 4xx
Succès 200 - 204
Erreur système 5xx