【发布时间】:2015-01-09 15:02:15
【问题描述】:
所以....
我已经能够配置一个 RestEasy 服务并让它在我的 Windows 8 上的 Eclipse 中工作,但是当我将它部署到安装在 Ubuntu 上的 Tomcat 7 上时它不起作用!
当我在 Eclipse 上启动我的 tomcat 时,我收到了消息:
信息:启动 Servlet 引擎:Apache Tomcat/7.0.29
nov. 12, 2014 年下午 4:00:06 org.apache.catalina.core.ApplicationContext 日志
信息:初始化 Spring 根 WebApplicationContext
nov。 12, 2014 下午 4:00:07 org.apache.catalina.core.ApplicationContext 日志
信息:初始化 Spring FrameworkServlet 'MessageBrokerServlet'
[INFO] 2014-11-12 16:00:08,001 org.jboss.resteasy.spi.ResteasyDeployment - 部署 javax.ws.rs.core.Application:类 fr .mycompany.myproject.MarkersApplication
但最后一行不在 ubuntu 上的 tomcat 服务器的日志中 => 因此,当我调用我的 Rest 服务(通过 javascript /jsapi)时,我收到了这条消息:
GRAVE: "Servlet.service()" pour la servlet RESTEasy JSAPI a généré une exception
java.lang.NullPointerException
at org.jboss.resteasy.jsapi.JSAPIWriter.generateEtag(JSAPIWriter.java:111)
at org.jboss.resteasy.jsapi.JSAPIWriter.writeJavaScript(JSAPIWriter.java:36)
at org.jboss.resteasy.jsapi.JSAPIServlet.service(JSAPIServlet.java:73)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1002)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:745)
null(我想)是 generateEtag() 方法的serviceRegistries,它在 Eclipse Tomcat 中启动时使用我的 RestService 填充。
我不知道为什么 ResteasyServletInitializer 会启动/初始化,所以如果有人遇到这种情况(以及解决方案 ^^),请帮助我 T_T
这是我使用的配置:
申请声明:
@ApplicationPath("/resteasy")
public class MarkersApplication extends Application {
}
服务:
@Path("/markersRest")
public class MarkersRest {
@Context
private ServletContext context;
private DataService getService() {
return WebApplicationContextUtils.getWebApplicationContext(context).getBean(DataService.class);
}
@POST
@Produces(MediaType.TEXT_PLAIN)
public Response getMarkers(@QueryParam("keyCache") String keyCache) {
String markers = getService().getCachedMarkers(keyCache);
return Response.ok().entity(markers).build();
}
}
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_3_0.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0" metadata-complete="true">
<display-name>MyProject</display-name>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:/spring/spring-config.xml</param-value>
</context-param>
<context-param>
<param-name>resteasy.servlet.mapping.prefix</param-name>
<param-value>/resteasy</param-value>
</context-param>
<!-- ************************ -->
<!-- ******* LISTENERS ****** -->
<!-- ************************ -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<listener>
<listener-class>flex.messaging.HttpFlexSession</listener-class>
</listener>
<!-- ************************ -->
<!-- ******* SERVLETS ******* -->
<!-- ************************ -->
<servlet>
<servlet-name>MessageBrokerServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:/spring/spring-flex-config.xml</param-value>
</init-param>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>MessageBrokerServlet</servlet-name>
<url-pattern>/messagebroker/*</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>RESTEasy JSAPI</servlet-name>
<servlet-class>org.jboss.resteasy.jsapi.JSAPIServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RESTEasy JSAPI</servlet-name>
<url-pattern>/rest-js</url-pattern>
</servlet-mapping>
</web-app>
pom.xml:
...
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-servlet-initializer</artifactId>
<version>3.0.9.Final</version>
</dependency>
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-jsapi</artifactId>
<version>3.0.9.Final</version>
</dependency>
...
和文件/WEB-INF/services/javax.servlet.ServletContainerInitializer
内容org.jboss.resteasy.plugins.servlet.ResteasyServletInitializer
【问题讨论】:
-
"和文件 /WEB-INF/services/javax.servlet.ServletContainerInitializer 内容为 org.jboss.resteasy.plugins.servlet.ResteasyServletInitializer" - 据我所知,它没有'看起来这部分根本没有做任何事情..