使用apache和通配符在JMS消息上使用xquery有问题。
我的代码从jms队列中读取并尝试过滤消息。
import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.cdi.ContextName;
import org.apache.camel.component.jms.JmsComponent;
import org.wildfly.extension.camel.CamelAware;
import javax.annotation.Resource;
import javax.ejb.Startup;
import javax.enterprise.context.ApplicationScoped;
import javax.jms.ConnectionFactory;
@Startup
@CamelAware
@ApplicationScoped
@ContextName("test")
class MyRouteBuilder extends RouteBuilder {
@Resource(mappedName = "java:jboss/DefaultJMSConnectionFactory")
private ConnectionFactory connectionFactory;
@Override
public void configure() throws Exception {
getContext().addComponent("jms", JmsComponent.jmsComponentAutoAcknowledge(connectionFactory));
from("jms:queue:test1").
routeId("test").
to("log:jms?showAll=true").
filter().xquery("fn:contains(//person/name/text(),'james')").
to("file://Users/asse/Outbound");
当我使用消息<person><name>james</name><person>
运行代码时,会得到以下错误:
消息历史- RouteId ProcessorId处理器 经过(ms)测试jms://queue: test 1 测试log:jms?showAll=true 测试filter[xquery{XQuery[net.sf.saxon.query.XQueryExpression@3af367ad]}] Stacktraceorg.apache.camel.processor.RedeliveryErrorHandler.process(RedeliveryErrorHandler.java:542) at org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:197)的.process(InstrumentationProcessor.java:77)
我不明白为什么!有人能帮我解决这个问题吗?
发布于 2016-12-23 17:39:13
在独立骆驼2.18.1中遇到了同样的问题。
我相信这是camel中的一个bug,它是由升级到SaxonVersion9.7.0引起的,它不再允许将空值放入查询上下文中-- bug在org.apache.camel.component.xquery.XQueryBuilder.类中它尝试将所有Exchange和属性添加到方法org.apache.camel.component.xquery.XQueryBuilder#configureQuery.中的查询执行上下文中如果任何标头或属性的值为空(如果使用JMS消息,则会引发异常)。
我能够复制这个问题,这似乎不是camel 2.18中xquery的唯一问题。
我记录了一个jira问题https://issues.apache.org/jira/browse/CAMEL-10653
https://stackoverflow.com/questions/41048421
复制相似问题