我一直在努力纠正http错误415 Unsupported Media Type
,但它仍然显示媒体不受支持的页面。
我在Postman中添加标题application/json
。
这是我的Java代码
package lostLove;
import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import org.json.JSONObject;
@Path("/Story")
public class Story {
@POST
@Consumes({"application/json"})
@Produces(MediaType.APPLICATION_JSON)
// @Consumes(MediaType.APPLICATION_JSON)
// @Path("/Story")
public JSONObject sayJsonTextHello(JSONObject inputJsonObj) throws Exception {
String input = (String) inputJsonObj.get("input");
String output = "The input you sent is :" + input;
JSONObject outputJsonObj = new JSONObject();
outputJsonObj.put("output", output);
return outputJsonObj;
}
@GET
@Produces(MediaType.TEXT_PLAIN)
public String sayPlainTextHello() {
return "hello";
}
}
这是我的web.xml
文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>LostLove</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<servlet>
<servlet-name>Jersey REST Service</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>lostLove</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Jersey REST Service</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>
</web-app>
答案 0 :(得分:15)
我们的对象如何在响应流和请求流中进行序列化和反序列化,是通过MessageBodyWriter
s和MessageBodyReader
s。
将会发生的搜索将从提供商的注册表中进行,以便处理JSONObject
和媒体类型application/json
。如果找不到,则Jersey无法处理该请求,并将发送415 Unsupported Media Type。您通常也应该在服务器端记录异常。不确定你是否有机会查看日志。
泽西岛没有org.json
对象的标准读者/作者。您必须在网上搜索实现或自己编写一个,然后注册它。您可以详细了解如何实施它here。
或者,您可以接受String并返回String。只需使用字符串参数构造JSONObject
,并在返回时调用JSONObject.toString()
。
@POST
@Consumes("application/json")
@Produces("application/json")
public String post(String jsonRequest) {
JSONObject jsonObject = new JSONObject(jsonRequest);
return jsonObject.toString();
}
我的建议是使用像Jackson这样的数据绑定框架,它可以处理模型对象(简单的POJO)的序列化和反序列化。例如,您可以拥有类似
的类public class Model {
private String input;
public String getInput() { return input; }
public void setInput(String input) { this.input = input; }
}
您可以将Model
作为方法参数
public ReturnType sayJsonTextHello(Model model)
ReturnType
相同。只需为您要返回的类型创建一个POJO。 JSON属性基于JavaBean属性名称(遵循上面显示的命名约定的getter / setter)。
要获得此支持,您可以添加此Maven依赖项:
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-json-jackson</artifactId>
<version>2.17</version> <!-- make sure the jersey version
matches the one you are using -->
</dependency>
或者,如果您不使用Maven,您可以看到this post,您可以单独下载这些罐子。
部分资源:
答案 1 :(得分:0)
由于以下问题:
JAX-RS不支持默认的Jackson映射转换。所以如果你有如下的ajax请求(Post):
jQuery.ajax({
url: "http://localhost:8081/EmailAutomated/rest/service/save",
type: "POST",
dataType: "JSON",
contentType: "application/JSON",
data: JSON.stringify(data),
cache: false,
context: this,
success: function(resp){
// we have the response
alert("Server said123:\n '" + resp.name + "'");
},
error: function(e){
alert('Error121212: ' + e);
}
});
在JAX-RS控制器方面,您需要执行以下操作:
@Path("/save")
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.TEXT_PLAIN)
public String saveDetailsUser(String userStr) {
Gson gson = new Gson();
UserDetailDTO userDetailDTO = gson.fromJson(userStr, UserDetailDTO.class);
String vemail = userDetailDTO.getEMAIL();
return "userDetailDTO";
}
请在参数上确认。 service接受json为String而不是POJO。
当然会有效。谢谢!
答案 2 :(得分:0)
如果客户端发送HTTP / 1.1请求,例如在HTTP / 2中使用Jersey与HTTP / 2时,我遇到了同样的问题。使用Jersey客户端,就可以正常工作。
如果我切换到Jetty HTTP2客户端来发送相同的内容,则会得到415。
我使用的临时解决方案是Paul Samsotha所描述的替代方案,即“接受字符串并返回字符串”,然后手动将字符串反序列化为POJO。