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,我已经更新了问题的细节