web-dev-qa-db-fra.com

État HTTP 415 - Impossible de consommer le type de contenu

Opération POST vers le service REST avec retour du corps JSON

org.jboss.resteasy.spi.UnsupportedMediaTypeException

: Impossible de consommer l'exception de type de contenu

@Consumes(MediaType.APPLICATION_JSON) et @Consumes("application/json") ont renvoyé la même exception.

J'ai essayé d'appeler le service à l'aide du client API Postman.

image

@RolesAllowed("admin")
@POST   
@Consumes(MediaType.APPLICATION_JSON)
@Path("/auth")
public Response login(UserCl usr){

    if(usr.getUsername().compareTo("user") == 0 && 
                usr.getPassword().compareTo("pass") == 0){                      
        return Response.status(200).build(); 
    }
    else{
        return Response.status(401).build();
    }

}

12:44:07,322 WARN  [org.jboss.resteasy.core.SynchronousDispatcher] (http-localhost-127.0.0.1-8080-1) Failed executing POST user-service/auth: org.jboss.resteasy.spi.UnsupportedMediaTypeException: Cannot consume content type
    at org.jboss.resteasy.core.registry.Segment.match(Segment.Java:117) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.registry.SimpleSegment.matchSimple(SimpleSegment.Java:33) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.registry.RootSegment.matchChildren(RootSegment.Java:327) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.registry.SimpleSegment.matchSimple(SimpleSegment.Java:44) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.registry.RootSegment.matchChildren(RootSegment.Java:327) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.registry.RootSegment.matchRoot(RootSegment.Java:374) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.registry.RootSegment.matchRoot(RootSegment.Java:367) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.ResourceMethodRegistry.getResourceInvoker(ResourceMethodRegistry.Java:307) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.SynchronousDispatcher.getInvoker(SynchronousDispatcher.Java:173) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.Java:118) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.Java:208) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.Java:55) [resteasy-jaxrs-2.3.2.Final.jar:]
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.Java:50) [resteasy-jaxrs-2.3.2.Final.jar:]
    at javax.servlet.http.HttpServlet.service(HttpServlet.Java:847) [jboss-servlet-api_3.0_spec-1.0.0.Final.jar:1.0.0.Final]
    at org.Apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.Java:329) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.Java:248) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.Java:275) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.catalina.core.StandardContextValve.invoke(StandardContextValve.Java:161) [jbossweb-7.0.13.Final.jar:]
    at org.jboss.as.web.security.SecurityContextAssociationValve.invoke(SecurityContextAssociationValve.Java:153) [jboss-as-web-7.1.1.Final.jar:7.1.1.Final]
    at org.Apache.catalina.core.StandardHostValve.invoke(StandardHostValve.Java:155) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.Java:102) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.Java:109) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.Java:368) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.coyote.http11.Http11Processor.process(Http11Processor.Java:877) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.Java:671) [jbossweb-7.0.13.Final.jar:]
    at org.Apache.Tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.Java:930) [jbossweb-7.0.13.Final.jar:]
    at Java.lang.Thread.run(Thread.Java:745) [rt.jar:1.7.0_79]
17
AvenashKrish

Vous n'avez pas défini le Content-Type entête. Je ne me souviens pas de la valeur par défaut, mais vous pouvez regarder dans les outils de développement Chrome pour voir la demande complète avec des en-têtes.

Le JSON La valeur dans la liste déroulante est uniquement destinée à la coloration syntaxique. Il ne définit pas réellement l'en-tête. Il suffit donc d'ajouter l'en-tête

Content-Type   ->>   application/json
27
Paul Samsotha