Spring Day02

properties

如果我们没有写呢,比如 jdbc.username写成username,那么有可能会和系统变量冲突,那么系统的优先级会更高,回复覆盖我们的,那怎么办

在context空间加载properties文件时,关闭系统文件

加载多个properties文件

<context: property-placeholder location="jdbc.properties,jdbc2.properties">

但是如果很多文件的时候有咋办

<context: property-placeholder location="classpath:*.properties">

总结

不加载系统属性:

<context: property-placeholder location="jdbc.properties" system-properties-mode="NEVER"/>

记载多个properties文件

<context: property-placeholder location="jdbc.properties,msg.properties"/>

加载所有properties文件

<context: property-placeholder location="*.properties">

加载properties文件标准格式

<context: property-placeholder location="classpath:*.properties"/>

从类途径或jar包中搜索并加载properties文件

<context: property-placeholder location=classpath*:*.properties"/>

获取容器的方法

1.记载类路径下的配置文件 用ClassPathXmlApplicationContext

  1. 用绝对路径的方法 FileSystemXmlApplicationContext

从容器获取bean的方法

使用bean名称获取

BookDao bookDao=(BookDao) ctx.getBean("bookDao");

使用bean名称获取并指定类型

BookDao bookDao = ctx.getBean("bookDao",BookDao.class);

使用bean类型获取

BookDao bookDao=ctx.getBean(BookDao.class);

注解开发

@Component定义bean

@Component() 括号里的参数,为放到bean里名字

那我们定义了,Spring怎么直到这里有呢,那就是核心配置环境用组件扫描即可

<context: component-scan base-package="com.itheima">

Spring提供@Component 注解的三个衍生注解

@Controller :用于表现层bean定义

@Service: 用于业务层bean定义

@Repository: 用于数据层bean定义

纯注解开发

Spring3.0开启了纯注解开发模式,使用Java类替代配置文件,开启了Spring快速开发赛道

Java类代替Spring核心配置文件

@Configuration 注解用于设定当前类为配置类

@ComponentScan注解用于设定扫描路径,此注解只能添加一次,多个数据请用数组格式

@ComponentScan({"com.itheima.service","com.itheima.dao"})

写了配置类就不写Spring核心配置文件了

@PostConstruct bean实例化之前执行

@PreDestory 则是bean对象销毁时执行

依赖注入

@Autowired

@Qualifier("bookDao")

value里的值怎么来自配置文件

1.在配置类上加入

@PropertySource("配置文件的名字") //这里不支持使用通配符

2.在属性名上加入("${配值文件的名字}")

如何管理第三方Bean

@Bean:表示当前方法返回的值是一个bean

但是有一个问题,就是这里是Spring的配置文件,我们写的是jdbc的配置,所以我们需要把他们放到别的一个类

|-----------|---------------------------------|------------------------------------------------------------|
| 功能 | XML配置 | 注解 |
| 定义bean | bean标签 id属性 class属性 | @Component @Controller @Service @Repository @ComponentScan |
| 设置依赖注入 | setter方法 引用/简单 构造器注入 引用/简单 自动装配 | @Autowired @Qualifier @Value |
| 配置第三方bean | bean标签 静态工厂,实例工厂 FactoryBean | @Bean |
| 作用范围 | scope属性 | @Scope |

生命周期 标准接口 init-method destory-method @PostConstructor @PreDestroy

基于junit框架来实现测试

需要导入依赖

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>4.12</version>

<scope>test</scope>

<groupId>org.springframework</groupId>

<artifactId>spring-test</artifactId>

<version>5.2.10.RELEASE</version>

相关推荐
运维有小邓@19 小时前
Log360 的可扩展架构(三):数据流管道
数据库·架构
醇氧19 小时前
【Windows】安装mysql8
数据库·windows·mysql
温暖小土19 小时前
ClickHouse vs Apache Doris:2026年实时OLAP数据库选型深度解析
数据库·数据仓库·clickhouse·apache
专注数据的痴汉19 小时前
「数据获取」全国民用运输机场吞吐量排名(2006-2024)
java·大数据·服务器·数据库·信息可视化
海边的椰子树19 小时前
非常方便的MySQL迁移数据ClickHouse工具
数据库·mysql·clickhouse·迁移
yongui4783419 小时前
使用C#实现Excel实时读取并导入SQL数据库
数据库·c#·excel
ryy102550631919 小时前
Springboot+Mysql 图书管理系统【源码+sql】
spring boot·sql·mysql
JZC_xiaozhong20 小时前
分析型数据库 ClickHouse 在数据中台中的集成
大数据·数据库·clickhouse·架构·数据一致性·数据孤岛解决方案·数据集成与应用集成
航Hang*20 小时前
第3章:复习篇——第3节:数据查询与统计---题库
数据库·笔记·sql·学习·mysql·期末·复习
廋到被风吹走20 小时前
【数据库】【MySQL】事务隔离深度解析:MVCC 实现与幻读解决机制
android·数据库·mysql