Heim Java javaLernprogramm Beste Möglichkeit, die Lokalisierung von Ausnahmemeldungen in Spring Boot zu handhaben

Beste Möglichkeit, die Lokalisierung von Ausnahmemeldungen in Spring Boot zu handhaben

Sep 06, 2024 am 06:03 AM

Best Way to Handle Localization For Exception Messages in Spring Boot

Da Anwendungen wachsen, um ein globales Publikum zu bedienen, wird die Lokalisierung zu einem entscheidenden Aspekt der Softwareentwicklung. Durch die Lokalisierung können sich Anwendungen an verschiedene Sprachen und Regionen anpassen und so ein benutzerfreundliches Erlebnis bieten. 

In diesem Artikel werde ich meine bevorzugte Art der Behandlung lokalisierter Ausnahmen in einer Spring Boot-Anwendung vorstellen.

Warum brauchen wir eine Lokalisierung für Ausnahmemeldungen?

Die Lokalisierung von Ausnahmemeldungen auf der Backend-Seite ist für die Schaffung eines nahtlosen Benutzererlebnisses von entscheidender Bedeutung, insbesondere bei Anwendungen, die auf ein globales Publikum ausgerichtet sind. 

Indem wir diese Nachrichten im Backend lokalisieren und direkt an das Frontend senden, können wir den Frontend-Entwicklern die Verantwortung für die Verwaltung mehrerer Sprachen abnehmen. Dieser Ansatz stellt sicher, dass die Fehlermeldungen über alle Plattformen und Sprachen hinweg konsistent sind, sodass sich Frontend-Entwickler auf die benutzerfreundliche Anzeige dieser Meldungen konzentrieren können, beispielsweise in einem Fehler-Toast. 

Dadurch ist es nicht erforderlich, dass das Frontend benutzerdefinierte Ausnahmemeldungen für jede Sprache verarbeitet, wodurch Doppelarbeit und Fehlerpotenzial reduziert werden und sichergestellt wird, dass alle Benutzer klares und relevantes Feedback in ihrer bevorzugten Sprache erhalten.

Wie erreichen wir unser Ziel bequem im Backend?

Befolgen Sie die folgenden Schritte, um unser Ziel zu erreichen. 

Allgemeine Ausnahmeklasse

Erstellen Sie zunächst eine Klasse, die von RuntimeException ausgeht, und nennen Sie sie ResponseException. Mit dieser benutzerdefinierten Ausnahme können Sie anwendungsspezifische Fehler kontrollierter behandeln.

public class ResponseException extends RuntimeException {

}
Nach dem Login kopieren

Antwortfehlerklasse

Erstellen Sie eine separate Klasse, die in der Antwort zurückgegeben wird, wenn eine Ausnahme auftritt. Diese Klasse kann Felder wie Nachricht, Zeitstempel, Fehlercode und alle anderen relevanten Informationen enthalten, die Sie an das Frontend übergeben möchten.

public record ErrorResponse(int status, String message) {

}
Nach dem Login kopieren

Globaler Ausnahmehandler

Implementieren Sie einen GlobalExceptionHandler mithilfe der @ControllerAdvice-Annotation von Spring. In dieser Klasse können Sie die ResponseException abfangen und sie basierend auf dem Gebietsschema des Benutzers der entsprechenden lokalisierten Nachricht zuordnen.

@Slf4j
@RestControllerAdvice
@RequiredArgsConstructor
public class GlobalExceptionHandler extends ResponseEntityExceptionHandler {

  @ExceptionHandler(value = ResponseException.class)
  public ResponseEntity<ErrorResponse> handleResponseStatusException(
      ResponseException ex
  ) {
    log.error("ResponseException: {}", ex.getMessage());

    String message = ex.getMessage();

    var errorResponse = new ErrorResponse(ex.getStatus().value(), message);

    return new ResponseEntity<>(errorResponse, ex.getStatus());
  }
}
Nach dem Login kopieren

Sprachspezifische Eigenschaftsdateien

Um die lokalisierten Nachrichten zu verwalten, erstellen Sie Eigenschaftsdateien für jede unterstützte Sprache, z. B. „messages_en.properties“ für Englisch, „messages_az.properties“ für Aserbaidschanisch usw. Diese Dateien enthalten die Schlüssel-Wert-Paare für jede Ausnahmemeldung, sodass Spring automatisch die richtige Meldung basierend auf dem Gebietsschema des Benutzers auflösen kann.

Erstellen Sie diese Eigenschaftendateien im Ordner src/main/resources.

err.username_already_exists.msg=User with username: {0} is already exists.
Nach dem Login kopieren

Lokalisierungsteil implementieren

