2013-11-27 5 views
0

Я создал приложение весны, которое успешно работает, когда я открываю следующую ссылку: localhost: 8080/test/greeting. Сервер полностью развернут, но когда я открываю эту ссылку, файл называется greeting, а встроенный json встроен. Я попытался открыть ссылку в Internet Explorer, и я подумал, что json появится прямо на экране. Разве это не так?Spring rest json output

Вот диспетчеру сервлет:

<?xml version="1.0" encoding="UTF-8"?> 
    <beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xmlns:context="http://www.springframework.org/schema/context" 
    xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd 
         http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd  
         http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
         http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> 

    <context:component-scan base-package="test" /> 
    <mvc:annotation-driven /> 
</beans> 

А вот web.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> 

    <servlet> 
     <servlet-name>dispatcher</servlet-name> 
     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
     <load-on-startup>1</load-on-startup> 
    </servlet> 

    <servlet-mapping> 
     <servlet-name>dispatcher</servlet-name> 
     <url-pattern>/*</url-pattern> 
    </servlet-mapping> 

</web-app> 

Вот код GreetingController:

package test; 

import java.util.concurrent.atomic.AtomicLong; 
import org.springframework.stereotype.Controller; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RequestParam; 
import org.springframework.web.bind.annotation.ResponseBody; 

@Controller 
public class GreetingController { 

    private static final String template = "Hello, %s!"; 
    private final AtomicLong counter = new AtomicLong(); 

    @RequestMapping("/greeting") 
    public @ResponseBody Greeting greeting(
      @RequestParam(value="name", required=false, defaultValue="World") String name) { 
     return new Greeting(counter.incrementAndGet(), 
          String.format(template, name)); 
    } 
} 

Я искал на некоторое время, и не смогли найти решение этого.

+0

Вы можете показать код контроллера? –

+1

Я думаю, что ответ Content-Type, который возвращает Spring (mvc), неверен. Это должно быть «application/json». Найдите «Content-type» Spring mvc. [Это переполнение Q/A] (http://stackoverflow.com/questions/8951534/spring-mvc-3-return-content-type-text-plain) может вам помочь. Он предлагает аннотировать ваш сервлет с помощью '@ ResponseBody' и использовать' response.setContentType'. – erny

+0

Опубликовать контроллер, который обрабатывает этот запрос –

ответ

0

Удалось решить, что это просто Internet Explorer, отлично работает в других браузерах!

1

Похоже, что правильный тип контента не задан для ответа. Если вы хотите установить тип и конверсионный тип ответа по умолчанию для JSON, вы можете добавить следующие определения bean-файлов в свой файл контекстного источника в дополнение к аннотации @ResponseBody в определении возврата.

<bean id="jacksonMessageConverter"class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></bean> 
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> 
     <property name="messageConverters"> 
      <list> 
       <ref bean="jacksonMessageConverter" /> 
      </list> 
     </property> 
</bean> 

Вам также необходимо добавить Джексона в свой путь к классам для обработки фактического Java < => преобразование JSON. Если это то, что вы хотите по умолчанию, это может помочь вам предотвратить шаблонный код, который потребуется для ручной установки типа содержимого в JSON для каждого метода определения соответствия запросов.

Смежные вопросы