を分割結果を送信:Apacheのキャメル - 私はCXFエンドポイントからの要求を処理し、JSONとして結果を返すべきルートを持っているCXFエンドポイントに
public class MyRoute extends RouteBuilder
{
// ... Autowired:
// msgRequestProcessor - converts json {string,string} to String of "\n" delimited json string: {string}\n{string}
// RangeProcessor, SingleProcessor - create mongodb Criteria object from json string
// msgTypeMapper - adds corresponding header "msg.type"
@Override
public void configure()
{
from("direct:list")
.process(msgRequestProcessor)
.split(body())
.bean(msgTypeMapper.class)
.choice()
.when(header("msg.type").isEqualTo("single"))
.log("Go to direct:single")
.to("direct:single")
.otherwise()
.log("Go to direct:range")
.to("direct:daterange")
.end()
.to("direct:aggregate");
from("direct:range")
.process(new RangeProcessor());
from("direct:single")
.process(new SingleProcessor());
from("direct:aggregate")
.aggregate(new MyAgg()).header("msg.collection").completionSize(2)
.log("RETVAL: ${body}")
.marshal().json(JsonLibrary.Gson).end();
}
public static final class MyAgg implements AggregationStrategy {
@Override
public Exchange aggregate(Exchange oldExchange, Exchange newExchange)
{
if (oldExchange == null) {
return newExchange;
}
Criteria oldCriteria = oldExchange.getIn().getBody(Criteria.class);
Criteria newCriteria = newExchange.getIn().getBody(Criteria.class);
Criteria criteria = new Criteria();
criteria.andOperator(oldCriteria, newCriteria);
oldExchange.getIn().setBody(criteria.getCriteriaObject().toString());
return oldExchange;
}
}
}
すべてが正常に動作します、私は正しい集計結果を参照してくださいそして、集計ログ
で完了が、CXFエンドポイントは、常に(分割前)msgRequestProcessorの出力を返します。
{"string"}
{"string"}
私はCriteriaオブジェクトが文字列に変換されることを期待していますが(ログに表示されます)
ご協力いただければ幸いです。ありがとう。
あなたのルートにはCXFが関係していますか? – Ralf
@Ralf直接のリクエストを転送するCXFリソースがあります。リストのエンドポイント。 – Savash
デフォルトでは、スプリッタは元の交換を返します(http://camel.apache.org/splitter.html#Splitter-WhattheSplitterreturns)。したがって、CXFエンドポイントが元の要求を受信したことは驚くことではありません。驚くべきことに、集約コードには何も集約されていないということです。それは本当ですか? – Ralf