Ich habe das Nötigste für die Behandlung von Ausnahmen in Spring Boot erstellt. Ich gehe davon aus, dass Sie mit dem oben Gesagten bereits vertraut sind. Fügen wir weiterhin den Übersetzungsteil hinzu.

ResponseException-Klasse ändern:

public class ResponseException extends RuntimeException {
  private final String messageTemplate;
  private final transient Object[] params;
  private final Locale locale;

  public static ResponseException notFound(String messageTemplate, Locale locale) {
    return new ResponseException(HttpStatus.NOT_FOUND, messageTemplate, null, locale);
  }

  public static ResponseException notFound(String messageTemplate, Object[] params, Locale locale) {
    return new ResponseException(HttpStatus.NOT_FOUND, messageTemplate, params, locale);
  }

  public static ResponseException forbidden(String messageTemplate, Locale locale) {
    return new ResponseException(HttpStatus.FORBIDDEN, messageTemplate, null, locale);
  }

  public static ResponseException forbidden(String messageTemplate, Object[] params, Locale locale) {
    return new ResponseException(HttpStatus.FORBIDDEN, messageTemplate, params, locale);
  }  
}
Nach dem Login kopieren

Erstellen Sie Hilfsmethoden für häufig verwendete HttpStatus-Codes wie NOT_FOUND, FORBIDDEN.

Sie können diese Hilfsmethoden auf folgende Weise verwenden:

// some code parts omitted ...
userService.findByUsername(username)
  .orElseThrow(() -> ResponseException.notFound("user_not_found", locale))
Nach dem Login kopieren

Erstellen Sie in allen Ihren Immobiliendateien eine Nachrichtenvorlage „user_not_found“.

// file: messages_en.properties
user_not_found=User not found

// file: messages_az.properties
user_not_found=İsdifadəçi tapılmadı
Nach dem Login kopieren

Um diese automatisch zu ersetzen, bevor Sie zum Frontend zurückkehren, aktualisieren Sie die Methode in der GlobalExceptionHandler-Klasse.

@Slf4j
@RestControllerAdvice
@RequiredArgsConstructor
public class GlobalExceptionHandler extends ResponseEntityExceptionHandler {

  private final MessageSource messageSource;

  @ExceptionHandler(value = ResponseException.class)
  public ResponseEntity<ErrorResponse> handleResponseStatusException(
      ResponseException ex
  ) {
    log.error("ResponseException: {}", ex.getMessage());

    String message = ex.getMessage();

    String messageTemplate = ex.getMessageTemplate();
    if (StringUtils.isNotBlank(messageTemplate)) {
      message = messageSource.getMessage(messageTemplate, ex.getParams(), ex.getLocale());
    }

    var errorResponse = new ErrorResponse(ex.getStatus().value(), message);

    return new ResponseEntity<>(errorResponse, ex.getStatus());
  }
}
Nach dem Login kopieren

So verwenden Sie dynamische Werte in Ausnahmemeldungen

Diese Art der Ausnahmebehandlung ist nützlich, insbesondere wenn Sie dynamische Werte für Ihre Ausnahmemeldungen festlegen müssen. Zum Beispiel

// file: messages_en.properties
err.invalid_phone_number.msg=The phone: {0} is invalid
Nach dem Login kopieren

Um {0} durch einen dynamischen Wert zu ersetzen.

public static ResponseException badRequest(
      String messageTemplate, 
      Locale locale,
      String... params
) {
  return new ResponseException(
        HttpStatus.BAD_REQUEST, 
        messageTemplate, 
        params, 
        locale
  );
}
Nach dem Login kopieren

Ich habe den Parameter varargs am Ende eingefügt, um mehrere dynamische Parameter zu übergeben, ohne jedes Mal eine neue Methode zu erstellen.

Ich habe einen speziellen Artikel über Nachrichten mit dynamischen Werten.

Wo erhalte ich das Gebietsschema des Benutzers?

Ich habe zwei Ansätze, um Gebietsschemas abzurufen:

  1. Gebietsschemata der Benutzer, die basierend auf den Benutzeroberflächeneinstellungen in der Datenbank gespeichert werden.

  2. Einige Controller-Methoden akzeptieren optionale lang-Anforderungsparameter. Dies kann zum Testen nützlich sein, wenn Frontend-Entwickler sehen möchten, wie die Benutzeroberfläche in verschiedenen Sprachen aussieht. Weil die Satzlänge in jeder Sprache nicht gleich ist.

Abschluss

Das war's für heute. Ich hoffe, es hat Ihnen gefallen.

Der Quellcode ist im Repository in meinem GitHub-Konto verfügbar.

Wenn Sie Fragen haben, können Sie mich gerne über LinkedIn erreichen.

