Heim >Java >javaLernprogramm >So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

PHPz
PHPznach vorne
2023-05-11 11:43:051420Durchsuche

Spring Boot Validation unterstützt JSR-380-Anmerkungen (auch bekannt als Bean Validation 2.0, Teil von Jakarta EE und JavaSE). Die Überprüfungsfehlermeldung kann über das Nachrichtenattribut der Überprüfungsanmerkung festgelegt werden, und jede Überprüfungsanmerkung verfügt über einen Standard Bei der Konfiguration wird beispielsweise der Nachrichtenattributwert von @NotBlank wie folgt festgelegt: @NotBlank的message属性值设置如下图:

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

默认的message = "{...}"的形式即指定国际化属性的名称,后续会根据语言环境替换为对应的值,而这些国际化属性的定义可参见hibernate-validator中的org.hibernate.validator.ValidationMessages.properties等一些列国际化属性定义:

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

而我们在实际使用过程中,除了可以设置message="{propName}"的形式来读取国际化属性,亦可以直接设置值message="具体的提示信息",而不明确设置message则使用之前提到的org.hibernate.validator.ValidationMessages.properties中的默认配置。

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

Spring Boot Validation起初其并不直接支持读取Spring Boot自身的国际化配置(通过spring.messages进行配置),而是需要在resources/ValidationMessages.properties中进行配置的国际化属性才会生效,而后续在Spring Boot 2.6+版本才支持Validation与Spring Boot自身的国际化配置相结合。

接下来结合Spring Boot 2.5和2.6版本分别介绍下Spring Boot Validation如何集成自定义国际化验证提示信息。

Spring Boot 2.5.x

在Spring Boot 2.5.x版本中,Spring Boot Validation默认只支持读取resources/ValidationMessages.properties系列文件的中的国际化属性,且中文需要进行ASCII转码才可正确显示

如下图:

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

而就算Spring Boot应用亦声明了自身的国际化配置,但是Spring Boot Validation框架是读取不到的

例如:

Spring Boot应用自身的国际化配置如下图,但是在验证注解message属性设置i18n/messages.properties中的"{propName}"是读取不到的:

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

而想要Spring Boot Validation框架和Spring Boot自身使用同样的国际化配置,则可通过如下方式进行配置:

import org.springframework.context.MessageSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.validation.Validator;
import org.springframework.validation.beanvalidation.LocalValidatorFactoryBean;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**
 * Spring Web验证器自定义国际化文件配置<br/>
 * 注:适用于Spring Boot 2.5.*
 *
 * @author luohq
 * @date 2022-05-21
 */
@Configuration
public class WebValidationConfig implements WebMvcConfigurer {

    /**
     * 国际化消息源
     */
    private MessageSource messageSource;

    public WebValidationConfig(MessageSource messageSource) {
        //注入Spring Boot国际化消息源(需通过spring.messages明确指定)
        this.messageSource = messageSource;
    }

    /**
     * 使用自定义LocalValidatorFactoryBean,
     * 设置Spring国际化消息源
     */
    @Bean
    @Override
    public Validator getValidator() {
        LocalValidatorFactoryBean bean = new LocalValidatorFactoryBean();
        //仅兼容Spring Boot spring.messages设置的国际化文件和原hibernate-validator的国际化文件
        //不支持resource/ValidationMessages.properties系列
        bean.setValidationMessageSource(this.messageSource);
        return bean;
    }

}

注:

  • 通过上述配置类进行配置后,

  • 仅兼容Spring Boot spring.messages设置的国际化文件和原hibernate-validator的国际化文件

  • 不再支持resource/ValidationMessages.properties系列

Spring Boot 2.6.x

翻了Github上Spring Boot框架的Release说明,发现其在2021-08-20发布的v2.6.0-M2中提到了支持使用自身国际化MessageSource解析验证提示信息,也就是说Spring Boot 2.6.x版本之后已支持验证注解message属性引用Spring Boot自身国际化配置。

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

实际测试Spring Boot 2.6.x版本,验证注解message="{propName}"

  • 可以直接读取通过spring.messages设置的国际化配置中的属性(设置UTF-8编码后中文可无需ASCII转码),

  • 同时亦支持读取resources/ValidationMessages.properties中的配置(中文需ASCII转码),

  • 且依旧支持原hibernate-validator

    So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsnachricht
Die Standard-message = „{...}“ hat die Form: Geben Sie den Namen des Internationalisierungsattributs an, das entsprechend dem Gebietsschema durch den entsprechenden Wert ersetzt wird. Die Definition dieser Internationalisierungsattribute finden Sie in org.hibernate.validator.ValidationMessages <code>hibernate-validator. und eine Reihe internationaler Eigenschaftsdefinitionen:

So konfigurieren Sie die Internationalisierung der SpringBoot-Validierungsaufforderungsinformationen

In der tatsächlichen Verwendung zusätzlich zum Festlegen der Form der Nachricht ="{propName}" Um die Internationalisierungseigenschaften auszulesen, können Sie auch direkt den Wert message="spezifische Eingabeaufforderungsinformationen" festlegen. Wenn Sie die Nachricht nicht explizit festlegen, verwenden Sie den Standardwert in org.hibernate .validator.ValidationMessages.properties bereits erwähnte Konfiguration.

