Spring Boot - fish

1. @RestController combines @Controller and @ResponseBody, 这是不是意味着不用再import jakson的包(@ResponseBody时用到的,将对象转成json对象)了? 有待考证。

2. Create an Application class

 1 package hello;
 2 
 3 import java.util.Arrays;
 4 
 5 import org.springframework.boot.SpringApplication;
 6 import org.springframework.boot.autoconfigure.SpringBootApplication;
 7 import org.springframework.context.ApplicationContext;
 8 
 9 @SpringBootApplication
10 public class Application {
11 
12     public static void main(String[] args) {
13         ApplicationContext ctx = SpringApplication.run(Application.class, args);
14 
15         System.out.println("Let's inspect the beans provided by Spring Boot:");
16 
17         String[] beanNames = ctx.getBeanDefinitionNames();
18         Arrays.sort(beanNames);
19         for (String beanName : beanNames) {
20             System.out.println(beanName);
21         }
22     }
23 
24 }

以上代码,调用annotation @SpringBootApplication,它会加载@Configuration,@EnableAutoConfiguation,@ComponentScan

其中,@Configuration:标记该class是ApplicationContext的一个bean定义,相当于原来applicationContext.xml文件中的<bean>标签。

   @EnableAutoConfiguation:标记Spring Boot开始加载各种beans(包括自定义的,classpath中的),以及各种属性。

     @ComponentScan:告知Spring去搜索其他组件,配置或者服务。其实就是原来applicationContext.xml文件中的<mvc:component-scan>标签。

另外,由以上分析,个人认为在Spring Boot中,实际上是通过各种annotation来代替.xml配置文件中的各种配置,从而将xml文件干掉。

针对Spring MVC应用,本应该需要注解@EnableWebMvc,但是当Spring Boot在classpath中看到spring-webmvc时,就会自动加载该注解,激活DispatcherServlet等。

    问题:对DispatcherServlet的配置,如何通过Spring Boot来配置呢?

--------------------------------------------------------------------------------------

通过对 Spring Boot中  Building a RESTful Web Service  这一章节的阅读,有以下理解:

首先,解决问题一:@RestController combines @Controller and @ResponseBody......

  仍然需要import jakson的包,因为spring并没有提供将java Object转成JSON对象的package。

  但spring提供MappingJackson2HttpMessageConverter,从而通过监测到jakson的包而自动加载并使用。最终将java Object转成JSON对象并附于HTTP response。

其次,如下:

 1 package hello;
 2 
 3 import java.util.concurrent.atomic.AtomicLong;
 4 import org.springframework.web.bind.annotation.RequestMapping;
 5 import org.springframework.web.bind.annotation.RequestParam;
 6 import org.springframework.web.bind.annotation.RestController;
 7 
 8 @RestController
 9 public class GreetingController {
10 
11     private static final String template = "Hello, %s!";
12     private final AtomicLong counter = new AtomicLong();
13 
14     @RequestMapping("/greeting")
15     public Greeting greeting(@RequestParam(value="name", defaultValue="World") String name) {
16         return new Greeting(counter.incrementAndGet(),
17                             String.format(template, name));
18     }
19 }

终于明白@RequestMapping, @ResponseBody的用意和区别了。

可以说,@ResponseBody是为RESTful web service服务的。正如上所述,traditional mvc controller和RESTful web service controller之间的区别主要在于HTTP响应体的创建方式。

前者应用在Spring中,具体表现为在处理请求后,展示数据将存于map/modelMap/viewAndModelMap中,返回的是String/void类型(String则表示view的名称),再通过view技术对model数据进行渲染。

后者则不同,而是将展示数据存于自定义的对象中,并返回该对象,最终将该对象转成JSON对象附于HTTP响应体上。类似于MVC被VC替代了。

在Spring 4中,增加了@RestController注解,它是@Controller和@ResponseBody的结合。用于标记该类中的所有方法将返回一个自定义对象,而非视图。所以,当需要Controller既返回view又返回对象时,就不能使用@RestController了。

 

posted on 2015-06-22 07:57  -赶鸭子上架-  阅读(759)  评论(0编辑  收藏  举报