在使用Camel时,你可能会使用到分解与聚合,例如当你向消息队列发送一个很大的文件的时候,你可能出于文件大小限制或效率的考量,需要将一个文件分解为若干文件包分别发送,在接收到接收到所有文件包后再合并为一个完整的文件。
在调用split方法时,evaluate方法需要返回一个的对象类型有一定的规则(要求),具体的规则是什么,看下面的源码则一目录了然:
分解即将一个消息分解为若干份(消息),然后可以对其进行单独处理,如下图:
要实现分解功能,则需要在路由定义中添加SplitDefinition,也就是要调用ProcessorDefinition.split方法,split方法主要是接收一个Expression对象,org.apache.camel.Expression是一个接口,其中只有一个evaluate方法:
package org.apache.camel;
public interface Expression {
<T> T evaluate(Exchange exchange, Class<T> type);
}
在调用split方法时,evaluate方法需要返回一个的对象类型有一定的规则(要求),具体的规则是什么,看下面的源码则一目录了然:
public static Iterator<Object> createIterator(Object value, String delimiter, final boolean allowEmptyValues) {
// if its a message than we want to iterate its body
if (value instanceof Message) {
value = ((Message) value).getBody();
}
if (value == null) {
return Collections.emptyList().iterator();
} else if (value instanceof Iterator) {
return (Iterator<Object>)value;
} else if (value instanceof Iterable) {
return ((Iterable<Object>)value).iterator();
} else if (value.getClass().i