此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring for Apache Kafka 3.3.0spring-doc.cadn.net.cn

@KafkaListener @Payload验证

从版本 2.2 开始,现在可以更轻松地添加Validator验证@KafkaListener @Payload参数。 以前,您必须配置自定义DefaultMessageHandlerMethodFactory并将其添加到注册商。 现在,您可以将验证器添加到注册商本身。 以下代码演示如何执行此作:spring-doc.cadn.net.cn

@Configuration
@EnableKafka
public class Config implements KafkaListenerConfigurer {

    ...

    @Override
    public void configureKafkaListeners(KafkaListenerEndpointRegistrar registrar) {
      registrar.setValidator(new MyValidator());
    }

}
当您将 Spring Boot 与验证Starters一起使用时,一个LocalValidatorFactoryBean是自动配置的,如下例所示:
@Configuration
@EnableKafka
public class Config implements KafkaListenerConfigurer {

    @Autowired
    private LocalValidatorFactoryBean validator;
    ...

    @Override
    public void configureKafkaListeners(KafkaListenerEndpointRegistrar registrar) {
      registrar.setValidator(this.validator);
    }
}

以下示例演示如何验证:spring-doc.cadn.net.cn

public static class ValidatedClass {

  @Max(10)
  private int bar;

  public int getBar() {
    return this.bar;
  }

  public void setBar(int bar) {
    this.bar = bar;
  }

}
@KafkaListener(id="validated", topics = "annotated35", errorHandler = "validationErrorHandler",
      containerFactory = "kafkaJsonListenerContainerFactory")
public void validatedListener(@Payload @Valid ValidatedClass val) {
    ...
}

@Bean
public KafkaListenerErrorHandler validationErrorHandler() {
    return (m, e) -> {
        ...
    };
}

从版本 2.5.11 开始,验证现在适用于@KafkaHandler方法。 看@KafkaListener在类上.spring-doc.cadn.net.cn

从版本 3.1 开始,您可以在ErrorHandlingDeserializer相反。 看ErrorHandlingDeserializer了解更多信息。spring-doc.cadn.net.cn