2017-08-08 356 views
0

我正在使用Jersey的rest API。我需要添加一個@PUT方法,但它會引發異常。HTTP狀態500 - servlet jersey-servlet的Servlet.init()拋出異常當我添加@PUT方法

這是我想現在就加入方法:

@Path("/login") 
public class LoginController { 
... 
    @PUT 
    @Path("/user") 
    @Consumes("application/json;charset=utf-8") 
    @Produces("application/json;charset=utf-8") 
    public String putUser(@QueryParam("user")LoginUser lu) { 
     return "login failed"; 
    } 
... 
} 

在現實中存在的方法的詳細內容,但內容並不重要。當此方法的類存在,我得到試圖訪問服務器時,以下異常:

javax.servlet.ServletException: Servlet.init() for servlet jersey-servlet threw exception 
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) 
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) 
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1041) 
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:603) 
    org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) 
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    java.lang.Thread.run(Thread.java:748) 
root cause 

com.sun.jersey.spi.inject.Errors$ErrorMessagesException 
    com.sun.jersey.spi.inject.Errors.processErrorMessages(Errors.java:170) 
    com.sun.jersey.spi.inject.Errors.postProcess(Errors.java:136) 
    com.sun.jersey.spi.inject.Errors.processWithErrors(Errors.java:199) 
    com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:795) 
    com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:790) 
    com.sun.jersey.spi.container.servlet.ServletContainer.initiate(ServletContainer.java:509) 
    com.sun.jersey.spi.container.servlet.ServletContainer$InternalWebComponent.initiate(ServletContainer.java:339) 
    com.sun.jersey.spi.container.servlet.WebComponent.load(WebComponent.java:605) 
    com.sun.jersey.spi.container.servlet.WebComponent.init(WebComponent.java:207) 
    com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:394)`enter code here` 
    com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:577) 
    javax.servlet.GenericServlet.init(GenericServlet.java:160) 
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) 
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) 
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1041) 
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:603) 
    org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) 
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    java.lang.Thread.run(Thread.java:748) 

還有其他@PUT方法的類,因爲他們應該,但是當我加入這個新的,一切工作停止工作。

這是我的web.xml文件的內容:

<!DOCTYPE web-app PUBLIC 
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" 
"http://java.sun.com/dtd/web-app_2_3.dtd" > 

<web-app> 
    <display-name>REST API</display-name> 

    <servlet> 
    <servlet-name>jersey-servlet</servlet-name> 
    <servlet-class> 
     com.sun.jersey.spi.container.servlet.ServletContainer 
    </servlet-class> 
    <load-on-startup>1</load-on-startup> 
    </servlet> 

    <servlet-mapping> 
    <servlet-name>jersey-servlet</servlet-name> 
    <url-pattern>/ws/*</url-pattern> 
    </servlet-mapping> 

</web-app> 

如果我改變@PUT註釋@GET並刪除@Consumes註釋,一切正常。爲什麼我不能添加新的@PUT

+0

如果您只是刪除'@ Consumes'註釋會怎麼樣?它工作嗎? – Nathan

+1

如果你發送的是正文(json)中的LoginUser,你必須刪除@QueryParam(「user」) –

+0

@Nathan否,除非我也將PUT更改爲GET。 –

回答

0

請注意,您發送LoginUser作爲json請求正文,因此您需要刪除@QueryParam("user")

相關問題