Maison >Java >javaDidacticiel >Résultat INPUT de Struts 2 : comment les erreurs de conversion et de validation sont-elles gérées, et pourquoi un résultat INPUT est-il renvoyé au lieu d'une exception ?

Résultat INPUT de Struts 2 : comment les erreurs de conversion et de validation sont-elles gérées, et pourquoi un résultat INPUT est-il renvoyé au lieu d'une exception ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-03 03:30:09880parcourir

Struts 2 INPUT Result: How are Conversion and Validation Errors Handled, and Why is an INPUT Result Returned Instead of an Exception?

Résultat Struts2 INPUT : comment ça marche ? Comment les erreurs de conversion/validation sont-elles gérées ?

Question principale

Lorsqu'une chaîne non valide est saisie à la place d'un nombre, elle doit passer par l'intercepteur d'exception. Pendant le Param Interceptor, la conversion en un type int à l'aide de Integer.parseInt devrait échouer, déclenchant une NumberFormatException. Cette exception ne devrait-elle pas être insérée dans la Value Stack ? Pourquoi le résultat est-il affiché malgré les erreurs ?

Question secondaire

La saisie des alphabets dans le formulaire entraîne l'affichage de zéro. Pourquoi ?

Concept

Struts2 traite les erreurs de conversion et de validation comme des erreurs de saisie plutôt que comme des erreurs de blocage. Au lieu de déclencher des exceptions, il renvoie un résultat INPUT et informe l'utilisateur d'une saisie incorrecte.

Flux de travail détaillé

  1. Intercepteur de paramètres : Essaie de définir les paramètres. Si une RuntimeException (par exemple, NumberFormatException) se produit en devMode, un message d'erreur est ajouté aux erreurs d'action. Sinon, l'exception est supprimée.
  2. Intercepteur d'erreurs de conversion : Vérifie les erreurs de conversion et ajoute des erreurs de champ pour celles trouvées. Il enregistre également les valeurs d'origine pour les afficher dans les requêtes ultérieures.
  3. Intercepteur de validation : Effectue les validations demandées et ajoute des erreurs de champ pour les champs ne répondant pas aux critères.
  4. Flux de travail Intercepteur : vérifie les erreurs de champ. Si aucun n'est trouvé, la chaîne continue. Si des erreurs existent, un résultat INPUT est renvoyé.

Réponse à la question secondaire

Dans la réponse d'origine, les erreurs de conversion ont abouti à zéro en raison de la récupération de la valeur int par défaut au lieu de l'entrée String. . Cependant, Conversion Interceptor aurait dû enregistrer la chaîne d'origine pour l'afficher dans les requêtes suivantes.

Mais pourquoi la chaîne est-elle affichée sous la forme zéro au lieu de abc ?

Le problème est dû à l'attribut value dans le composant d’entrée. L'utilisation de getText() ou getText() dans l'attribut value entraîne des problèmes de conversion. La suppression de l'attribut value ou l'utilisation de %{myIntField} résout le problème.

Conclusions

  • Assurez-vous que la pile d'intercepteurs est correctement configurée.
  • Vérifiez l'attribut value en entrée. composants.
  • Supprimez l'attribut value à des fins de test pour vérifier l'exactitude comportement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn