ProxyConfig
这个类主要保存代理的信息,如果是否使用类代理,是否要暴露代理等。
public class ProxyConfig implements Serializable {
/** use serialVersionUID from Spring 1.2 for interoperability. */
private static final long serialVersionUID = -8409359707199703185L;
// 是否代理的对象是类,动态代理分为代理接口和类,这里的属性默认是代理的接口
private boolean proxyTargetClass = false;
// 是否进行主动优化,默认是不会主动优化
private boolean optimize = false;
// 是否由此配置创建的代理不能被转成Advised类型,默认时候可转
boolean opaque = false;
// 是否会暴露代理在调用的时候,默认是不会暴露
boolean exposeProxy = false;
// 是否冻结此配置,不能被修改
private boolean frozen = false;
}
ProxyProcessorSupport
public class ProxyProcessorSupport extends ProxyConfig implements Ordered, BeanClassLoaderAware, AopInfrastructureBean
继承ProxyConfig
实现了Order接口,所以有一个属性private int order = Ordered.LOWEST_PRECEDENCE,最低级别,意味着这个排序的时候排在最后。
实现了BeanClassLoaderAware接口,所以有一个属性private ClassLoader proxyClassLoader = ClassUtils.getDefaultClassLoader();用来保存类加载器的信息。
还有一个自己方法
// beanClass:bean类的原信息
protected void evaluateProxyInterfaces(Class<?> beanClass, ProxyFactory proxyFactory) {
// 获得这个原信息的所有接口
Class<?>[] targetInterfaces = ClassUtils.getAllInterfacesForClass(beanClass, getProxyClassLoader());
boolean hasReasonableProxyInterface = false;
for (Class<?> ifc : targetInterfaces) {
// 遍历接口,是否有可以用的接口,(一些特定的接口是不能作为代理接口的)
if (!isConfigurationCallbackInterface(ifc) && !isInternalLanguageInterface(ifc) &&
ifc.getMethods().length > 0) {
hasReasonableProxyInterface = true;
break;
}
}
// 如果有自己接口可以代理,那么添加到代理工厂中。
if (hasReasonableProxyInterface) {
// 如果有可以代理的接口就方法代理工厂中
for (Class<?> ifc : targetInterfaces) {
proxyFactory.addInterface(ifc);
}
}
// 没有接口可以代理,就设置代理为cglib代理
else {
proxyFactory.setProxyTargetClass(true);
}
}
该方法的功能是查看代理对象是否有可以代理的接口,如果有放入代理工厂中;如果没有,则设置该代理对象使用类代理。
即使是设置的用接口代理,但如果没有可以代理的接口,就会自动改为用类代理