文章目录
BeanFactory
结构图
名字 | 作用 |
---|---|
BeanFactory | 顶端接口,最主要的方法就是getBean,其他功能通过其他接口不断扩展 |
ListableBeanFactory | 提供访问容器中bean的一些基本方法,比如bean的个数,bean的名称,容器中是否包含某个bean等 |
HierarchicalBeanFactory | ioc子容器可以通过其中方法访问到父容器 |
ConfigurableBeanFactory | 增加了ioc容器的可定制性,它定义了设置类装载器,属性编辑器,容器初始化后置处理器等 |
AutowireCapableBeanFactory | 定义了容器中的bean按某种规则自动装配,名称类型等 |
ConfigurableListableBeanFactory | 提供bean definition的解析,注册功能,再对单例来个预加载(解决循环依赖问题) |
SingletonBeanRegistry | 定义了在运行期间向容器注册单例bean的方法 |
BeanDefinitionRegistry | 提供了向容器手工注册BeanDefinition对象的方法 |
AliasRegistry | 别名管理接口,给bean添加别名,删除别名等 |
用这种方法加载的bean只会在第一次调用时初始化,而不是项目启动时就初始化
基本使用
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--bean就是java对象 , 由Spring创建和管理-->
<bean id="hello" name="ck,cql" class="pojo.hello" >
<property name="name" value="Spring"/>
</bean>
<alias name="hello" alias="gs"></alias>
</beans>
public class test {
public static void main(String[] args) {
//Resolver读取配置文件 转换成Resource
ResourcePatternResolver pathMatchingResourcePatternResolver = new PathMatchingResourcePatternResolver();
Resource resource = pathMatchingResourcePatternResolver.getResource("beans.xml");
//创建bean工厂
DefaultListableBeanFactory defaultListableBeanFactory = new DefaultListableBeanFactory();
//加载工厂然后生产bean
XmlBeanDefinitionReader xmlBeanDefinitionReader = new XmlBeanDefinitionReader(defaultListableBeanFactory);
xmlBeanDefinitionReader.loadBeanDefinitions(resource);
hello hello = (hello)defaultListableBeanFactory.getBean("hello");
System.out.println(hello.getName());
}
}
ApplicationContext
名字 | 作用 |
---|---|
ApplicationEventPublisher | 让容器拥有发布应用上下文的功能,包括容器启动事件,关闭事件。实现了ApplicationListener接口的bean可以接受到容器事件。ApplicationContext的抽象实现类AbstractApplicationContext中有个applicationEventMulticaster保存所有的监听器,在事件触发时通知 |
MessageSource | 国际化功能 |
ResourcePatternResolver | 提供了可以读取配置文件的功能 |
Lifecycle | 提供了start()和stop()接口,主要用于控制异步处理过程。 |
ConfigurableApplicationContext | 让ApplicationContext可以刷新,启动,关闭容器的功能,refresh()在关闭的时候可以启动,在启动时可以刷新容器。 |
用这种方法加载的bean在项目启动时就会全部加载完毕
基本使用(通用)
配置文件
public class test {
public static void main(String[] args) {
//FileSystemXmlApplicationContext 文件路径获取bean配置
FileSystemXmlApplicationContext applicationContext = new FileSystemXmlApplicationContext("D:\\testWorkbase\\springTest\\src\\main\\resources\\beans.xml");
//ClassPathXmlApplicationContext 类路径获取bean配置
ClassPathXmlApplicationContext applicationContext1 = new ClassPathXmlApplicationContext("beans.xml");
hello hello = (hello)applicationContext.getBean("hello");
hello.show();
}
}
注解形式
@Configuration
public class bean {
@Bean("nihao")
public hello getbean()
{
hello hello = new hello();
hello.setName("ck");
return hello;
}
}
public class test {
public static void main(String[] args) {
ApplicationContext ApplicationContext = new AnnotationConfigApplicationContext(bean.class);
hello hello = (hello)ApplicationContext.getBean("nihao");
hello.show();
}
}
WebApplicationContext(针对web加强)
实现于ApplicationContext针对Web应用的扩展
WebApplicationContext 提供了可以获取ServletContext的方法
ConfigurableWebApplicationContext 允许通过配置的方式实例化WebApplicationContext 其中方法
void setServletContext(@Nullable ServletContext var1);设置ServletContext
void setServletConfig(@Nullable ServletConfig var1);设置ServletConfig
void setConfigLocations(String… var1);设置bean的配置文件路径。
在web中配置ApplicationContext(xml文件)
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0"
metadata-complete="false">
<context-param>
<!-- 固定name要为contextConfigLocation -->
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/bean.xml</param-value>
</context-param>
<!-- 监听器固定为这个类 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
</web-app>
在web中获取ApplicationContext
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//从ServletContext获取WebApplicationContext
ServletContext servletContext = req.getServletContext();
WebApplicationContext attribute = (WebApplicationContext)servletContext.getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE);
//从WebApplicationContext 中获取ServletContext
ServletContext servletContext1 = attribute.getServletContext();
}
在web中配置ApplicationContext(java文件)
配置类
@Configuration
public class bean {
@Bean("ck")
public hello getbean()
{
hello hello = new hello();
hello.setName("ck");
return hello;
}
@Bean("gs")
public hello getbean1()
{
hello hello = new hello();
hello.setName("gs");
return hello;
}
}
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0"
metadata-complete="false">
<!--固定写法-->
<context-param>
<param-name>contextClass</param-name>
<param-value>org.springframework.web.context.support.AnnotationConfigWebApplicationContext</param-value>
</context-param>
<!--name固定-->
<context-param>
<param-name>contextConfigLocation</param-name>
<!--配置类,多个可用逗号或者空格分开-->
<param-value>com.chenke.servlet.config.bean</param-value>
</context-param>
<!--监听器固定写法-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
</web-app>
读取bean
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
ServletContext servletContext = req.getServletContext();
WebApplicationContext attribute = (WebApplicationContext)servletContext.getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE);
hello hello = attribute.getBean("ck", hello.class);
hello hello1 = attribute.getBean("gs", hello.class);
hello.show();
hello1.show();
}
配置log4j日志
Log4jServletContextListener必须配置在ContextLoaderListener前
导入依赖
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
<version>2.12.0</version>
</dependency>
配置
<context-param>
<param-name>log4jConfiguration</param-name>
<param-value>classpath:log4j2.xml</param-value>
</context-param>
<!--log4j-->
<listener>
<listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class>
</listener>
<filter>
<filter-name>log4jServletFilter</filter-name>
<filter-class>org.apache.logging.log4j.web.Log4jServletFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>log4jServletFilter</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
<dispatcher>ERROR</dispatcher>
</filter-mapping>
log4j配置类 resources文件夹下
<?xml version="1.0" encoding="UTF-8"?>
<!-- status:这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,会看到log4j2内部各种详细输出。
monitorInterval:Log4j能够自动检测修改配置文件和重新配置本身, 设置间隔秒数。
注:本配置文件的目标是将不同级别的日志输出到不同文件,最大2MB一个文件, 文件数据达到最大值时,旧数据会被压缩并放进指定文件夹 -->
<Configuration status="off" monitorInterval="1800">
<properties>
<!-- 配置日志文件输出目录-->
<property name="LOG_HOME">/WEB-INF/logs</property>
<!-- 配置日志文件输出目录,此配置将日志输出到项目根目录 -->
<property name="LOG_ROOT">${web:rootDir}</property>
<!-- 配置日志文件输出目录,输出文件名 -->
<property name="FILE_NAME">ubs</property>
</properties>
<Appenders>
<!-- 优先级从高到低分别是 OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL -->
<!-- 单词解释: Match:匹配 DENY:拒绝 Mismatch:不匹配 ACCEPT:接受 -->
<!-- DENY,日志将立即被抛弃不再经过其他过滤器; NEUTRAL,有序列表里的下个过滤器过接着处理日志; ACCEPT,日志会被立即处理,不再经过剩余过滤器。 -->
<!--输出日志的格式
%d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间
%p : 日志输出格式
%c : logger的名称
%m : 日志内容,即 logger.info("message")
%n : 换行符
%C : Java类名
%L : 日志输出所在行数
%M : 日志输出所在方法名
hostName : 本地机器名
hostAddress : 本地ip地址 -->
<!--这个输出控制台的配置,这里输出DEBUG及以上级别的信息到System.out -->
<Console name="Console" target="SYSTEM_OUT">
<!-- 控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) . -->
<ThresholdFilter level="DEBUG" onMatch="ACCEPT" onMismatch="DENY" />
<!-- 输出日志的格式 -->
<PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n" />
<!-- <PatternLayout pattern="%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n" /> -->
</Console>
<!-- 这个输出控制台的配置,这里输出error及以上级别的信息到System.err,在eclipse控制台上看到的是红色文字 -->
<Console name="console_err" target="SYSTEM_ERR">
<ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY" />
<PatternLayout pattern="%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n" />
</Console>
<!-- TRACE级别日志 ; 设置日志格式并配置日志压缩格式,压缩文件独立放在一个文件夹内, 日期格式不能为冒号,否则无法生成,因为文件名不允许有冒号,此appender只输出trace级别的数据到trace.log -->
<RollingFile name="trace_appender" immediateFlush="true" fileName="${LOG_HOME}/trace.log" filePattern="${LOG_HOME}/trace/trace - %d{yyyy-MM-dd HH_mm_ss}.log.gz">
<PatternLayout>
<pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern>
</PatternLayout>
<Policies>
<!-- 每个日志文件最大2MB -->
<SizeBasedTriggeringPolicy size="2MB" />
</Policies>
<Filters>
<!-- 此Filter意思是,只输出TRACE级别的数据 DENY,日志将立即被抛弃不再经过其他过滤器; NEUTRAL,有序列表里的下个过滤器过接着处理日志;ACCEPT,日志会被立即处理,不再经过剩余过滤器。 -->
<ThresholdFilter level="debug" onMatch="DENY" onMismatch="NEUTRAL" />
<ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY" />
</Filters>
</RollingFile>
<!-- DEBUG级别日志 设置日志格式并配置日志压缩格式,压缩文件独立放在一个文件夹内, 日期格式不能为冒号,否则无法生成,因为文件名不允许有冒号,此appender只输出debug级别的数据到debug.log; -->
<RollingFile name="debug_appender" immediateFlush="true" fileName="${LOG_HOME}/debug.log" filePattern="${LOG_HOME}/debug/debug - %d{yyyy-MM-dd HH_mm_ss}.log.gz">
<PatternLayout>
<pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern>
</PatternLayout>
<Policies>
<!-- 每个日志文件最大2MB ; -->
<SizeBasedTriggeringPolicy size="2MB" />
<!-- 如果启用此配置,则日志会按文件名生成新压缩文件, 即如果filePattern配置的日期格式为 %d{yyyy-MM-dd HH},则每小时生成一个压缩文件, 如果filePattern配置的日期格式为 %d{yyyy-MM-dd} ,则天生成一个压缩文件 -->
<TimeBasedTriggeringPolicy interval="1" modulate="true" />
</Policies>
<Filters>
<!-- 此Filter意思是,只输出debug级别的数据 -->
<ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL" />
<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
</Filters>
</RollingFile>
<!-- INFO级别日志 -->
<RollingFile name="info_appender" immediateFlush="true" fileName="${LOG_HOME}/info.log" filePattern="${LOG_HOME}/info/info - %d{yyyy-MM-dd HH_mm_ss}.log.gz">
<PatternLayout>
<pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern>
</PatternLayout>
<Policies>
<SizeBasedTriggeringPolicy size="2MB" />
</Policies>
<Filters>
<ThresholdFilter level="warn" onMatch="DENY" onMismatch="NEUTRAL" />
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
</Filters>
</RollingFile>
<!-- WARN级别日志 -->
<RollingFile name="warn_appender" immediateFlush="true" fileName="${LOG_HOME}/warn.log" filePattern="${LOG_HOME}/warn/warn - %d{yyyy-MM-dd HH_mm_ss}.log.gz">
<PatternLayout>
<pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern>
</PatternLayout>
<Policies>
<SizeBasedTriggeringPolicy size="2MB" />
</Policies>
<Filters>
<ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL" />
<ThresholdFilter level="warn" onMatch="ACCEPT" onMismatch="DENY" />
</Filters>
</RollingFile>
<!-- ERROR级别日志 -->
<RollingFile name="error_appender" immediateFlush="true" fileName="${LOG_HOME}/error.log" filePattern="${LOG_HOME}/error/error - %d{yyyy-MM-dd HH_mm_ss}.log.gz">
<PatternLayout>
<pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern>
</PatternLayout>
<Policies>
<SizeBasedTriggeringPolicy size="2MB" />
</Policies>
<Filters>
<ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY" />
</Filters>
</RollingFile>
<File name="info" fileName="${web:rootDir}/../../ubslogs/ubsinfo.log" append="true">
<Filters>
<ThresholdFilter level="WARN" onMatch="DENY" onMismatch="NEUTRAL" />
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
</Filters>
<PatternLayout pattern="%d{yyyy.MM.dd HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n" />
</File>
<File name="error" fileName="${web:rootDir}/../../ubslogs/ubserror.log" append="true">
<Filters>
<ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY" />
</Filters>
<PatternLayout pattern="%d{yyyy.MM.dd HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n" />
</File>
</Appenders>
<Loggers>
<!-- 配置日志的根节点 -->
<!-- 定义logger,只有定义了logger并引入了appender,appender才会生效 -->
<Root level="trace" additivity="false">
<!-- 这里是输入到控制台-->
<AppenderRef ref="Console"/>
<AppenderRef ref="console_err"/>
<!-- 这里是输入到文件,很重要-->
<AppenderRef ref="trace_appender"/>
<AppenderRef ref="debug_appender"/>
<AppenderRef ref="info_appender"/>
<AppenderRef ref="warn_appender"/>
<AppenderRef ref="error_appender"/>
<AppenderRef ref="info"/>
<AppenderRef ref="error"/>
</Root>
</Loggers>
</Configuration>