4

我正在努力做到这一点,以便我的 Spring rest 应用程序可以同时处理 xml 和 json 响应,但似乎添加 Jaxb 消息转换器破坏了我的 json 映射。

@Bean
public MappingJackson2HttpMessageConverter jsonConverter() {
    MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();
    SimpleModule simpleModule = new SimpleModule();
    simpleModule.addSerializer(String.class, new StringSerializer());
    ObjectMapper mapper = new ObjectMapper()
        .registerModule(simpleModule);
    converter.setObjectMapper(mapper);
    return converter;
}

@Bean
public Jaxb2RootElementHttpMessageConverter jaxbConverter() {
    return new Jaxb2RootElementHttpMessageConverter();
}

@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
    converters.add(jsonConverter());
    converters.add(jaxbConverter());
}

如果我在那里注释掉第二种和第三种方法,一切都会重新开始工作(当然除了 xml 映射!)。但是,有了这些,我就搞砸了,比如在 中序列化List<String>结果[APPLEORANGEBANANA],其中 apple、orange 和banana 在列表中是单独的字符串。

如果我直接使用jackson对象映射器映射到json,就没有这个问题,但是使用@ResponseBody注解自动序列化到json我就有这个问题了。

有人有想法么?

4

4 回答 4

5

我就是这样做的。

@RequestMapping(method = RequestMethod.GET, value = "/accounts/{accountId}", produces = {APPLICATION_XML_VALUE, APPLICATION_JSON_VALUE})
@ResponseBody
@ResponseStatus(value = HttpStatus.OK)
public Account getAccount(@PathVariable String accountId) {
    return new Account(); // populate Account VO and send
}

并在 XML 文件中

<mvc:annotation-driven content-negotiation-manager="contentNegotiationManager" >
    <mvc:message-converters register-defaults="false">
       <ref bean="xmlConverter"/>
       <ref bean="jsonConverter"/>
    </mvc:message-converters>
</mvc:annotation-driven> 

 <!-- XML MessageConverter -->
 <bean id="xmlConverter" class="org.springframework.http.converter.xml.MarshallingHttpMessageConverter">
  <constructor-arg ref="jaxbMarshaller"/>
  <property name="supportedMediaTypes" value="application/xml" />
 </bean> 

<!-- JSON MessageConverter -->
 <bean id="jsonConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
 </bean>

<!-- JAXB Classes to be marshalled -->
<bean id="jaxbMarshaller" class="org.springframework.oxm.jaxb.Jaxb2Marshaller">
    <property name="packagesToScan">
   <list>
    <value>com.test.*</value>
    <value>com.*.test</value>
  </list>
  </property>
</bean>
于 2013-09-06T05:30:21.567 回答
0

我删除了configureMessageConverters它,它自动拾取了两个转换器,都没有问题。

于 2013-09-06T06:17:03.223 回答
0

当您覆盖 configureMessageConverters 时,它不会添加默认消息转换器。试试下面的代码。

@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
    converters.add(jsonConverter());
    converters.add(jaxbConverter());
    super.addDefaultHttpMessageConverters();
}
于 2019-05-16T07:50:21.867 回答
0

发生在我身上也是一样的。两次:-)

在一种情况下,converters.clear()添加我的转换器之前的一个简单的方法解决了这个问题。看起来 Spring 默认添加了一些转换器。使用 XML 注入它们会删除 Spring 隐式设置的一个,而从代码中显式添加它们则不会。

在另一种情况下,问题是在请求中设置了正确的标头,即content-typeand accept。然后,在请求映射中,我必须指定“consumes”和“produces”参数,分别映射两个标头。

public class MyRequestHandler {
     ...

     @RequestMapping(... , consumes={ MediaType.APPLICATION_JSON_VALUE, produces = { MediaType.APPLICATION_JSON_VALUE } }
     public ResponseEntity<MyResultClass> doSomething(...) { ... }

     ...
}

这为我解决了这个问题。

于 2015-09-24T10:39:38.387 回答