首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >骆驼速度找不到资源

骆驼速度找不到资源
EN

Stack Overflow用户
提问于 2017-06-13 20:52:13
回答 3查看 860关注 0票数 0

我正在学习如何使用Apache和Apache (在Karaf中)托管动态网页,但是当我试图在另一个页面中包含一个速度文件时,即使它们在同一个目录中,我也会得到一个资源错误。

如果我从第一个文件中移除行#parse("${page}.vm"),所有操作都会按照预期进行。

这是我的整个装置。除了安装camel速度和jetty-9之外,这里没有列出的所有东西都是默认的ServiceMix 7.0.0设置。

骆驼路线

代码语言:javascript
复制
<route id="web_route">
  <from uri="jetty:http://localhost:8080/test?sessionSupport=true&amp;matchOnUriPrefix=true"/>
  <to uri="velocity:file:web/vm/webpage.vm?contentCache=false"/>
</route>

/web/vm/webpage.vm含量

代码语言:javascript
复制
Hello sir $!{headers.name}! Welcome to the VM World!
#set($page="$headers.CamelHttpUrl")
#set($page="$page.substring($page.lastIndexOf('/')).substring(1)")
#parse("${page}.vm")

/web/vm/hello.vm含量

代码语言:javascript
复制
Hello World!

本地主机:8080/test/hello

代码语言:javascript
复制
org.apache.velocity.exception.ResourceNotFoundException: Unable to find resource 'hello.vm'
    at org.apache.velocity.runtime.resource.ResourceManagerImpl.loadResource(ResourceManagerImpl.java:474)
    at org.apache.velocity.runtime.resource.ResourceManagerImpl.getResource(ResourceManagerImpl.java:352)
    at org.apache.velocity.runtime.RuntimeInstance.getTemplate(RuntimeInstance.java:1533)
    at org.apache.velocity.runtime.directive.Parse.render(Parse.java:197)
    at org.apache.velocity.runtime.parser.node.ASTDirective.render(ASTDirective.java:207)
    at org.apache.velocity.runtime.parser.node.SimpleNode.render(SimpleNode.java:342)
    at org.apache.velocity.runtime.RuntimeInstance.render(RuntimeInstance.java:1378)
    at org.apache.velocity.runtime.RuntimeInstance.evaluate(RuntimeInstance.java:1314)
    at org.apache.velocity.app.VelocityEngine.evaluate(VelocityEngine.java:272)
    at org.apache.camel.component.velocity.VelocityEndpoint.onExchange(VelocityEndpoint.java:212)
    at org.apache.camel.impl.ProcessorEndpoint$1.process(ProcessorEndpoint.java:71)
    at org.apache.camel.util.AsyncProcessorConverterHelper$ProcessorToAsyncProcessorBridge.process(AsyncProcessorConverterHelper.java:61)
    at org.apache.camel.processor.SendProcessor.process(SendProcessor.java:145)
    at org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:77)
    at org.apache.camel.processor.RedeliveryErrorHandler.process(RedeliveryErrorHandler.java:460)
    at org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:196)
    at org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:196)
    at org.apache.camel.component.jetty.CamelContinuationServlet.service(CamelContinuationServlet.java:191)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:812)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1669)
    at org.eclipse.jetty.servlets.MultiPartFilter.doFilter(MultiPartFilter.java:146)
    at org.apache.camel.component.jetty.CamelFilterWrapper.doFilter(CamelFilterWrapper.java:43)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1652)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:585)
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:221)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1127)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:515)
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:185)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1061)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
    at org.eclipse.jetty.server.Server.handle(Server.java:499)
    at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:311)
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:257)
    at org.eclipse.jetty.io.AbstractConnection$2.run(AbstractConnection.java:544)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:635)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:555)
    at java.lang.Thread.run(Thread.java:745)

所以为什么不能导入hello.vm?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-06-16 12:53:23

我发现#parse()和#include()引用文件相对于%karaf_home%,而不是当前目录。因此,如果您想在%karaf_home%/web/vm/hello.vm中包含一个资源,就必须使用#include("/web/vm/hello.vm")

票数 0
EN

Stack Overflow用户

发布于 2017-06-15 06:23:03

您需要指定引用Karaf主目录的文件位置。

你应该用

代码语言:javascript
复制
 <to uri="velocity:file:${karaf.home}/web/vm/webpage.vm?contentCache=false"/>

更多详细信息见:http://camel.apache.org/using-propertyplaceholder.html

票数 1
EN

Stack Overflow用户

发布于 2021-03-03 15:26:01

尽管得到了一个公认的答案,但我认为对于其他人来说,如果他不幸运地在Karaf中使用Apache Camel,那么在他的模板中如何使用#include或#解析是有用的。

主要思想是指定速度的TEMPLATE_ROOT,如果您的路线使用XML,我所知道的唯一方法就是使用propertiesFile选项

代码语言:javascript
复制
<to uri="velocity:file:/home/webpage.vm?propertiesFile=conf/velocity.properties"/>

使用文件velocity.properties

代码语言:javascript
复制
resource.loader = file
file.resource.loader.path = /opt/templates

请注意,此路径必须是绝对的。因为在那里使用字符串文本不太方便,所以您甚至可以使用空值的属性。

代码语言:javascript
复制
resource.loader = file
file.resource.loader.path =

并通过例如exchange属性或标头传递实际模板路径(相对于该值或绝对(如果为空)。

代码语言:javascript
复制
#parse(${exchange.properties.templatePath})

在这种情况下,您可以使用例如属性占位符,因此路径不必硬编码。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44531340

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档