So konfigurieren Sie die Internationalisierung der SpringBoot Validation-EingabeaufforderungsinformationenSo konfigurieren Sie die Internationalisierung der SpringBoot-Validierungsaufforderungsinformationen

Spring Boot Validation unterstützt zunächst nicht direkt das Lesen der eigenen Internationalisierungskonfiguration von Spring Boot (konfiguriert über spring.messages), muss jedoch in resources/ValidationMessages.properties konfiguriert werden. Das Validierungsattribut wird wirksam. und die Kombination aus Validierung und der eigenen Internationalisierungskonfiguration von Spring Boot wird nur in Spring Boot 2.6+ unterstützt.

Als nächstes stellen wir in Kombination mit den Versionen Spring Boot 2.5 und 2.6 vor, wie Spring Boot Validation benutzerdefinierte internationale Verifizierungsaufforderungsinformationen integriert. So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen

Spring Boot 2.5.x

In der Spring Boot 2.5.x-Version unterstützt Spring Boot Validation standardmäßig nur das Lesen der resources/ValidationMessages.properties-Reihe Das Internationalisierungsattribut in der Datei und Chinesisch müssen ASCII-transkodiert werden, um #🎜🎜##🎜🎜# wie unten gezeigt korrekt anzuzeigen: #🎜🎜##🎜🎜#So konfigurieren Sie die Internationalisierung der SpringBoot-Validierungsaufforderungsinformationen#🎜🎜##🎜🎜#Sogar die Spring Boot-Anwendung deklariert auch ihre eigene Internationalisierungskonfiguration. aber das Spring Boot Validation Framework kann es nicht lesen "{propName}" in i18n/messages.properties kann nicht gelesen werden: #🎜🎜##🎜🎜#So konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen#🎜🎜##🎜🎜#Und Sie möchten, dass das Spring Boot Validation Framework und Spring Boot selbst dieselbe Internationalisierungskonfiguration verwenden, Sie können es folgendermaßen konfigurieren: #🎜🎜#rrreee#🎜🎜#Hinweis:#🎜🎜#
  • #🎜 🎜# Nach der Konfiguration über die obige Konfigurationsklasse ist #🎜🎜##🎜🎜#
  • #🎜🎜# nur mit den von Spring Boot spring.messages festgelegten Internationalisierungsdateien und den Internationalisierungsdateien des ursprünglichen Hibernate-Validators#🎜🎜 kompatibel # #🎜🎜#
  • #🎜🎜#Die Serie „resource/ValidationMessages.properties“ wird nicht mehr unterstützt #🎜🎜##🎜🎜##🎜🎜#

    Spring Boot 2.6.x

    #🎜🎜 #umgedreht Laut der Release-Beschreibung des Spring Boot-Frameworks auf Github wurde festgestellt, dass in v2.6.0-M2, veröffentlicht am 20.08.2021, erwähnt wurde, dass es die Verwendung einer eigenen internationalisierten MessageSource zum Parsen von Verifizierungsaufforderungsinformationen unterstützt Dies bedeutet, dass Spring Boot es seit Version 2.6.x unterstützt. Stellen Sie sicher, dass sich das Anmerkungsnachrichtenattribut auf die eigene Internationalisierungskonfiguration von Spring Boot bezieht. #🎜🎜##🎜🎜#So konfigurieren Sie die Internationalisierung der SpringBoot-Validierungsaufforderungsinformationen#🎜🎜##🎜🎜# Aktuelle Testversion von Spring Boot 2.6.x, überprüfen Sie die Anmerkung message="{propName}": #🎜🎜#
    • #🎜🎜# Sie können die Eigenschaften in der Internationalisierungskonfiguration direkt über spring.messages lesen (nach dem Festlegen der UTF-8-Kodierung ist für Chinesisch keine ASCII-Transkodierung erforderlich), #🎜🎜 # #🎜🎜#
    • #🎜🎜# Unterstützt auch das Lesen der Konfiguration in resources/ValidationMessages.properties (Chinesisch erfordert ASCII-Transkodierung), #🎜🎜# #🎜 🎜#
    • #🎜🎜# Und unterstützt weiterhin die ursprünglichen hibernate-validator-Internationalisierungsdateien. #🎜🎜##🎜🎜##🎜🎜##🎜🎜#Und die Leseprioritäten sind von oben nach unten, das heißt, die oberste wird zuerst wirksam. #🎜🎜##🎜🎜#Die spezifische Konfiguration und Verwendung ist in der folgenden Abbildung dargestellt: #🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜#Spring Boot 2.6 Bezüglich der Integration der Spring Boot-Validierung und MessageSource. Spezifische Implementierungsdetails finden Sie im GitHub Pull Request #17530, der im Release erwähnt wird: #🎜🎜##🎜🎜##🎜🎜##🎜🎜#

Das obige ist der detaillierte Inhalt vonSo konfigurieren Sie die Internationalisierung der SpringBoot Validation-Eingabeaufforderungsinformationen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen