Jersey 中的 JSON 序列化 - 如何忽略 XmlJavaTypeAdapter 来序列化地图?
在我的基于 Jersey 的 REST Web 服务中,我需要提供 xml 和 json 输出。类 Result 有一个映射,用 XmlJavaTypeAdapter 进行注释,以将其正确序列化为 xml。
@XmlRootElement
public class Result {
private Map<String,Integer> results = new HashMap<String, Integer>();
public Result(){}
@XmlJavaTypeAdapter(ResultMapAdapter.class)
public Map<String,SearchResult> getResults() {
return results;
}
}
XML 输出如下所示:
<results>
<result><name>Key1</name><value>Value1</value>
<result><name>Key2</name><value>Value2</value>
</results>
json 输出如下所示
"result":[{
"name": "Key1",
"value": Value1
},{
"name": "Key2",
"value": Value2
}]
但我希望它看起来像:
"result":{
"Key1": Value1,
"Key2": Value2
}
如果删除 XMlRootElement 和 XmlJavaTypeAdapter 注释,则 json 输出看起来像我想要的,但 xml 序列化失败。有解决方法吗?
In my Jersey-based REST webservice I need to provide xml and json output. The class Result has a map, annotated with XmlJavaTypeAdapter to correctly serialize it to xml.
@XmlRootElement
public class Result {
private Map<String,Integer> results = new HashMap<String, Integer>();
public Result(){}
@XmlJavaTypeAdapter(ResultMapAdapter.class)
public Map<String,SearchResult> getResults() {
return results;
}
}
The XML output looks like:
<results>
<result><name>Key1</name><value>Value1</value>
<result><name>Key2</name><value>Value2</value>
</results>
And the json output looks like
"result":[{
"name": "Key1",
"value": Value1
},{
"name": "Key2",
"value": Value2
}]
But I want that it looks like:
"result":{
"Key1": Value1,
"Key2": Value2
}
If I remove the XMlRootElement and the XmlJavaTypeAdapter annotation, the json output looks like I wanted, but then the xml serialization failed. Is there a workaround?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
一种可能的解决方案是使用自定义 ObjectMapperProvider。以下提供程序不会为 json 和 xml 创建组合映射器。所以json序列化不使用xml注释。
当然这个溶胶的缺点
One possible solution is the use an custom ObjectMapperProvider. The Following provider doesn't create an combined mapper for json and xml. So the json serialization doesn't use the xml annoatation.
Of course the disadvantage of this sol