着信soapリクエストをログに記録するバンドルをFuseESBにデプロイしました。私はJavaDSLを
from("cxf:bean:comprovaWS?dataFormat=MESSAGE").setHeader("SOAPAction", new ConstantExpression("http://www.about.com")).streamCaching()
            .choice()
            .when(xPathBuilder).log("Request is:"+getParsedXPath(simple("${body}").getText().trim(),"//item[2]/stringValue/text()", false))
            .to("callService")
            .otherwise().log("Error");
ここでメソッドgetParsedXPathを使用すると、FuseESBは例外を次のように表示します。  org.xml.sax.SAXParseException: Content is not allowed in prolog.
上記の方法でCDATA情報を取得しています。メソッドは次のようになります。
 public String getParsedXPath(String xmlStringToParse, String xPathExpression, boolean isNamespaceAware) {
    String parsedXMLPath="";
    try {
        DocumentBuilderFactory xmlFact =
                DocumentBuilderFactory.newInstance();
        DocumentBuilder builder = xmlFact.newDocumentBuilder();
        Document doc = builder.parse(new java.io.ByteArrayInputStream(xmlStringToParse.getBytes()));
        XPath xpath = XPathFactory.newInstance().newXPath();
        xmlFact.setNamespaceAware(isNamespaceAware);
        if(isNamespaceAware){
        xpath.setNamespaceContext(new NamespaceContext() {
    public String getNamespaceURI(String prefix) {
    // we know there's only one namespace uri, just return it!
    return "http://www.about.com";
    }
    // this is not used by XPath
    public String getPrefix(String namespaceURI) {
    System.out.println("getPrefix: " + namespaceURI);
    return null;
    }
    // this is not used by XPath
    public Iterator getPrefixes(String namespaceURI) {
    System.out.println("getPrefixes: " + namespaceURI);
    return null;
    }
});
        }
        NodeList nodes = (NodeList) xpath.evaluate(xPathExpression, doc, XPathConstants.NODESET);
    if (nodes.getLength() == 0) {
    parsedXMLPath="<error>Wrong xPath value: "+xPathExpression+"</error>";
    }
    else {
            parsedXMLPath = nodes.item(0).getNodeValue();
    }
    } catch (Exception e) {
        e.printStackTrace();
    }
    return parsedXMLPath;
}
コード自体で実際のsoapリクエストに相当するデモXMLを使用すると、Fuseは例外なくバンドルをインストールします。
FuseはSOAPリクエストを受け入れる前にどのように例外をスローできますか?誰かが私に解決策を教えてもらえますか?