我有一个自定义 Spring XD 源模块,它使用 Spring Social for Twitter 并输出 Tweet 对象。这工作得很好。我可以记录源的输出并查看列出的 Tweet 对象。我可以将该流的源的输出类型更改为 application/json 以查看 JSON 的输出。这按预期工作。
然后我创建了一个处理器模块,它将从该推文创建一个新对象并输出它。转换消息需要一个包含 Tweet 对象的 GenericMessage 作为其有效负载(我也尝试让方法参数只是 Tweet,但这也不起作用)。
@Transformer
public OtherThing<Tweet> transform(GenericMessage<Tweet> message) {
// ... snip ...
}
但是,当我将两个模块链接在一起时
stream create --name test --definition 'my-tweet-source-module | my-tweet-processor | log' --deploy
并且从源模块输出一条推文,我得到一个类转换异常:
java.lang.ClassCastException: org.springframework.social.twitter.api.Tweet cannot be cast to org.springframework.social.twitter.api.Tweet
我已经验证这两个模块都使用相同版本的 Spring Social Twitter,所以那里应该没有问题。目前,模块通过本地传输进行通信,因此这也不应该是任何类加载问题(它们最终将需要通过非本地传输进行通信)。
我也尝试过解决方法,例如在流中定义源模块的输出类型应该是application/json
,然后尝试从输入字符串有效负载中读取 JSON,但由于 Spring Social Tweet 对象的性质,Jackson 不遵守.
我想知道为什么会发生这种情况以及我应该如何解决这个问题?我觉得我无疑做错了什么。如果我不允许这样做,我想知道为什么会这样以及应该做的事情是什么。
任何帮助,将不胜感激。
谢谢
编辑:我正在使用 Spring XD 1.2.1.RELEASE