php - Quant à savoir si l'API utilise les codes d'état HTTP ou renvoie les 200
我想大声告诉你
我想大声告诉你 2017-05-16 13:03:19
0
6
908

L'API du projet actuel souhaite utiliser un style reposant, et l'interface API actuelle renvoie la spécification : toutes les interfaces réussies renvoient {status:200,msg:'',data:{}}, et les interfaces d'erreur renvoient {status:403, msg : '',data :{}}, c'est-à-dire qu'il n'y a que deux statuts : 200 et 403. J'ai senti que quelque chose n'allait pas, alors j'ai cherché en ligne

 200 OK - [GET] : Le serveur renvoie avec succès les données demandées par l'utilisateur L'opération est idempotente.
    201 CREATED - [POST/PUT/PATCH] : L'utilisateur a réussi à créer ou à modifier des données.
    202 Accepté - [*] : Indique qu'une requête est entrée dans la file d'attente en arrière-plan (tâche asynchrone)
    204 AUCUN CONTENU - [DELETE] : L'utilisateur a supprimé les données avec succès.
    400 INVALID REQUEST - [POST/PUT/PATCH] : Il y a une erreur dans la requête émise par l'utilisateur. Le serveur ne crée ni ne modifie les données. Cette opération est idempotente.
    401 Non autorisé - [*] : indique que l'utilisateur n'a pas d'autorisation (le jeton, le nom d'utilisateur et le mot de passe sont incorrects).
    403 Forbidden - [*] Indique que l'utilisateur est autorisé (contrairement à l'erreur 401), mais que l'accès est interdit.
    404 NOT FOUND - [*] : La requête émise par l'utilisateur concerne un enregistrement qui n'existe pas et le serveur n'a pas effectué l'opération. L'opération est idempotente.
    406 Not Acceptable - [GET] : Le format demandé par l'utilisateur n'est pas disponible (par exemple, l'utilisateur a demandé le format JSON, mais uniquement le format XML).
    410 Gone -[GET] : La ressource demandée par l'utilisateur a été définitivement supprimée et ne sera plus obtenue.
    422 Entité non traitable - [POST/PUT/PATCH] Une erreur de validation s'est produite lors de la création d'un objet.
    500 ERREUR DE SERVEUR INTERNE - [*] : Une erreur de serveur s'est produite et l'utilisateur ne pourra pas déterminer si la demande effectuée a réussi.

Dois-je suivre cette spécification pour renvoyer les codes d'état en fonction de différentes situations ? Par exemple, une demande d'obtention renvoie 200 avec succès et une demande de publication renvoie 201 avec succès ? Au lieu de simplement rendre 200 en cas de succès ? Au fait, ces codes d’état sont-ils vraiment écrits dans la valeur de retour ? Ne devrait-il pas être déterminé automatiquement dans le protocole http ? Ou le modifier dans l'en-tête renvoyé ? C'est très déroutant ici, j'espère que quelqu'un pourra clarifier les choses !

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

répondre à tous(6)
巴扎黑

Il existe deux méthodes
1.status_code vaut tous 200, le corps de la réponse est le suivant :
Succès成功

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

失败

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

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

[]// 或者{}

失败(4xx,5xx)

{
  errcode: 1,
  errmsg: '账号或密码错误',
}
É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
Ty80

{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-end

某草草

En 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.

过去多啦不再A梦

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 interface

習慣沉默

Code d'erreur commerciale 4xx
Succès 200 - 204
Erreur système 5xx

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal