目前我正在开发我的第一个Google App Engine应用程序。我使用Jersey(JAX-RS)和JSP 2.0与自定义标记的组合来将应用程序逻辑与布局分开。Google App Engine + Jersey + JSP结果NOT_FOUND
我创建的应用程序在本地沙箱中运行得很好(使用Maven appengine:devserver开始),但是当我在Google上运行完全相同的代码时,出现同一调用的“错误:NOT_FOUND”错误。 GAE上的日志说:
2013-04-12 12:37:38.520 /rest/home 404 ...
2013-04-12 12:37:34.034
com.sun.jersey.api.core.PackagesResourceConfig init: Scanning for root resource and provider classes in the packages:
xxx.rest
2013-04-12 12:37:34.308
com.sun.jersey.api.core.ScanningResourceConfig logClasses: Root resource classes found:
class xxx.rest.HomeResource
2013-04-12 12:37:34.308
com.sun.jersey.api.core.ScanningResourceConfig init: No provider classes found.
2013-04-12 12:37:34.619
com.sun.jersey.server.impl.application.WebApplicationImpl _initiate: Initiating Jersey application, version 'Jersey: 1.17.1 02/28/2013 12:47 PM'
2013-04-12 12:37:38.422
xxx.rest.HomeResource <init>: HomeResource constructor
2013-04-12 12:37:38.427
xxx.rest.HomeResource displayHomepage: Display home
最后两行显示HomeResource存在并且它被调用。它看起来像这样:
@Path("/home")
public class HomeResource {
private Log log = LogFactory.getLog(HomeResource.class);
public HomeResource() {
log.info("HomeResource constructor");
}
@GET
@Produces(MediaType.TEXT_HTML)
public Response displayHomepage() {
log.info("Display home");
return Response.ok(new Viewable("/home")).build();
//return new Viewable("/home");
}
}
的JSP文件位于WEB-INF/views
和WEB-INF/tags
自定义代码,如web.xml
规定:
<servlet>
<servlet-name>Test</servlet-name>
<servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>com.sun.jersey.config.property.packages</param-name>
<param-value>xxx.rest</param-value>
</init-param>
<init-param>
<param-name>com.sun.jersey.config.property.JSPTemplatesBasePath</param-name>
<param-value>/WEB-INF/views/</param-value>
</init-param>
<init-param>
<param-name>com.sun.jersey.config.property.WebPageContentRegex</param-name>
<param-value>/(img|js|css|(WEB-INF/tags)|(WEB-INF/views))/.*</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Test</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>
标签的位置在JSP作为指定:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="t" tagdir="/WEB-INF/tags" %>
这应该是正确的,因为JSP编译没有问题。
请问我可以帮我解决这个问题吗?提前感谢!
编辑: 它似乎与JSP模板的位置有关。当我将Viewable
替换为静态String
时,所有功能都按预期工作。如何引用WEB-INF/views
中的JSP?
我最初的猜测是你的应用程序在你的dev和appengine环境中部署了不同的上下文路径,因此,URL是不同的 – NilsH
@NilsH这怎么改变URL呢?该日志显示资源在那里,并且资源中正确的方法被调用。还是它改变了其他途径之一? – joost1024
我认为你在执行控制器后关于视图解析的权利。你可以调整日志级别以提供更多的输出吗?当它工作时,你使用了什么字符串? – NilsH