当前位置: 首页 > article >正文

软件设计之SSM(3)

软件设计之SSM(3)

路线图推荐:
【Java学习路线-极速版】【Java架构师技术图谱】
尚硅谷新版SSM框架全套视频教程,Spring6+SpringBoot3最新SSM企业级开发
资料可以去尚硅谷官网免费领取

学习内容:

注解方式管理Bean

  1. 组件注解标记和扫描
  2. 组件作用域和周期方法注解
  3. 引用类型自动装配
  4. 基本类型属性赋值

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;
    }
}


http://www.kler.cn/a/326423.html

相关文章:

  • 【通俗理解】AI的两次寒冬:从感知机困局到深度学习前夜
  • java mail 535 Login Fail. Please enter your authorization code to login
  • 【vue3封装element-plus的反馈组件el-drawer、el-dialog】
  • 接口测试-postman(使用postman测试接口笔记)
  • php 多进程那点事,用 swoole 如何解决呢 ?
  • HarmonyOS开发:传参方式
  • SpringBoot中各种O的分层模型
  • 16 数组——18. 四数之和 ★★
  • 6种MySQL高可用方案对比分析
  • CleanMyMac X v4.12.1 中文破解版 Mac优化清理工具
  • 10个降低性能的SQL问题及改进措施
  • Leetcode面试经典150题-201.数字范围按位与
  • oracle 分表代码示例
  • FiBiNET模型实现推荐算法
  • qiankun自定义数据通信方案
  • Json files to Excel - Python
  • 【QT】QWidget 重要属性
  • Golang | Leetcode Golang题解之第435题无重叠区间
  • Qt开发第一讲
  • ip池子的大小与什么相关?
  • echarts 导出pdf空白原因
  • Spring系统学习(五)——Spring数据库编程
  • YOLOv8改进 | 主干改进篇,华为的轻量化架构GhostNetV2改进特征提取网络
  • 前端项目依赖包中的依赖包漏洞解决方案
  • springboot实战学习(10)(ThreadLoacl优化获取用户详细信息接口)(重写拦截器afterCompletion()方法)
  • 解决VRM格式模型在Unity中运行出现头发乱飞等问题