1.Spring与日志框架的整合
1.Spring与日志框架进行整合,日志框架就可以在控制台中,输出Spring框架运行过程中的一些重要的信息。
好处:方便了解Spring框架的运行过程,利于程序的调试。
- Spring如何整合日志框架
Spring5.x整合log4j
1.引入log4j.jar包
2.引入log4j.properties配置文件
- pom文件
<dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.25</version> </dependency>
- log4j.properties
### 设置### log4j.rootLogger = debug,stdout ### 输出信息到控制抬 ### log4j.appender.stdout = org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target = System.out log4j.appender.stdout.layout = org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
2.注入(Injection)
1.什么是注入
通过Spring工厂及配置文件,为所创建对象的成员变量赋值
1.1为什么需要注入?

1.2如何进行注入[开发步骤]
- 类的成员变量提供 set get方法
- 配置spring的配置文件
java
<bean id="person" class="basic.Person">
<property name="name">
<value>张三</value>
</property>
<property name="age">
<value>18</value>
</property>
</bean>
1.3注入好处
解耦合
2.Spring注入的原理分析(简易版)

Spring解析到<property name=""><value> <property等效于调用该对象的set方法。
Spring通过底层调用对象属性对应的set方法,完成成员变量的赋值,这种方式也称之为set注入。
3.Set注入详解
针对不同类型的成员变量,在<property>标签需要嵌套其他标签

1.JDK内置类型
1.1Spring内置8中基本类型
<value>张三<value>
1.2数组
java
<property name="emails">
<list>
<value>888888888@qq.com</value>
<value>6666666666@qq.com</value>
</list>
</property>
1.3Set集合
java
<property name="phones">
<set>
<value>123456789</value>
<value>987654321</value>
<value>987654321</value>
</set>
</property>
1.4List集合
java
<property name="address">
<list>
<value>北京</value>
<value>上海</value>
</list>
</property>
1.5Map集合
java
注意:map---entry--key有特定的标签<key></key>
值根据对应类型选择对应类型的标签
<property name="qqs">
<map>
<entry key="qq" value="123456789"/>
<entry key="wechat" value="123456789"/>
</map>
</property>
1.6Properties
Properties类型 特殊的Map key=String value=String
java
<property name="properties">
<props>
<prop key="wechat">12345678</prop>
<prop key="qq">12345678</prop>
</props>
</property>
2.用户自定义类型
为成员标量提供set get方法
配置文件中进行注入(赋值)
2.1第一种方式
java
<bean id="userService" class="basic.UserServiceImpl">
<property name="userDao">
<bean id="userDao" class="basic.UserDaoImpl"></bean>
</property>
</bean>
2.2第二种方式
- 第一种方式存在的问题
1.配置文件代码冗余
2.被注入的对象(userDao),多次创建,浪费(JVM)内存资源
- 为成员变量提供set get方法
- 配置文件中进行配置
java
<bean id="userDao" class="basic.UserDaoImpl"></bean>
<bean id="userService" class="basic.UserServiceImpl">
<property name="userDao" ref="userDao"></property>
</bean>
4.Set注入简化写法
4.1基于属性简化
JDK类型注入
<property name="name" value="张三"></property>
注意:value属性 只能简化 8种基本数据类型+String 注入标签
用户自定义标签
<bean id="userService" class="basic.UserServiceImpl"> <property name="userDao" ref="userDao"></property> </bean>
4.2基于p命名空间简化
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="userDao" class="basic.UserDaoImpl"></bean> <bean id="userService" class="basic.UserServiceImpl" p:userDao-ref="userDao"></bean>
5.构造注入
注入:通过Spring的配置文件,为成员变量赋值
Set注入:Spring调用Set方法,通过配置文件为成员变量赋值
构造注入:Spring调用构造方法,通过配置文件,为成员变量赋值
1.开发步骤
- 提供有参的构造方法
java
private String name;
private int age;
public Customer(String name, int age) {
this.name = name;
this.age = age;
}
- Spring的配置文件
java
<bean id="customer" class="basic.Customer">
<constructor-arg>
<value>张三</value>
</constructor-arg>
<constructor-arg>
<value>18</value>
</constructor-arg>
</bean>
参数位置对应 并且一个参数对应一个constructor-arg标签
2.构造方法的重载
2.1参数个数不同时
通过控制<constructor-arg>标签的数量进行区分
2.2参数个数相同时
<bean id="customer" class="basic.Customer"> <constructor-arg type="int">//指定类型 <value>18</value> </constructor-arg> </bean>
6.总结
未来实战中,应用set注入还是构造注入?
set注入更到:
1.构造注入麻烦(重载)
2.Spring框架底层 大量应用set注入!