3

我按照我之前的问题Spring Cloud Stream message from/to JSON conversion configuration和配置的流进行了描述,但是,我无法使其正常工作。

我的设置如下。我有两个应用程序AB. 应用程序A使用输入通道one,输出two。应用程序B使用输入two。频道two配置为内容类型application/json

应用 A. 属性。

spring.cloud.stream.bindings.input.destination=one
spring.cloud.stream.bindings.input.group=default

spring.cloud.stream.bindings.output.destination=two
spring.cloud.stream.bindings.output.content-type=application/json

监听器方法。

@ServiceActivator(inputChannel = Processor.INPUT, outputChannel = Processor.OUTPUT)
public Dto handle(byte[] payload) throws IOException {
    final Dto dto = new ObjectMapper().readValue(payload, Dto.class);
    logger.info("{}", dto);
    dto.setId(dto.getId() + 1000);
    return dto;
}

应用 B. 属性。

spring.cloud.stream.bindings.input.destination=two
spring.cloud.stream.bindings.input.group=default
spring.cloud.stream.bindings.input.content-type=application/json

监听器方法。

@ServiceActivator(inputChannel = Sink.INPUT)
public void handle(Dto dto) throws IOException {
    logger.info("DTO {}", dto);
}

当我手动将带有正确 JSON 字符串的消息发送到 channelone时,它会被正确处理并two作为 JSON 消息发送到 channel(标题与上述问题中描述的完全相同)。之后,twoApp B 在频道上接收到它并抛出异常:Method handle(java.lang.String) cannot be found

当然,当我创建这两种方法时,将 Dto 和 String 作为输入处理,它可以工作,但总是调用 String 方法并且必须自己反序列化有效负载。

我在哪里弄错了吗?如何使用这样的签名设置方法:public Dto handle(Dto incoming)

4

2 回答 2

2

您应该将 AppB 输入的内容类型声明更改为

application/x-java-object;type=your.package.Dto.

正如您在问题中指定的那样,您当然只接受 JSON 字符串。

于 2016-03-23T10:33:53.550 回答
0

如果使用@StreamListener你不必使用答案方式,但你必须删除(不要指定任何东西,否则它将是一个json字符串):

spring.cloud.stream.bindings.input.content-type=application/json

来自 AppB 属性

来源(旧文档但仍然有效): https ://docs.spring.io/spring-cloud-stream/docs/Brooklyn.RELEASE/reference/html/contenttypemanagement.html#__literal_streamlistener_literal_and_message_conversion

于 2019-04-16T17:09:46.153 回答