2013-04-12 45 views
0

目前我正在开发我的第一个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/viewsWEB-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?

+0

我最初的猜测是你的应用程序在你的dev和appengine环境中部署了不同的上下文路径,因此,URL是不同的 – NilsH

+0

@NilsH这怎么改变URL呢?该日志显示资源在那里,并且资源中正确的方法被调用。还是它改变了其他途径之一? – joost1024

+0

我认为你在执行控制器后关于视图解析的权利。你可以调整日志级别以提供更多的输出吗?当它工作时,你使用了什么字符串? – NilsH

回答

2

我终于破解了它......它确实与Viewable中的路径有关。我把它改为:

@Path("/hello") 
public class HelloResource { 

    @GET 
    @Produces(MediaType.TEXT_HTML) 
    public Response displayHello() { 
     return Response.ok(new Viewable("/views/hello")).build(); 
    } 

} 

而且我感动包含JSP来的WEB-INFviews文件夹,并从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> 
    <load-on-startup>1</load-on-startup> 
</servlet> 

<servlet-mapping> 
    <servlet-name>Test</servlet-name> 
    <url-pattern>/rest/*</url-pattern> 
</servlet-mapping> 

现在它就像一个魅力!