Das obige ist der detaillierte Inhalt vonBeste Möglichkeit, die Lokalisierung von Ausnahmemeldungen in Spring Boot zu handhaben. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

<🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1672
14
PHP-Tutorial
1277
29
C#-Tutorial
1257
24
Verursacht die Sicherheitssoftware des Unternehmens, die die Anwendung nicht ausführt? Wie kann man es beheben und es lösen? Verursacht die Sicherheitssoftware des Unternehmens, die die Anwendung nicht ausführt? Wie kann man es beheben und es lösen? Apr 19, 2025 pm 04:51 PM

Fehlerbehebung und Lösungen für die Sicherheitssoftware des Unternehmens, die dazu führt, dass einige Anwendungen nicht ordnungsgemäß funktionieren. Viele Unternehmen werden Sicherheitssoftware bereitstellen, um die interne Netzwerksicherheit zu gewährleisten. ...

Wie konvertiere ich Namen in Zahlen, um die Sortierung zu implementieren und die Konsistenz in Gruppen aufrechtzuerhalten? Wie konvertiere ich Namen in Zahlen, um die Sortierung zu implementieren und die Konsistenz in Gruppen aufrechtzuerhalten? Apr 19, 2025 pm 11:30 PM

Lösungen zum Umwandeln von Namen in Zahlen zur Implementierung der Sortierung in vielen Anwendungsszenarien müssen Benutzer möglicherweise in Gruppen sortieren, insbesondere in einem ...

Wie vereinfachte ich Probleme mit der Feldzuordnung im Systemdocking mithilfe des Mapstruct? Wie vereinfachte ich Probleme mit der Feldzuordnung im Systemdocking mithilfe des Mapstruct? Apr 19, 2025 pm 06:21 PM

Die Verarbeitung von Feldzuordnungen im Systemdocken stößt häufig auf ein schwieriges Problem bei der Durchführung von Systemdocken: So kartieren Sie die Schnittstellenfelder des Systems und ...

Wie identifiziert Intellij IDEA die Portnummer eines Spring -Boot -Projekts, ohne ein Protokoll auszugeben? Wie identifiziert Intellij IDEA die Portnummer eines Spring -Boot -Projekts, ohne ein Protokoll auszugeben? Apr 19, 2025 pm 11:45 PM

Beginnen Sie den Frühling mit der Intellijideaultimate -Version ...

Wie kann ich elegante Entitätsklassenvariablennamen erhalten, um Datenbankabfragebedingungen zu erstellen? Wie kann ich elegante Entitätsklassenvariablennamen erhalten, um Datenbankabfragebedingungen zu erstellen? Apr 19, 2025 pm 11:42 PM

Bei Verwendung von MyBatis-Plus oder anderen ORM-Frameworks für Datenbankvorgänge müssen häufig Abfragebedingungen basierend auf dem Attributnamen der Entitätsklasse erstellt werden. Wenn Sie jedes Mal manuell ...

Wie kann ich Java -Objekte sicher in Arrays umwandeln? Wie kann ich Java -Objekte sicher in Arrays umwandeln? Apr 19, 2025 pm 11:33 PM

Konvertierung von Java-Objekten und -Arrays: Eingehende Diskussion der Risiken und korrekten Methoden zur Konvertierung des Guss-Typs Viele Java-Anfänger werden auf die Umwandlung eines Objekts in ein Array stoßen ...

E-Commerce-Plattform SKU und SPU-Datenbankdesign: Wie berücksichtigen Sie sowohl benutzerdefinierte Attribute als auch Attributloses Produkte? E-Commerce-Plattform SKU und SPU-Datenbankdesign: Wie berücksichtigen Sie sowohl benutzerdefinierte Attribute als auch Attributloses Produkte? Apr 19, 2025 pm 11:27 PM

Detaillierte Erläuterung des Designs von SKU- und SPU-Tabellen auf E-Commerce-Plattformen In diesem Artikel werden die Datenbankdesignprobleme von SKU und SPU in E-Commerce-Plattformen erörtert, insbesondere wie man mit benutzerdefinierten Verkäufen umgeht ...

Wie verwendet ich die Redis -Cache -Lösung, um die Anforderungen der Produktranking -Liste effizient zu erkennen? Wie verwendet ich die Redis -Cache -Lösung, um die Anforderungen der Produktranking -Liste effizient zu erkennen? Apr 19, 2025 pm 11:36 PM

Wie erkennt die Redis -Caching -Lösung die Anforderungen der Produktranking -Liste? Während des Entwicklungsprozesses müssen wir uns häufig mit den Anforderungen der Ranglisten befassen, z. B. das Anzeigen eines ...

See all articles