Java 如何强制Bindy始终返回列表?
我有以下路线:Java 如何强制Bindy始终返回列表?,java,apache-camel,bindy,Java,Apache Camel,Bindy,我有以下路线: from("direct:abc") // read the file .split(body().tokenize("\n", 3, false)).streaming().stopOnException() .unmarshal(new BindyCsvDataFormat(Foo.class)) .process(new FooListProcessor()); 问题是,如果我在文件中有4条记录,第一组作
from("direct:abc")
// read the file
.split(body().tokenize("\n", 3, false)).streaming().stopOnException()
.unmarshal(new BindyCsvDataFormat(Foo.class))
.process(new FooListProcessor());
问题是,如果我在文件中有4条记录,第一组作为List
进入处理器,而第二组作为单个Foo
对象。
我必须用instanceof
检查body,并在每次发生此类情况时创建一个列表
Foo
class:
@CsvRecord(separator = ",")
public class Foo {
@DataField(pos = 1)
private String fooField;
@DataField(pos = 2, trim = true)
private String barField;
}
文件内容:
"lorem","ipsum"
"dolorem","sit"
"consectetur","adipiscing"
"eiusmod","incididunt"
有没有办法强制
Bindy
总是将其解组到列表中?如果存在单个实例,则没有Bindy返回单个实例。还有一个列表,还有更多
我已经记录了一个改进记录单,因此您可以对此进行配置:只是一个小点。由于它不受@Claus所说的支持,所以您不需要执行签入处理器代码的实例,您还可以按照这样的方式执行,并让camel为您处理它
from("file:///tmp/camel/input")
// read the file
.split(body().tokenize("\n", 3, false)).streaming().stopOnException()
.unmarshal(new BindyCsvDataFormat(Foo.class))
.choice()
.when(body().isInstanceOf(List.class))
.process(exchange -> { // Your logic here for list})
.otherwise()
.process(exchange -> {// Your logic here for individual items})
.endChoice();
你能显示文件内容片段和你的Foo吗Class@pvpkiran,我已经更新了问题的细节