Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/google-app-engine/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Google app engine 谷歌应用程序引擎上的Jersey 2.2.0。错误404。泽西酒店。不过在本地工作_Google App Engine_Jersey - Fatal编程技术网

Google app engine 谷歌应用程序引擎上的Jersey 2.2.0。错误404。泽西酒店。不过在本地工作

Google app engine 谷歌应用程序引擎上的Jersey 2.2.0。错误404。泽西酒店。不过在本地工作,google-app-engine,jersey,Google App Engine,Jersey,我正在使用jersey 2.2.0 JAR将我的应用程序部署到google应用程序引擎上。我一直在本地开发和运行,并且在本地运行/测试期间运行良好 我部署到google应用程序引擎,开始出现错误:所有资源都有404个错误。检查谷歌日志,在第一次请求时,它会吐出以下内容 org.glassfish.jersey.server.ApplicationHandler初始化:启动jersey应用程序,jersey版本:2.7 2014-03-12 18:11:31 jersey servlet抛出了以下

我正在使用jersey 2.2.0 JAR将我的应用程序部署到google应用程序引擎上。我一直在本地开发和运行,并且在本地运行/测试期间运行良好

我部署到google应用程序引擎,开始出现错误:所有资源都有404个错误。检查谷歌日志,在第一次请求时,它会吐出以下内容

org.glassfish.jersey.server.ApplicationHandler初始化:启动jersey应用程序,jersey版本:2.7 2014-03-12 18:11:31

jersey servlet抛出了以下内容

I 09:27:38.889 org.glassfish.jersey.filter.LoggingFilter日志:1*服务器已收到线程请求EE25C261的请求 收到 接受:text/html、application/xhtml+xml、application/xml;q=0.9,图像/webp,/;q=0.8 接受语言:en-US,en;q=0.8 主持人:xxxxx.appspot.com 用户代理:Mozilla/5.0 Macintosh;英特尔Mac OS X 10_9_2 AppleWebKit/537.36 KHTML,如Gecko Chrome/33.0.1750.152 Safari/537.36 X-AppEngine-City:班加罗尔 X-AppEngine-CitylateLong:12.971599,77.594563 X-AppEngine-Country:位于 X-AppEngine-Region:ka

然后吐出未找到的资源

I 09:41:15.094 org.glassfish.jersey.filter.LoggingFilter日志:3*服务器响应线程请求9826AB68 <404

它还增加了一行建议

I 09:27:39.180此请求导致为您的应用程序启动一个新进程,从而导致首次加载您的应用程序代码。因此,与应用程序的典型请求相比,此请求可能需要更长的时间并使用更多的CPU

现在,所有这些都可以在我的本地测试中使用,但这只是部署到Google App Engine时的一个问题

这是我的web.xml

<?xml version="1.0" encoding="utf-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
  <servlet>
      <servlet-name>Jersey Web Application</servlet-name>
      <servlet-class>
        org.glassfish.jersey.servlet.ServletContainer
      </servlet-class>
      <init-param>
          <param-name>jersey.config.server.provider.packages</param-name>
<!--           Enter your Jersey resources to speed up initial Jersey loading
          You can separate the java packages using , -->
          <param-value>com.poolE.web.rest</param-value>
        </init-param>
        <init-param>
            <param-name>jersey.config.server.provider.classnames</param-name>
            <param-value>org.glassfish.jersey.filter.LoggingFilter</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
      <servlet-name>Jersey Web Application</servlet-name>
      <url-pattern>/service/*</url-pattern>
    </servlet-mapping>
    <system-properties>
        <property name="java.util.logging.config.file" value="WEB-INF/logging.properties" />
    </system-properties>
</web-app>

任何帮助都将不胜感激。我被困在这个令人沮丧的问题中,就是在GAE中把所有的东西都放在一起

我对泽西以及它如何匹配一无所知。但我猜@Path/users/不会匹配http://xxxx.appspot.com/service/users/test -具体测试您是否尝试过/服务/用户/其他一切看起来都是正确的。我的意思是所有的日志消息看起来都是正确的。但是info方法用@Pathtest注释,所以看起来很好。感谢您的关注。正如我试图在上面提到的。。它在我的本地电脑上运行良好。这与谷歌应用程序引擎生产环境有关。。jersey在本地应用程序引擎构建环境中工作时,无法在该环境中查找已配置的web资源GAE env上运行正常吗?例如index.html站点?为了解决这个问题,我将其降级到jersey 1.18。之后也出现了一些问题,因此必须创建一个应用程序类来注册我的jersey资源
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;

import com.poole.web.jpa.EMFService;
import com.poole.web.jpa.Users;
import com.poole.web.jpa.model.User;

@Path("/users/")
public class UsersResource {

    private static final Logger log = Logger.getLogger(UsersResource.class.getName());

    @GET
    @Produces("application/json")
    @Path("test")
    public String info() {
        log.info("comes into test");
        return "Hello Jersey on Google App Engine";
    }

}