请求方法“POST”不受支持。 500内部服务器ERRor Spring-boot

时间:2017-02-27 06:41:55

标签: spring spring-mvc spring-boot spring-web

我正在为我的网络服务编写一个新的API。我已经尝试了与此相关的所有其他stackoverflow链接。但问题仍然存在。

问题是: 当我尝试使用:

命中我的spring-boot应用程序时
curl -v -XPOST http://localhost:9081/postpayment/v1/invoice/djhbjsd/send

我得到以下回复:

 Trying ::1...
 Connected to localhost (::1) port 9081 (#0)
 POST /postpayment/v1/invoice/djhbjsd/send HTTP/1.1
 Host: localhost:9081
 User-Agent: curl/7.43.0
 Accept: */*

 HTTP/1.1 500 Internal Server Error
 Server: Apache-Coyote/1.1
 Content-Type: application/json;charset=UTF-8
 Transfer-Encoding: chunked
 Date: Mon, 27 Feb 2017 06:21:43 GMT
 Connection: close

 Closing connection 0
 {"timestamp":1488176503569,"status":500,"error":"Internal Server Error","exception":"org.springframework.web.HttpRequestMethodNotSupportedException","message":"Request method 'POST' not supported","path":"/postpayment/v1/invoice/djhbjsd/send"}

我的控制器是:

@RestController
public class PostPaymentApiController {


     @ResponseBody
     @RequestMapping(value = "/postpayment/v1/invoice/{invoiceGUID}/send", method = RequestMethod.POST)
     public ResponseEntity<String> sendPaymentConfirmation(
        @PathVariable("invoiceGUID") String invoiceGUID) throws Exception {

        try {
           //logic

        } catch (Exception e) {

            LOGGER.error(invoiceGUID+" Error in sending payment confirmation",e);
            return new ResponseEntity<String>(invoiceGUID+" "+e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
        }

        return new ResponseEntity<String>(invoiceGUID+" payment confirmation sent successfully",HttpStatus.OK);
     }

}

日志错误:

: Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request method 'POST' not supported] with root cause
org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'POST' not supported
at org.springframework.web.servlet.support.WebContentGenerator.checkRequest(WebContentGenerator.java:301) ~[spring-webmvc-4.2.4.RELEASE.jar:4.2.4.RELEASE]
at org.springframework.web.servlet.resource.ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:229) ~[spring-webmvc-4.2.4.RELEASE.jar:4.2.4.RELEASE]
at org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:51) ~[spring-webmvc-4.2.4.RELEASE.jar:4.2.4.RELEASE]
at org.springframework.boot.actuate.autoconfigure.EndpointWebMvcChildContextConfiguration$CompositeHandlerAdapter.handle(EndpointWebMvcChildContextConfiguration.java:266) ~[spring-boot-actuator-1.3.2.RELEASE.jar:1.3.2.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:959) ~[spring-webmvc-4.2.4.RELEASE.jar:4.2.4.RELEASE]

还有一件事。我正在对管理端口做出以下回应。当我点击服务器端口时,我得到404.My application.yml包含:

    server.port: 9080
    management.port: 9081 

1 个答案:

答案 0 :(得分:0)

你的休息控制器包括@Configuration和处理程序方法包括@RestponseBody,这在@RestController中是不必要的,所以从你的控制器中删除@Configuration和@ResponseBody