Spring 源码阅读 AOP一
2016-11-12 21:48
253 查看
Spring AOP本质是用了代理模式和反射机制实现的。
来看下常用的几个接口:
Advice:这是一个空接口,里面没有任何方法,来标识一个通知。所有通知都实现此接口,如BeforeAdvice和AfterAdvice.
PointCut:决定Aop通知作哪个连接点。
Advisor:通知器或者通知者,我们从现实角度来说,通知者当然需要知道要通知什么。所以Advisor依赖于Advice,而Advisor旗下的子接口PointAdvisor还依赖于Pointcut,也就是说这个接口更确切的定位应该是包含了要通知谁和要通知什么,也就是说要能获得Advice和Pointcut。
JoinPoint:代表了一个运行时的连接点。
Invocation:代表了程序的一个调用,可以被拦截器interceptor拦截。
@SuppressWarnings("serial")
public class ProxyFactoryBean extends ProxyCreatorSupport
implements FactoryBean<Object>, BeanClassLoaderAware, BeanFactoryAware {
/**
* This suffix in a value in an interceptor list indicates to expand globals.
*/
public static final String GLOBAL_SUFFIX = "*";
protected final Log logger = LogFactory.getLog(getClass());
private String[] interceptorNames;
private String targetName;
private boolean autodetectInterfaces = true;
private boolean singleton = true;
private AdvisorAdapterRegistry advisorAdapterRegistry = GlobalAdvisorAdapterRegistry.getInstance();
private boolean freezeProxy = false;
private transient ClassLoader proxyClassLoader = ClassUtils.getDefaultClassLoader();
private transient boolean classLoaderConfigured = false;
private transient BeanFactory beanFactory;
这里没有贴出全部代码:可以看到2个重要的属性,interceptorname和targetname.前者代表的是需要加强哪些东西以及需要怎样加强,也就是advice和pointcut。而后者代表的则是我们针对谁来做这些加强,即我们的目标对象。
来看下常用的几个接口:
Advice:这是一个空接口,里面没有任何方法,来标识一个通知。所有通知都实现此接口,如BeforeAdvice和AfterAdvice.
PointCut:决定Aop通知作哪个连接点。
Advisor:通知器或者通知者,我们从现实角度来说,通知者当然需要知道要通知什么。所以Advisor依赖于Advice,而Advisor旗下的子接口PointAdvisor还依赖于Pointcut,也就是说这个接口更确切的定位应该是包含了要通知谁和要通知什么,也就是说要能获得Advice和Pointcut。
JoinPoint:代表了一个运行时的连接点。
Invocation:代表了程序的一个调用,可以被拦截器interceptor拦截。
@SuppressWarnings("serial")
public class ProxyFactoryBean extends ProxyCreatorSupport
implements FactoryBean<Object>, BeanClassLoaderAware, BeanFactoryAware {
/**
* This suffix in a value in an interceptor list indicates to expand globals.
*/
public static final String GLOBAL_SUFFIX = "*";
protected final Log logger = LogFactory.getLog(getClass());
private String[] interceptorNames;
private String targetName;
private boolean autodetectInterfaces = true;
private boolean singleton = true;
private AdvisorAdapterRegistry advisorAdapterRegistry = GlobalAdvisorAdapterRegistry.getInstance();
private boolean freezeProxy = false;
private transient ClassLoader proxyClassLoader = ClassUtils.getDefaultClassLoader();
private transient boolean classLoaderConfigured = false;
private transient BeanFactory beanFactory;
这里没有贴出全部代码:可以看到2个重要的属性,interceptorname和targetname.前者代表的是需要加强哪些东西以及需要怎样加强,也就是advice和pointcut。而后者代表的则是我们针对谁来做这些加强,即我们的目标对象。
相关文章推荐
- Spring 源码阅读之BeanFactory
- Spring工具类的源码阅读(更新中~)
- Spring源码阅读——BeanFactory体系结构
- Spring源码阅读入门指引
- Spring 源码阅读 一
- spring源码下载及与myeclipse集成阅读
- Spring源码阅读--AbstractApplicationContext refresh()方法调用
- spring-mvc源码阅读(三)RequestMappingHandlerMapping
- spring-mvc源码阅读(二)<mvc:annotation-driven/>做了什么
- Spring源码阅读:IOC容器的设计与实现(二)——ApplicationContext
- Spring IOC 源码阅读资源加载和注册
- 初始化IoC容器(Spring源码阅读)
- 初始化IoC容器(Spring源码阅读)-我们到底能走多远系列(31)
- Spring源码阅读——获得bean
- Spring 源码阅读(二)——Spring的初始化以及资源加载
- Spring IoC容器在Web环境中的启动源码阅读
- Spring源码阅读之IoC容器初始化3 -- BeanDefinition在IoC容器中的注册
- Spring源码阅读1---导入eclipse
- Spring源码阅读笔记(待补充)
- Spring源码阅读系列总结