软件设计之SSM(3)
软件设计之SSM(3)
路线图推荐:
【Java学习路线-极速版】【Java架构师技术图谱】
尚硅谷新版SSM框架全套视频教程,Spring6+SpringBoot3最新SSM企业级开发
资料可以去尚硅谷官网免费领取
学习内容:
注解方式管理Bean
- 组件注解标记和扫描
- 组件作用域和周期方法注解
- 引用类型自动装配
- 基本类型属性赋值
1、组件注解标记和扫描
- 和 XML 配置文件一样,
注解
本身并不能执行
,注解本身仅仅只是做一个标记
,具体的功能是框架检测到注解标记的位置,然后针对这个位置按照注解标记的功能来执行具体操作。 - Spring 为了知道程序员在哪些地方标记了什么注解,就需要通过
扫描
的方式,来进行检测。然后根据注解进行后续操作 - Spring 提供了以下多个注解,这些注解可以直接标注在 Java 类上,将它们定义成 Spring Bean。
-
@Controller
、@Service
、@Repository
这三个注解只是在@Component注解的基础上起了三个新的名字,目的是为了分辨组件作用
注解 | 说明 |
---|---|
@Component | 该注解用于描述 Spring 中的 Bean,它是一个泛化的概念,仅仅表示容器中的一个组件(Bean),并且可以作用在应用的任何层次,例如 Service 层、Dao 层等。 使用时只需将该注解标注在相应类上即可。 |
@Repository | 该注解用于将数据访问层(Dao 层)的类标识为 Spring 中的 Bean,其功能与 @Component 相同。 |
@Service | 该注解通常作用在业务层(Service 层),用于将业务层的类标识为 Spring 中的 Bean,其功能与 @Component 相同。 |
@Controller | 该注解通常作用在控制层(如SpringMVC 的 Controller ),用于将控制层的类标识为 Spring 中的 Bean,其功能与 @Component 相同。 |
配置文件确定扫描范围
三种情况:全扫描、排除某一类型组件再进行扫描、只针对某一组件类型扫描
配置项 | 说明 |
---|---|
base-package | 指定扫描的基础包路径 |
include-filter | 包含的类过滤器,如特定注解的类 |
exclude-filter | 排除的类过滤器,如特定包或类的排除 |
scope | 扫描的范围,如全局或特定模块 |
lazy | 是否延迟加载,默认为false |
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">
<!-- 配置自动扫描的包 -->
<!-- 1.包要精准,提高性能!
2.会扫描指定的包和子包内容
3.多个包可以使用,分割 例如: com.atguigu.controller,com.atguigu.service等
-->
<context:component-scan base-package="com.atguigu.components"/>
<!-- 情况二:指定不扫描的组件 -->
<context:component-scan base-package="com.atguigu.components">
<!-- context:exclude-filter标签:指定排除规则 -->
<!-- type属性:指定根据什么来进行排除,annotation取值表示根据注解来排除 -->
<!-- expression属性:指定排除规则的表达式,对于注解来说指定全类名即可 -->
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
</beans>
<!-- 情况三:仅扫描指定的组件 -->
<!-- 仅扫描 = 关闭默认规则 + 追加规则 -->
<!-- use-default-filters属性:取值false表示关闭默认扫描规则 -->
<context:component-scan base-package="com.atguigu.ioc.components" use-default-filters="false">
<!-- context:include-filter标签:指定在原有扫描规则的基础上追加的规则 -->
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
使用注解后组件的默认id
- 在我们使用 XML 方式管理 bean 的时候,每个 bean 都有一个唯一标识——id 属性的值,便于在其他地方引用。现在使用注解后,每个组件仍然应该有一个唯一标识。
- 默认值: 类名首字母小写就是 bean 的 id。例如:
SoldierController 类
对应的 bean 的 id 就是soldierController
- 可以使用value属性指定组件id
@Controller(value = "tianDog")
//当注解中只设置一个属性时,value属性的属性名可以省略
//@Controller("tianDog")
public class SoldierController {
}
2、组件作用域和周期方法注解
配置项 | 说明 |
---|---|
@PostConstruct | 在组件初始化后执行的方法,用于初始化逻辑 |
@PreDestroy | 在组件销毁前执行的方法,用于清理资源 |
@Scope | 定义组件的作用域,如singleton (单例)或prototype (原型) |
@RequestScope | 每个HTTP请求创建一个新的组件实例 |
@SessionScope | 在一个HTTP会话中共享组件实例 |
3、引用类型自动装配
引用类型自动装配是指在Spring中,自动将一个Bean的实例注入到另一个Bean中,以满足依赖关系。
前提:
`参与自动装配的组件(需要装配、被装配)全部都必须在IoC容器中
@Autowired
可用于不同位置:
- 成员变量:直接在类的成员变量上使用,Spring会在创建Bean时自动注入。
- 构造函数:在构造函数参数上使用,确保所有依赖在对象创建时注入,通常用于必须的依赖。
- setXxx()方法:Spring会自动调用该方法并传入所需的依赖
@Qualifier
@Qualifier 注解用于在依赖注入中指定具体的 bean,当有多个同类型的 bean 可用时,它帮助 Spring 确定要注入哪一个
@Controller(value = "tianDog")
public class SoldierController {
@Autowired
@Qualifier(value = "maomiService222")
// 根据面向接口编程思想,使用接口类型引入Service组件
private ISoldierService soldierService;
@Resource
@Resource 注解
是 Java EE 规范的一部分,用于依赖注入。它的主要作用是根据名称查找和注入 bean。与 Spring 的 @Autowired 和 @Qualifier 不同,@Resource 默认按照名称进行匹配,优先使用 name 属性。- @Resource注解属于JDK扩展包,所以不在JDK当中,需要额外引入以下依赖:
<dependency>
<groupId>jakarta.annotation</groupId>
<artifactId>jakarta.annotation-api</artifactId>
<version>2.1.1</version>
</dependency>
4、基本类型属性赋值
@Value
通常用于注入外部化属性
一般用于在XML引入外部配置文件(.properties等
),随后利用value进行赋值
前提:
- 在XML引入了配置文件
- 组件已经声明在容器内
package com.atguigu.components;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
/**
* projectName: com.atguigu.components
*
* description: 普通的组件
*/
@Component
public class CommonComponent {
/**
* 情况1: ${key} 取外部配置key对应的值!
* 情况2: ${key:defaultValue} 没有key,可以给与默认值
*/
@Value("${catalog:hahaha}")
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}