Maison >Java >javaDidacticiel >Exceptions au printemps : comment apprivoiser vos erreurs
Donc, vous implémentez Spring dans votre projet, puis, selon la loi de Murphy, une exception apparaît. Mais pas de panique : Spring dispose de puissantes capacités de gestion des erreurs ! Voyons exactement comment vous pouvez utiliser ces fonctionnalités.
Exceptions cochées et non cochées : pourquoi tout est-il si confus ?
Java divise les exceptions en deux types : cochées et non cochées. Les exceptions vérifiées nécessitent une gestion explicite. Imaginez deux passages pour piétons avec des personnes qui les traversent. Un passage à niveau est gardé par un inspecteur strict avec un panneau « Contrôle strict ». Ici, chaque personne est contrôlée et si elle n'a pas l'autorisation de passer, elle ne sera pas autorisée à passer. Cette transition est analogue aux exceptions vérifiées : elles nécessitent un traitement obligatoire, sinon le programme ne sera pas compilé.
La deuxième transition, au contraire, n'est pas maîtrisée. Les gens y transitent librement et rapidement, sans aucun contrôle. Ceci est analogue aux exceptions non contrôlées : ces exceptions ne nécessitent pas de traitement et le code peut être exécuté même sans vérification des erreurs. Cependant, en cas d'erreur, elle apparaîtra de manière inattendue - directement sur la « route ».
public void someMethod() throws IOException { throw new IOException("Oops, checked exception!"); }
@ExceptionHandler : quand les bugs bénéficient d'un traitement VIP
@ExceptionHandler est votre propre « videur » personnel qui intercepte et gère les exceptions uniquement pour les méthodes ou classes spécifiées. Si vous souhaitez accorder un traitement VIP à certaines erreurs, annotez la méthode avec @ExceptionHandler et profitez-en.
public void someMethod() throws IOException { throw new IOException("Oops, checked exception!"); }
Désormais, chaque fois qu'une ResourceNotFoundException est rencontrée, votre gestionnaire imprimera discrètement un message convivial au lieu que l'utilisateur voie une pile d'erreurs effrayante.
@ControllerAdvice : quand donner des conseils à gauche et à droite
Si @ExceptionHandler ne fonctionne que pour une classe spécifique, alors @ControllerAdvice est le roi de la file d'attente. Cette annotation couvre tous les contrôleurs, afin que les bugs ne passent plus entre les mailles du filet !
@ExceptionHandler(ResourceNotFoundException.class) public ResponseEntity<String> handleResourceNotFound(ResourceNotFoundException ex) { return new ResponseEntity<>("Resource not found: " + ex.getMessage(), HttpStatus.NOT_FOUND); }
Avec ce code, toutes les erreurs non détectées seront détectées et traitées avec un seul message. C'est comme un cadre "Tout compris" pour les exceptions - pratique et sûr.
@ResponseStatus : quand vous souhaitez rendre l'exception plus expressive
Parfois, les statuts HTTP standard ne capturent pas tout à fait l'essence de l'exception. Mais avec @ResponseStatus, vous pouvez forcer les exceptions à être plus expressives.
@ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(Exception.class) public ResponseEntity<String> handleGlobalException(Exception ex) { return new ResponseEntity<>("Oops, something went wrong!", HttpStatus.INTERNAL_SERVER_ERROR); } }
Désormais, lorsqu'une ResourceNotFoundException est levée, Spring renvoie automatiquement un statut 404, sans vous obliger à le faire manuellement. Une excellente façon d'ajouter du drame, n'est-ce pas ?
@RestControllerAdvice : pour les amateurs de REST
@RestControllerAdvice est comme @ControllerAdvice, mais exclusivement pour les contrôleurs REST. Autrement dit, c'est votre meilleur choix pour créer une API puisqu'elle renvoie du JSON au lieu des pages HTML. Prise en charge des vrais fans de REST !
public void someMethod() throws IOException { throw new IOException("Oops, checked exception!"); }
Cette approche garantit que vos utilisateurs reçoivent toujours des réponses structurées au format JSON, ce qui rend vos API encore plus conviviales.
Exceptions personnalisées : quand les exceptions standards ne suffisent pas
À un moment donné, vous réalisez que les exceptions standard et RuntimeException n'expriment tout simplement pas toute la tragédie de votre situation. Eh bien, créez vos propres exceptions ! Les exceptions personnalisées ajoutent un peu de personnalité et Spring les gère toujours avec respect.
@ExceptionHandler(ResourceNotFoundException.class) public ResponseEntity<String> handleResourceNotFound(ResourceNotFoundException ex) { return new ResponseEntity<>("Resource not found: " + ex.getMessage(), HttpStatus.NOT_FOUND); }
Créez un gestionnaire pour cela, et les utilisateurs de votre application verront un message clair, et non un tas de lignes effrayantes.
Conclusion
La gestion des erreurs au printemps est un peu un art. Du traitement au niveau de la méthode au traitement global, des réponses JSON aux statuts personnalisés, les possibilités sont vraiment vastes.
Alors prenez @ExceptionHandler, @ControllerAdvice et @ResponseStatus et transformez les exceptions en une masterclass de gestion des erreurs. Spring est prêt à vous aider à gérer toute erreur et à sauver la face devant les utilisateurs
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!