Apache Camel exec与args

Dam*_*amo 4 apache-camel

使用exec组件时,是否可以指定args内联而不必将其设置为ExecBinding.EXEC_COMMAND_ARGS

例如,我有这条路线:

from("seda:getPolicyListStart")
.process(new Processor() {
    public void process(Exchange e) {
        ClientRequestBean requestBean = (ClientRequestBean)e.getIn().getBody();
        List<String> args = new ArrayList<String>();
        args.add(requestBean.getClient());
        args.add(requestBean.getSort());
        e.getOut().setHeader(ExecBinding.EXEC_COMMAND_ARGS, args);
    }
})
.to("exec:some_command?useStderrOnEmptyStdout=true")
.convertBodyTo(String.class)
.log("Executed OS cmd and received: ${body}")
Run Code Online (Sandbox Code Playgroud)

但是我会认为我可以使用简单表达式语言来简化它:

from("seda:getPolicyListStart")
.to("exec:some_command?useStderrOnEmptyStdout=true&args=${body.client} ${body.sort}")
.convertBodyTo(String.class)
.log("Executed OS cmd and received: ${body}")
Run Code Online (Sandbox Code Playgroud)

与使用文件组件时如何使用文件语言(简单的子集)类​​似.

可能吗?如果没有,第一个例子可以简化吗?

更新 [解决方案]:

    from(requestNode)
    .routeId(routeId)
    .recipientList(simple("exec:"+osCmd+"?useStderrOnEmptyStdout=true&args=${body.client}"))
    .convertBodyTo(String.class)
    .log("Executed OS cmd and received: ${body}")
    .to(responseNode);
Run Code Online (Sandbox Code Playgroud)

谢谢.

Cla*_*sen 7

答案是EIP模式.在运行时计算端点目标时,需要使用动态收件人列表EIP模式.

http://camel.apache.org/recipient-list.html

收件人列表接受表达式,这意味着您可以使用Simple语言在运行时构造参数