У меня есть класс
public enum A{
LOAN1,
LOAN2
}
Я создаю свой объект сообщения, как показано ниже: -
@ServiceActivator(inputChannel = Processor.INPUT, outputChannel = Processor.OUTPUT)
public Message handle(Message<?> message){
Message<String> message1 = (Message<String>);
MessageBuilder.fromMessage(message)
.setHeader("ID", person.getID())
.setHeader("AType",A.LOAN1)
.build();
logger.info("Enriched Header with 2nd Attribute-->> "+message1.getHeaders().get("AType"));
return message1;
}
Приведенный выше код работает нормально. Печатает все нормально.
Теперь в моем другом приложении Spring Boot, которое потребляет message1 от KafkaTopic
@ServiceActivator(inputChannel = Processor.INPUT)
public Message handle2(Message<?> message){
A atype = (A) message.getHeaders().get("AType");
logger.info("RECEIVED ENUM data is-->> "+atype);
}
Это ошибка вышеупомянутой части. NonTrustedHeaderType
Я не совсем понимаю концепции Enum относительно заголовков Spring Kafka, насколько это необходимо. Но я учусь. Очень признателен. Спасибо.




NonTrustedHeaderType означает, что вам не хватает доверия к пакету, в котором находится ваш Enum.
См. Дополнительную информацию в Справочное руководство:
By default, the mapper will only deserialize classes in
java.langandjava.util. You can trust other (or all) packages by adding trusted packages using theaddTrustedPackagesmethod. If you are receiving messages from untrusted sources, you may wish to add just those packages that you trust. To trust all packages usemapper.addTrustedPackages("*").
Также имеется соответствующее свойство конфигурации с точки зрения Весенний ботинок:
spring.kafka.consumer.properties.spring.json.trusted.packages=com.example,org.acme
Я считаю, что вам нужно добавить его к надежным именам заголовков. Например, см. Свойство связывателя spring.cloud.stream.kafka.binder.headerMapperBeanName, чтобы указать на экземпляр компонента DefaultKafkaHeaderMapper.