340.3. unmarshal
在本例中,我们从名为 MY_QUEUE 的 ActiveMQ 队列传播 Tar 文件有效负载,并将其转发到 UnTarpedMessageProcessor
。
from("activemq:queue:MY_QUEUE").unmarshal().tarFile().process(new UnTarpedMessageProcessor());
from("activemq:queue:MY_QUEUE").unmarshal().tarFile().process(new UnTarpedMessageProcessor());
如果 Tar 文件有更多条目,则使用 TarFileDataFormat 的使用Iterator 选项为 true,您可以使用 splitter 进行进一步工作。
或者您可以使用 TarSplitter 作为拆分人的表达式,如下所示
from("file:src/test/resources/org/apache/camel/dataformat/tarfile?consumer.delay=1000&noop=true") .split(new TarSplitter()) .streaming() .process(new UnTarpedMessageProcessor()) .end();
from("file:src/test/resources/org/apache/camel/dataformat/tarfile?consumer.delay=1000&noop=true")
.split(new TarSplitter())
.streaming()
.process(new UnTarpedMessageProcessor())
.end();