三、Spring Boot核心注解

1. @SpringBootApplication

代表是Spring Boot的启动类。

申明让spring boot自动给程序进行必要的配置,这个配置等同于@Configuration ,@EnableAutoConfiguration 和 @ComponentScan三个配置。

2. @Configuration

通过对bean对象的操作替代spring中xml文件。

@Configuration的注解类标识这个类可以使用Spring IoC容器作为bean定义的来源。@Bean注解告诉Spring,一个带有@Bean的注解方法将返回一个对象,该对象应该被注册为在Spring应用程序上下文中的bean。

<!--Spring中定义bean-->
<beans>
	<bean id="wheel" class="cn.boot.Wheel"/>
	<bean id="car" class="cn.boot.Car">
		<property name="wheel" ref="wheel"/>
	</bean>
</beans>
//在java源代码中使用注解获取bean
@Configuration
public class Test{
	@Bean
	public Car car(){
		Car cae = new Car();
		car.setWheel(sheel());
		return car;
	}
	@Bean
	public Wheel wheel(){
		return new Wheel();
	}
}

3. @Component

@Component和@Configuration用法差不多相同,实现效果也一样,使用其中一个即可。

package cn.boot.util;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Component;
//@Configuration
@Component
//这个是在.yml中配置的
@ConfigurationProperties(prefix = "spring.redis.cluster")
public class RedisConfig {
    private String nodes;
    private String password;
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    public String getNodes() {
        return nodes;
    }
    public void setNodes(String nodes) {
        this.nodes = nodes;
    }
}

//application.yml
spring:
	redis:
	    cluster:
	      nodes: 8081
	      password: 987654

//测试
@Autowired
RedisConfig redisConfig;
@GetMapping("/testUtil")
public String testUtil(){
    System.out.println(redisConfig.getNodes()+"\t"+redisConfig.getPassword());
    return "index";
}

spring boot 注解 简化构造函数 @springboot注解_spring boot

4. @EnableAutoConfiguration

完成一些初始化环境的配置。

@EnableAutoConfiguration:能够自动配置spring的上下文,试图猜测和配置你想要的bean类,通常会自动根据你的类路径和你的bean定义自动配置。

Spring Boot自动配置(auto-configuration):尝试根据你添加的jar依赖自动配置你的Spring应用。例如,如果你的classpath下存在HSQLDB,并且你没有手动配置任何数据库连接beans,那么我们将自动配置一个内存型(in-memory)数据库”。
你可以将@EnableAutoConfiguration或者@SpringBootApplication注解添加到一个@Configuration类上来选择自动配置。如果发现应用了你不想要的特定自动配置类,你可以使用@EnableAutoConfiguration注解的排除属性来禁用它们。

5. @ComponentScan

主程序所在包及其下面的所有子包里面的组件都会被默认扫描。

如果想要改变扫描路径,来完成spring的组件扫描,可以使用注解指定扫描路径,注解替代之前在xml文件中配置的自动扫描(无需以前的包扫描配置)。

@ComponentScan:会自动扫描指定包下的全部标有@Component的类,并注册成bean,当然包括@Component下的子注解@Service,@Repository,@Controller。

表示将该类自动发现(扫描)并注册为Bean,可以自动收集所有的Spring组件,包括@Configuration类。我们经常使用@ComponentScan注解搜索beans,并结合@Autowired注解导入。如果没有配置的话,Spring Boot会扫描启动类所在包下以及子包下的使用了@Service,@Repository等注解的类。

当然,这个扫描也可以直接在启动类中使用注解@SpringBootApplication(scanBasePackages = “cn.boot”),这两个的效果都是一样的。

package cn.boot.main;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.SpringApplication;

@SpringBootApplication(scanBasePackages = "cn.boot")
//@ComponentScan("cn.boot")
public class HellobootApplication {
    public static void main(String[] args) {
        SpringApplication.run(HellobootApplication.class, args);
    }
}

spring boot 注解 简化构造函数 @springboot注解_字符串_02

@SpringBootApplication
等同于
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan("cn.boot")

6. RestController

是@ResponseBody和@Controller的合集。

表示一个Controller,也表示当前这个Controller下的所有方法都会以json格式的数据返回。

当不需要返回页面时,可以直接使用@RestController来代替@Controller和@ResponseBody,即可直接返回结果。

package cn.boot.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

/**
 * 当不需要返回页面时,可以直接使用@RestController来代替@Controller和@ResponseBody,
 * 即可直接返回结果,即在页面上显示的是 Hello字符串
 */
@RestController
public class MyBootController {
    @RequestMapping("/HelloMyBoot")
    public String HelloMyBoot(){
        System.out.println("111");
        return "Hello";
    }
}

7. @ResponseBody

当需要同时返回页面和字符串时,需要使用@Controller,在返回字符串的方法上使用@ResponseBody,表示响应返回内容,该注解一般会配合@RequestMapping一起使用。

package cn.boot.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

/**
 * 当不需要返回页面时,可以直接使用@RestController来代替@Controller和@ResponseBody,
 * 即可直接返回结果,即在页面上显示的是 Hello字符串
 */
//@RestController
@Controller
public class MyBootController {
    /**
     * 当需要同时返回页面和字符串时,需要使用@Controller,
     * 在返回字符串的方法上使用@ResponseBody,表示响应返回内容
     */
    @ResponseBody
    @RequestMapping("/HelloMyBoot")
    public String HelloMyBoot(){
        System.out.println("111");
        return "Hello";
    }
}

8. @PropertySource

如果需要有自定义的属性文件需要加载,可以使用该注解进行注入,并用@Value配合使用。

一般的属性文件都统一放在resource目录下,或者配置在.yml文件中。

package cn.boot.util;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.context.annotation.PropertySources;
import org.springframework.stereotype.Component;
//@Configuration
@Component
//已定义属性文件spring.redis
@PropertySource("classpath:spring.redis")
public class ConfigUtil {
    @Value("${spring.redis.port}")
    private int port;
    @Value("${spring.redis.ip}")
    private  String ip;
    public int getPort() {
        return port;
    }
    public void setPort(int port) {
        this.port = port;
    }
    public String getIp() {
        return ip;
    }
    public void setIp(String ip) {
        this.ip = ip;
    }
}


//spring.redis配置文件
spring.redis.port=6379
spring.redis.ip=127.0.0.1

//测试
@Autowired
ConfigUtil configUtil;
@GetMapping("/testUtil")
public String testUtil(){
    System.out.println(configUtil.getIp()+"\t"+configUtil.getPort());
    return "index";
}

spring boot 注解 简化构造函数 @springboot注解_redis_03

9. @InportResource

用来加载xml配置文件。

10. @Bean

用@Bean标注方法等价于xml中配置的bean。上面已经实现过了。

11. @Value

注入Spring Boot属性文件中属性的值,同时也可以注入自定义属性文件中属性的值。