Подтвердить что ты не робот

Spring Не разрешается Json с соответствующим ответом

Я попытался иметь контроллер в Spring, чтобы вернуть ответ JSON безрезультатно, используя классы Jackson, как рекомендуется с 3.0. Конечно, у меня есть файлы json json (jackson-core-asl-1.5.5.jar и jackson-mapper-asl-1.5.5.jar) в моем классе.

Что касается записей appconfig.xml, я не уверен, что мне это нужно. Я поставил их там как последний акт отчаяния, прежде чем вернуться к модной не-json ajax.

В отладке я наблюдаю, как контроллер получает запрос, возвращает foo, а затем, в firebug, получает 406.

Сообщения об ошибках выглядят следующим образом: Из регистратора при настройке для отладки: org.springframework.web.HttpMediaTypeNotAcceptableException: не удалось найти приемлемое представление

Из ответа: (406) Ресурс, идентифицированный этим запросом, способен генерировать ответы с характеристиками, неприемлемыми в соответствии с запросом "принять" заголовки().

Мой appconfig.xml находится здесь:

    <!-- Configures support for @Controllers -->
    <mvc:annotation-driven />

    <!-- Resolves view names to protected .jsp resources within the /WEB-INF/views directory -->
    <bean class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">
  <property name="mediaTypes">
    <map>
      <entry key="html" value="text/html"/>
      <entry key="json" value="application/json"/>
    </map>
  </property>
  <property name="viewResolvers">
    <list>
      <bean class="org.springframework.web.servlet.view.BeanNameViewResolver"/>
      <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/views/"/>
        <property name="suffix" value=".jsp"/>
      </bean>
    </list>
  </property>
  <property name="defaultViews">
    <list>
      <bean class="org.springframework.web.servlet.view.json.MappingJacksonJsonView" />
    </list>
  </property>
</bean>
    <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
    <property name="basename" value="messages"></property>
    </bean>

Мой контроллер

@RequestMapping(value="foo/bar", method=RequestMethod.GET)
public @ResponseBody foo getFoo(@RequestParam String fooId) {
    return new foo(fooId); 
}

В jsp, где выполняется вызов ajax:

function addRow() {
$.getJSON("foo/bar",{ fooId: 1} , function(data) {
alert("it worked.");        
});

}

Сообщите мне, если вам нужна дополнительная информация.

4b9b3361

Ответ 1

Избавьтесь от всего Jackson beans и от json-отображения в переговорном резольвере. mvc:annotation-driven должен настроить все, что вам нужно для сериализации Джексона, чтобы работать.

Ответ 2

  • Убедитесь, что POJO, который вы возвращаете, имеет(), один для каждого поля.
  • Убедитесь, что у сервера приложений (Tomcat) есть библиотеки, даже если вы уверены, что ваша система сборки (Eclipse/Maven) делает.

У меня была эта ошибка дважды. Только теперь я добавил геттеры к моему pojo. Ошибка 406 исчезла, и я получил JSON, как ожидалось. Я предполагаю, что, поскольку мои поля были защищены от пакетов (доступ по умолчанию), он будет захватывать их, но я думаю, что нет. Для записи, если это имеет значение, я также сделал POJO для реализации Serializable, toString(), serialVersionUID, конструктора no-arg и явных конструкторов.

В предыдущее время я очистил/очистил/обновил свой кеш Tomcat и сделал все возможное, чтобы заставить его перезагрузить. Я полагаю, что когда я добавил зависимости Jackson, он исправил мои ошибки времени компиляции, но, поскольку tomcat пропустил их, во время выполнения Spring MVC не обнаружил библиотеки Jackson и произвел ошибку 406 о неприемлемом типе ответа.

Ответ 3

Кроме того, убедитесь, что вы добавили два файла jar, связанные с jackson.

  • jackson-core-asl-1.9.8.jar
  • jackson-mapper-asl-1.9.8.jar

Версия может быть разной.

Ответ 4

Я знаю, что это старый поток, но, возможно, кто-то столкнется с той же проблемой, что и я. Я получил это исключение при переносе приложения из Spring 4.0.3.RELEASE в Spring 4.1.0.RELEASE. В моем случае обновление Джексона с 1.9.x до 2.4.x сделало трюк.

Ответ 5

Отправка заголовка Accept: application/xml не работает. Но отправьте Accept: application/json на самом деле работает, и джексон-карпп начинает работать. Я избавился от своего 406 и получил свой сериализованный java-объект в json-формате с не более конфигурацией, чем @ResponseBody, и возвратил новый MyObject() :) Спасибо skaffman за эту информацию и спасибо Bozho за значение рабочего заголовка: D

Ответ 6

Этот вопрос появляется повсюду в сети, и я его кусаю пару раз. Spring 3.0.6 (и 5 возможно) имеет некоторые проблемы при рендеринге json. Как только я изменил версию 3.1.0.RELEASE, eveyrything работал AS IS. Без каких-либо изменений конфигурации. Следует отметить, что метод return должен иметь @ResponseBody (как в примере выше) и должен находиться в файле servlet-context.xml или в файле конфигурации контекста Spring.

Ответ 7

У меня такое же исключение при переходе с spring 3.x на spring 4.x.

Я решил это с обновлением зависимостей jackson от

    <dependency>
        <groupId>org.codehaus.jackson</groupId>
        <artifactId>jackson-mapper-asl</artifactId>
        <version>1.9.13</version>
    </dependency>

к

    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>2.5.1</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.5.1</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-annotations</artifactId>
        <version>2.5.1</version>
    </dependency>

Мне ничего больше не понадобилось.

Ответ 8

Может быть, мой ответ немного запоздалый, но это может помочь кому-то еще посещать этот вопрос.

Я решил проблему, добавив

 hibernate-validator-4.0.2 

и дал мне другое исключение (исключение класса не найдено: org.slf4j.LoggerFactory), которое я разрешил, добавив

slf4j-api-1.5.6.jar

Я надеюсь, что это поможет кому-то.