Я пытаюсь вернуть ответ JSON с Spring 3.0.6, но я получаю 406 ответ «Не приемлемо» с описанием:
«Ресурс, идентифицированный этим запросом, способен генерировать ответы только с характеристиками
не принимается в соответствии с запросом "accept" headers (). "
Я знаю, что очень похожий вопрос задавался ранее, но я не могу заставить его работать для моего проекта, несмотря на многие
тесты и я не понимаю, что я делаю не так.
В моем Maven pom.xml я имею следующее:
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.8.5</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-asl</artifactId>
<version>1.8.5</version>
<scope>compile</scope>
</dependency>
В web.xml я ссылаюсь на webmvc-config.xml, и журнал подтверждает, что загружен.
<servlet>
<servlet-name>mainServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/webmvc-config.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
В файле webmvc-config.xml есть следующее:
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
<mvc:annotation-driven />
Мой контроллер:
@Controller
public class ClassifiedController {
@RequestMapping(value = "/classified/{idClassified}", headers = "Accept=*/*",
method = RequestMethod.GET)
@ResponseBody
public final Classified getClassified(@PathVariable final int idClassified) {
...
Я пытался с или без параметра заголовков с одинаковыми результатами. Если я позвоню URL
непосредственно в Firefox заголовки запроса содержат следующее (проверено с помощью firebug):
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Если я использую следующий JQuery:
$.ajax({
url: '/classified/38001',
type: 'GET',
dataType: 'json'
});
Отправляются следующие заголовки:
Accept: application/json, text/javascript, */*; q=0.01
В обоих случаях результатом является ошибка 406. Я не знаю, что еще я должен проверить, чтобы сделать
это работает.
ОБНОВЛЕНИЕ : я решил выполнить отладку через Spring и обнаружил, что Джексон был вызван правильно, и в org.codehaus.jackson.map.ser.StdSerializerProvider метод _findExplicitUntypedSerializer содержит следующий код:
try {
return _createAndCacheUntypedSerializer(runtimeType, property);
} catch (Exception e) {
return null;
}
Это прискорбно, потому что скрывает источник проблемы. С помощью отладчика я обнаружил, что это исключение содержит очень описательное сообщение об ошибке:
Conflicting getter definitions for property "reminded":
ClassifiedImpl#isReminded(0 params) vs
ClassifiedImpl#getReminded(0 params)
Теперь, когда я вижу сообщение об ошибке, это глупая ошибка, которую легко исправить, но без этого это было не так очевидно. Фактически, исправление проблемы привело к работающей сериализации.