我正在为我的网络服务编写一个新的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
答案 0 :(得分:0)
你的休息控制器包括@Configuration和处理程序方法包括@RestponseBody,这在@RestController中是不必要的,所以从你的控制器中删除@Configuration和@ResponseBody