三、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。
<beans>
<bean id="wheel" class="cn.boot.Wheel"/>
<bean id="car" class="cn.boot.Car">
<property name="wheel" ref="wheel"/>
</bean>
</beans>
@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;
@Component
@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;
}
}
@Autowired
RedisConfig redisConfig;
@GetMapping("/testUtil")
public String testUtil(){
System.out.println(redisConfig.getNodes()+"\t"+redisConfig.getPassword());
return "index";
}
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")
public class HellobootApplication {
public static void main(String[] args) {
SpringApplication.run(HellobootApplication.class, args);
}
}

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
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;
@Controller
public class MyBootController {
@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;
@Component
@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.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";
}
|