官方网址:projects.spring.io/spring-framework
一、Spring优势
① 轻量级:Spring是非侵入性的,应用开发可不依赖Spring的API,即不需要继承和实现框架的任何类和接口
② 依赖注入:DI
③ 面向切面编程:AOP
④ 框架:可以利用XML和Java注解组合对象
⑤ 一站式:IOC和AOP的基础上可以整合各种企业级应用开源框架和第三方类库
二、入门Spring基本配置
2.0 准备工作
必须先学会xml文件的配置,schema的使用以及java基础
2.0.1 maven配置Spring框架的依赖以及配置jdk版本,也可手动导入下述依赖包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<groupId>org.spring.learning</groupId>
<artifactId>spring框架学习</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>4.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>4.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>4.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.0.2.RELEASE</version>
</dependency>
</dependencies>
</project>
2.0.2 配置一个log4j2的日志配置文件:
log4j2.xml配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->
<!--Configuration后面的status,这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,你会看到log4j2内部各种详细输出-->
<!--monitorInterval:Log4j能够自动检测修改配置 文件和重新配置本身,设置间隔秒数-->
<configuration status="INFO" monitorInterval="30">
<!--先定义所有的appender-->
<appenders>
<!--这个输出控制台的配置-->
<console name="Console" target="SYSTEM_OUT">
<!--输出日志的格式-->
<PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
</console>
<!--文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,这个也挺有用的,适合临时测试用-->
<File name="log" fileName="log/test.log" append="false">
<PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
</File>
<!-- 这个会打印出所有的info及以下级别的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档-->
<RollingFile name="RollingFileInfo" fileName="${sys:user.home}/logs/info.log"
filePattern="${sys:user.home}/logs/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log">
<!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch)-->
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
</RollingFile>
<RollingFile name="RollingFileWarn" fileName="${sys:user.home}/logs/warn.log"
filePattern="${sys:user.home}/logs/$${date:yyyy-MM}/warn-%d{yyyy-MM-dd}-%i.log">
<ThresholdFilter level="warn" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
<!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件,这里设置了20 -->
<DefaultRolloverStrategy max="20"/>
</RollingFile>
<RollingFile name="RollingFileError" fileName="${sys:user.home}/logs/error.log"
filePattern="${sys:user.home}/logs/$${date:yyyy-MM}/error-%d{yyyy-MM-dd}-%i.log">
<ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
</RollingFile>
</appenders>
<!--然后定义logger,只有定义了logger并引入的appender,appender才会生效-->
<loggers>
<!--过滤掉spring和mybatis的一些无用的DEBUG信息-->
<logger name="org.springframework" level="INFO"/>
<logger name="org.mybatis" level="INFO"/>
<root level="all">
<appender-ref ref="Console"/>
<appender-ref ref="RollingFileInfo"/>
<appender-ref ref="RollingFileWarn"/>
<appender-ref ref="RollingFileError"/>
</root>
</loggers>
</configuration>
2.1 开发过程
① 配置xml文件,设置属性
② 创建ApplicationContext 对象
③ 通过反射获取对象,使用属性注入,属性注入必须要有一个无参构造方法
2.2 加载xml文件的方式
① ClassPathXmlApplicationContext 从类路径下加载配置文件
② FileSystemXmlApplicationContext 从文件系统中加载配置文件
③ ConfigurableApplicationContext 扩展于ApplicationContext 新增两个方法refresh和close 用于启动 刷新 关闭 上下文
2.3 获取Bean对象
源码中提供了如下类:
建议使用id+类名的方法,可以避免很多类的强制转换从而带来安全隐患,而对于泛型类则仍需要强制类型转换
@Override
public Object getBean(String name) throws BeansException {
assertBeanFactoryActive();
return getBeanFactory().getBean(name);
}
@Override
public <T> T getBean(String name, Class<T> requiredType) throws BeansException {
assertBeanFactoryActive();
return getBeanFactory().getBean(name, requiredType);
}
@Override
public <T> T getBean(Class<T> requiredType) throws BeansException {
assertBeanFactoryActive();
return getBeanFactory().getBean(requiredType);
}
@Override
public Object getBean(String name, Object... args) throws BeansException {
assertBeanFactoryActive();
return getBeanFactory().getBean(name, args);
}
三、HelloWord入门测试
创建文件到类路径(其他类似)ApplicationContext.xml文件,增加schema约束,以及添加对应的schemaLocation,总体配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.springframework.org/schema/beans"
xmlns:util="http://www.springframework.org/schema/util"
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
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util.xsd">
<!-- 配置bean 属性注入,实际需要调用无参构造函数得到对象,然后使用set方法 -->
<bean id="helloWord1" class="com.spring.hellowrod.HelloWord">
<property name="name" value="Spring"/>
<property name="age" value="25"/>
</bean>
</beans>
3.1 编写测试的类HelloWorld
HelloWorld类如下:
/**
* Created with IntelliJ IDEA.
* User: gxm
* Date: 2020/4/7
* Time: 17:09
* To change this template use File | Settings | File Templates.
* Description:
**/
package com.spring.hellowrod;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import java.util.logging.Logger;
/**
* @author gxm
*/
public class HelloWord {
private static final Logger logger = Logger.getLogger(HelloWord.class.getName());
private String name;
private int age;
public HelloWord(String name, int age) {
this.name = name;
this.age = age;
System.out.println("调用构造方法1");
}
public HelloWord(int age, String name) {
this.name = name;
this.age = age;
System.out.println("调用构造方法2");
}
// 提供无参构造方法,供属性注入使用
public HelloWord() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
System.out.println("set name");
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
System.out.println("set age");
}
public void hello() {
System.out.println("hello " + name);
}
public static void main(String[] args) throws IllegalAccessException, InstantiationException {
ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml");
HelloWord helloWord = applicationContext.getBean("specialWord", HelloWord.class);
helloWord.hello();
logger.info("test");
}
}