SpringBoot 常用注解 -- Spring Bean 注解

本文介绍了SpringBoot中常用的注解,包括@ComponentScan用于配置组件扫描路径,@Component及其派生注解如@Controller、@Service、@Repository用于标记组件类等,并通过示例详细解释了这些注解的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringBoot 常用注解 – Spring Bean 注解

摘自:https://mp.weixin.qq.com/s/dWIO1bfmMhVWo1ZPVIS09Q

@ComponentScan

说明:

@ComponentScan注解用于配置Spring需要扫描的被组件注解注释的类所在的包。可以通过配置其basePackages属性或者value属性来配置需要扫描的包路径。value属性是basePackages的别名。

属性:

  • basePackages/value 指扫描哪写包下的组件注解。
  • basePackageClasses 扫描指定的类,该类有组件注解才能被扫描到。
  • useDefaultFilters 使用默认的过滤机制,常常搭配下面两个属性一起使用。
    • includeFilters 扫描哪些组件。
    • excludeFilters 不扫描哪些组件。
  • lazyInit 由于是包扫描一次性的,那么无法单独配置哪个组件是否懒加载,因此提供该属性用于声明是否开启懒加载。

示例:

@Configuration
@ComponentScan(basePackages = {
        "com.controller", 
        "com.dao",
        "com.service"
})
public class MyConfig {
}

@Component

说明:

@Component注解用于标注一个普通的组件类,它没有明确的业务范围,只是通知Spring被此注解的类需要被纳入到Spring Bean容器中并进行管理。
@Component 有三个衍生注解:

  • @Controller: 用于Controller层
  • @Service: 用于业务层
  • @Repository: 用于持久层

示例:

@Component
public class EncryptUserPasswordComponent{
	public String encrypt(String password,String salt){
		// .. 
	}
}

@Service

说明:

@Service注解是@Component的一个延伸(特例),它用于标注业务逻辑类。与@Component注解一样,被此注解标注的类,会自动被Spring所管理。

示例:

public interface UserService{
	User createUser(User user);
}
	
@Service("userService")
public class UserServiceImpl implements UserService{

	@Autowired
	private UserRepository userRepository;
	
	@Override
	public User createUser(User user){
		return userRepository.save(user);
	}
}

@RestController
@RequestMapping("/users")
public class UserController{

	@Autowired
	private UserService userService;
	
	@PostMapping
	public User createUser(aRequestBody User user){
		return userService.createUser(user);
	}
}

@Repository

说明:

@Repository注解也是@Component注解的延伸,与@Component注解一样,被此注解标注的类会被Spring自动管理起来,@Repository注解用于标注DAO层的数据持久化类。

示例:

@Entity
@Table(name="t_user")
public class User{

	@ld
	@CoLumn(name="USER_ID")
	private Long id;
		// ...
	}
	
	@Repository
	public interface UserRepository extends JpaRepository<User,Long>{
		// ...
	}
### Spring Boot 3 中 Bean Searcher 实现与用法 Spring Boot 提供了一种强大的机制用于管理依赖注入和组件扫描,这使得开发者可以轻松定义并检索应用程序中的 `Bean`。对于特定功能如 `bean-searcher` 的实现或用法,在 Spring Boot 3 中可以通过多种方式完成。 #### 使用 Component Scanning 自动注册 Beans 在 Spring Boot 中,默认情况下会通过注解驱动的方式自动发现和注册 `@Component`, `@Service`, `@Repository`, 和 `@Controller` 等标注的类作为容器内的 `Beans`。这种行为由 `@SpringBootApplication` 注解触发,它隐含了 `@EnableAutoConfiguration` 和 `@ComponentScan` 功能[^1]。 如果需要自定义扫描路径或者调整默认配置,则可以在启动类上指定额外参数: ```java @SpringBootApplication(scanBasePackages = {"com.example.beans"}) public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } } ``` 上述代码片段展示了如何限定扫描范围至特定包下,从而更精确控制哪些类会被识别为 Spring 容器中的 beans。 #### 手动获取 Bean 实例 除了依靠框架自动化过程外,还可以利用 `ApplicationContext` 接口手动访问已存在的 bean 资源。例如: ```java @Autowired private ApplicationContext context; @Bean public String getBeanByName() { return (String)this.context.getBean("myCustomBean"); } ``` 这里演示了怎样借助于 `ApplicationContext` 来按名称提取某个具体类型的对象实例。注意实际开发过程中应尽量减少直接操作上下文的行为,保持业务逻辑清晰分离才是最佳实践。 #### 配置文件支持复杂场景下的 Bean 查找优化 当面对较为复杂的多模块项目架构时,可能涉及到跨不同子项目的 bean 加载需求。此时可通过 YAML 或 properties 格式的外部化配置来进一步增强灵活性: ```yaml spring: profiles: dev application.name: my-spring-boot-app custom: enabledFeatures: featureA,featureB ``` 配合条件装配技术(Conditional Configuration),能够依据环境变量动态决定某些部分是否生效以及相应资源加载策略: ```java @Configuration @Profile("dev") @EnableConfigurationProperties(SomeConfigProps.class) public class DevSpecificConfig { @Bean public SomeFeature someFeature(@Value("${custom.enabledFeatures}") List<String> features){ // Implementation here... } } ``` 综上所述,虽然官方文档并未单独提及所谓 “bean searcher” 这一术语,但从广义角度看以上介绍的内容涵盖了相似的功能范畴——即高效定位所需服务单元并与之交互的能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值