SpringBoot中必须掌握的常用注解小结
作者:磊哥|www.javacn.site
1.Bean相关
@Component:将一个类标识为 Spring 组件(Bean),可以被 Spring 容器自动检测和注册。通用注解,适用于任何层次的组件。
@Component public class MyComponent { public void doSomething() { System.out.println("MyComponent is doing something."); } }
@ComponentScan:自动扫描指定包及其子包中的 Spring 组件。
@ComponentScan("com.example") // 扫描com.example包下的组件,加载到Spring容器 @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
@Controller:标识控制层组件,实际上是 @Component 的一个特化,用于表示 Web 控制器。处理 HTTP 请求并返回视图或响应数据。
@Controller public class MyController { @Autowired private final UserService userService; @GetMapping("/user") public String getUser(Model model) { User user = userService.getUserById(1); model.addAttribute("user", user); return "user"; } }
@RestController:是 @Controller 和 @ResponseBody 的结合,返回的对象会自动序列化为 JSON 或 XML,并写入 HTTP 响应体中。
@RestController public class MyController { @Autowired private final UserService userService; @GetMapping("/user") public User getUser() { User user = userService.getUserById(1); return user; } }
@Service:标识服务层组件,实际上是 @Component 的一个特化,用于表示业务逻辑服务。
@Service public class MyService { }
@Repository:标识持久层组件(DAO 层),实际上是 @Component 的一个特化,用于表示数据访问组件。常用于与数据库交互。
@Repository public interface UserDao { }
@Bean:方法注解,用于修饰方法,主要功能是将修饰方法的返回对象添加到 Spring 容器中,使得其他组件可以通过依赖注入的方式使用这个对象。
@Configuration public class AppConfig { @Bean public MyBean myBean() { return new MyBean(); } }
@Configuration:标识一个类作为配置类,@Component 的一个特化,通常配合 @Bean 注解一起使用。
@Configuration public class AppConfig { }
@Scope:用于声明一个 Spring Bean 实例的作用域,作用域的范围有单例模式、原型模式(多例模式)等。
@Configuration public class AppConfig { @Bean @Scope("prototype") public MyPrototypeBean myPrototypeBean() { return new MyPrototypeBean(); } }
2.依赖注入
@Autowired:用于自动注入依赖对象,Spring 框架提供的注解。
@RestController public class MyController { @Autowired private final UserService userService; @GetMapping("/user") public User getUser() { User user = userService.getUserById(1); return user; } }
@Resource:按名称自动注入依赖对象(也可以按类型,但默认按名称),JDK 提供注解。
@RestController public class MyController { @Resource private final UserService userService; @GetMapping("/user") public User getUser() { User user = userService.getUserById(1); return user; } }
@Qualifier:与 @Autowired 一起使用,用于指定要注入的 Bean 的名称。当存在多个相同类型的 Bean 时,可以使用 @Qualifier 来指定注入哪一个。
@RestController public class MyController { @Autowired @Qualifier("userService") private final UserService us; @GetMapping("/user") public User getUser() { User user = userService.getUserById(1); return user; } }
3.Web相关
@RequestMapping:用于映射 HTTP 请求到处理方法上,支持 GET、POST、PUT、DELETE 等请求方法。可以标注在类或方法上。标注在类上时,表示类中的所有响应请求的方法都是以该类路径为父路径。
@RestController @RequestMapping("/contoller") public class MyController { @Resource private final UserService userService; @RequestMapping("/user") public User getUser() { User user = userService.getUserById(1); return user; } }
@GetMapping、@PostMapping、@PutMapping、@DeleteMapping:分别用于映射 HTTP GET、POST、PUT、DELETE 请求到处理方法上。它们是 @RequestMapping 的特化,分别对应不同的 HTTP 请求方法。
@RestController @GetMapping("/contoller") public class MyController { @Resource private final UserService userService; @GetMapping("/user") public User getUser() { User user = userService.getUserById(1); return user; } }
@RequestParam:用于将请求参数绑定到 Controller 方法的参数上。它主要用于处理 GET、POST 等请求中的查询参数,例如将 http://example.com/api?param1=value1¶m2=value2
中的 param1 和 param2 参数设置到方法的参数上。
@PathVariable:用于从请求的 URL 路径中提取变量值,并将其绑定到控制器方法的参数上。
@GetMapping("/user/{userId}") public String getUserById(@PathVariable("userId") Long id) { return "User with ID " + id; }
@RequestBody:将 HTTP 请求体的内容(如 JSON、XML)转换为 Java 对象。通常用于接收前端传递的数据,标注在方法的参数上。
@Controller public class MyController { @PostMapping("/submit") public String submitData(@RequestBody MyData myData) { System.out.println(myData); return "success"; } }
@ResponseBody:将方法的返回值转换为指定格式(如 JSON、XML)作为 HTTP 响应的内容返回给客户端。通常与 @RequestMapping 或 @GetMapping 等注解一起使用在方法上。
@RestController public class MyController { @GetMapping("/data") @ResponseBody public String getData() { return "Some data"; } }
4. 读取配置
@Value:用于注入属性值,通常从配置文件中获取。标注在字段上,并指定属性值的来源(如配置文件中的某个属性)。
@Component public class MyComponent { @Value("${my.property}") private String myPropertyValue; public void printValue() { System.out.println(myPropertyValue); } }
@ConfigurationProperties:用于将配置属性绑定到一个实体类上。通常用于从配置文件中读取属性值并绑定到类的字段上。
import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Component @ConfigurationProperties(prefix = "my.app") public class MyAppProperties { private String property1; private int property2; // Getters and setters }
5. 配置启动注解
@SpringBootApplication:用于标识 SpringBoot 应用程序的入口类。它是一个组合注解,包括了 @Configuration、@EnableAutoConfiguration 和 @ComponentScan 三个注解。
@SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
@EnableAutoConfiguration:启用 Spring Boot 的自动配置机制,根据添加的依赖和配置文件自动配置 Spring 应用。
6. 其他常用注解
@Transactional:声明事务管理。标注在类或方法上,指定事务的传播行为、隔离级别等。
import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @Service public class MyService { @Transactional public void performTransactionalOperation() { // Database operations } }
@Scheduled:声明一个方法需要定时执行。标注在方法上,并指定定时执行的规则(如每隔一定时间执行一次)。
import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component public class MyScheduledTask { @Scheduled(fixedRate = 5000) public void performTask() { System.out.println("Task executed."); } }
小结
Spring Boot 中的注解用很多,本文也是走马观花的带大家了解了一下 Spring Boot 中的常见注解。当然这些注解也不需要全部记住,只需有一个大概的印象即可,用的时候再查具体的使用就可以了。
以上就是SpringBoot中必须掌握的常用注解小结的详细内容,更多关于SpringBoot常用注解的资料请关注脚本之家其它相关文章!