DELETE,以及
GET请求不应具有有效负载(实体)。我不知道是否在任何地方指定此名称,但是您可以在此处查看讨论。
这就是原因
400 BadRequest(对于GET也会发生)。摆脱它,它将起作用。但是无论如何,甚至不需要发送该正文,就像您一样,只有信息是
id,该信息已经包含在URL路径中。
如果仅是示例,并且您需要与请求一起发送其他一些任意信息,则使用查询参数,例如
/app/rest/user/user4?some=value1&other=value2&data=value3 public String deleteUser(@PathParam("id") final String id, @QueryParam("some") String some, @QueryParam("other") String other, @QueryParam("data") String data) {}
使用jQuery,您可以做到
var params = { some:"valeu1", other:"value2", data:"value3"}var enpred = $.param(params);var url = baseUrl + "?" + enpred;$.ajax({ url: url, ...})
更新
因此,经过一些调查,这似乎是一个灰熊问题。我已经对Jetty进行了测试,并且效果很好。
看到类似的问题
- 在这里 -最后的评论说它是固定的,但是我无法提供一个可行的例子
- 这里
因此,如@alexey在下面的评论中所述
没错,默认情况下,Grizzly不允许HTTP方法的有效负载,而HTTP规范对此并未明确说明。像HTTP
GET,DELETE和HEAD。但是您可以通过调用以下方式打开支持:httpServer.getServerConfiguration().setAllowPayloadForUndefinedHttpMethods(true);请不要在开始之前调用该方法HttpServer
所以解决办法是做类似
public static HttpServer createServer() { final ResourceConfig rc = new ResourceConfig(); rc.packages(true, "app"); rc.register(ResponseCorsFilter.class); HttpServer server = GrizzlyHttpServerFactory.createHttpServer( URI.create(base_URI), rc, false); server.getServerConfiguration().setAllowPayloadForUndefinedHttpMethods(true); return server;}public static void main(String[] args) throws IOException { final HttpServer server = createServer(); server.start(); System.out.println(String.format("Jersey app started with WADL available at " + "%sapplication.wadlnHit enter to stop it...", base_URI)); System.in.read(); server.stop();}
经过测试,可以正常工作。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)