1.建立maven项目
点击finish,完成创建maven项目
在pom.xml文件中添加如下代码:
1 <parent>
2 <groupId>org.springframework.boot</groupId>
3 <artifactId>spring-boot-starter-parent</artifactId>
4 <version>1.4.4.RELEASE</version>
5 </parent>
6 <dependencies>
7 <dependency>
8 <groupId>org.springframework.boot</groupId>
9 <artifactId>spring-boot-starter-web</artifactId>
10 </dependency>
11 </dependencies>
其中,spring-boot-starter-parent的作用是继承一些springboot的默认配置,比如:
- 默认使用Java 8
- 使用UTF-8编码
- 一个引用管理的功能,在dependencies里的部分配置可以不用填写version信息,这些version信息会从spring-boot-dependencies里得到继承。
- 识别过来资源过滤(Sensible resource filtering.)
- 识别插件的配置(Sensible plugin configuration (exec plugin, surefire, Git commit ID, shade).)
- 能够识别application.properties和application.yml类型的文件,同时也能支持profile-specific类型的文件(如: application-foo.properties and application-foo.yml,这个功能可以更好的配置不同生产环境下的配置文件)。
如果不想用默认配置,可以使用自定义配置覆盖默认配置,比如更改默认使用的jdk版本为1.7
<properties>
<java.version>1.7</java.version>
</properties>
建立Application.class类,该类作为springboot的启动器
1 package main;
2
3 import org.springframework.boot.SpringApplication;
4 import org.springframework.boot.autoconfigure.SpringBootApplication;
5
6 @SpringBootApplication(scanBasePackages={"com.myproject"})
7 public class Application {
8 public static void main(String[] args) {
9 SpringApplication.run(Application.class, args);
10 //以下是是否禁用启动标识
11 // SpringApplication application = new SpringApplication(Application.class);
12 // application.setBannerMode(Mode.OFF);
13 // application.run(args);
14 }
15 }
其中,@SpringBootApplication是一个组合注解,@SpringBootApplication = (默认属性)@Configuration + @EnableAutoConfiguration + @ComponentScan。
@Configuration
1、@Configuration:提到@Configuration就要提到他的搭档@Bean。使用这两个注解就可以创建一个简单的spring配置类,可以用来替代相应的xml配置文件。
1 <beans>
2 <bean id = "car" class="com.test.Car">
3 <property name="wheel" ref = "wheel"></property>
4 </bean>
5 <bean id = "wheel" class="com.test.Wheel"></bean>
6 </beans>
相当于:
1 @Configuration
2 public class Conf {
3 @Bean
4 public Car car() {
5 Car car = new Car();
6 car.setWheel(wheel());
7 return car;
8 }
9 @Bean
10 public Wheel wheel() {
11 return new Wheel();
12 }
13 }
@Configuration的注解类标识这个类可以使用Spring IoC容器作为bean定义的来源。@Bean注解告诉Spring,一个带有@Bean的注解方法将返回一个对象,该对象应该被注册为在Spring应用程序上下文中的bean。
2、@EnableAutoConfiguration:能够自动配置spring的上下文,试图猜测和配置你想要的bean类,通常会自动根据你的类路径和你的bean定义自动配置。
3、@ComponentScan:会自动扫描指定包下的全部标有@Component的类,并注册成bean,当然包括@Component下的子注解@Service,@Repository,@Controller。
这里注意:@SpringBootApplication后必须跟扫描包的位置,否则Controller类将不会被映射到地址上,则无法访问.
新建包,并建立Controller类
HelloWorld类为一个控制器类,代码如下:
1 package com.myproject.controller;
2
3 import org.springframework.web.bind.annotation.RequestMapping;
4 import org.springframework.web.bind.annotation.RestController;
5
6 @RestController
7 public class HelloWorld {
8
9 @RequestMapping("/hello")
10 public String sayHello(){
11 System.out.println("HelloWorld");
12 return "HelloWorld";
13 }
14 }
@RestController注解,该注解表示当前类为一个Controller组件,该注解 = @Controller与@ResponseBody注解的结合.
@responseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML数据。
这个注解表示该方法的返回结果直接写入HTTP response body中,一般在异步获取数据时使用。
在使用@RequestMapping后,返回值通常解析为跳转路径。加上@responsebody后,返回结果直接写入HTTP response body中,不会被解析为跳转路径。比如异步请求,希望响应的结果是json数据,那么加上@responsebody后,就会直接返回json数据。
至此,一个简单的springboot项目就搭建好了,访问http://localhost:8080/hello,在页面上显示HelloWorld,并在控制台打印"HelloWorld".