Save This Page
Home » spring-framework-2.5.5-with-dependencies » org.springframework » aop » framework » [javadoc | source]
org.springframework.aop.framework
public class: ProxyFactoryBean [javadoc | source]
java.lang.Object
   org.springframework.aop.framework.ProxyConfig
      org.springframework.aop.framework.AdvisedSupport
         org.springframework.aop.framework.ProxyCreatorSupport
            org.springframework.aop.framework.ProxyFactoryBean

All Implemented Interfaces:
    BeanClassLoaderAware, BeanFactoryAware, FactoryBean, Advised, Serializable

org.springframework.beans.factory.FactoryBean implementation that builds an AOP proxy based on beans in Spring org.springframework.beans.factory.BeanFactory .

MethodInterceptors and Advisors are identified by a list of bean names in the current bean factory, specified through the "interceptorNames" property. The last entry in the list can be the name of a target bean or a org.springframework.aop.TargetSource ; however, it is normally preferable to use the "targetName"/"target"/"targetSource" properties instead.

Global interceptors and advisors can be added at the factory level. The specified ones are expanded in an interceptor list where an "xxx*" entry is included in the list, matching the given prefix with the bean names (e.g. "global*" would match both "globalBean1" and "globalBean2", "*" all defined interceptors). The matching interceptors get applied according to their returned order value, if they implement the org.springframework.core.Ordered interface.

Creates a JDK proxy when proxy interfaces are given, and a CGLIB proxy for the actual target class if not. Note that the latter will only work if the target class does not have final methods, as a dynamic subclass will be created at runtime.

It's possible to cast a proxy obtained from this factory to Advised , or to obtain the ProxyFactoryBean reference and programmatically manipulate it. This won't work for existing prototype references, which are independent. However, it will work for prototypes subsequently obtained from the factory. Changes to interception will work immediately on singletons (including existing references). However, to change interfaces or target it's necessary to obtain a new instance from the factory. This means that singleton instances obtained from the factory do not have the same object identity. However, they do have the same interceptors and target, and changing any reference will change all objects.

Field Summary
public static final  String GLOBAL_SUFFIX    This suffix in a value in an interceptor list indicates to expand globals. 
protected final  Log logger     
Fields inherited from org.springframework.aop.framework.AdvisedSupport:
EMPTY_TARGET_SOURCE,  targetSource,  advisorChainFactory
Fields inherited from org.springframework.aop.framework.ProxyConfig:
opaque,  exposeProxy
Method from org.springframework.aop.framework.ProxyFactoryBean Summary:
adviceChanged,   createCompositeInterface,   getObject,   getObjectType,   getProxy,   isSingleton,   setAdvisorAdapterRegistry,   setAutodetectInterfaces,   setBeanClassLoader,   setBeanFactory,   setFrozen,   setInterceptorNames,   setProxyClassLoader,   setProxyInterfaces,   setSingleton,   setTargetName
Methods from org.springframework.aop.framework.ProxyCreatorSupport:
addListener,   adviceChanged,   createAopProxy,   getAopProxyFactory,   isActive,   removeListener,   setAopProxyFactory
Methods from org.springframework.aop.framework.AdvisedSupport:
addAdvice,   addAdvice,   addAdvisor,   addAdvisor,   addAllAdvisors,   addInterface,   adviceChanged,   adviceIncluded,   copyConfigurationFrom,   copyConfigurationFrom,   countAdvicesOfType,   getAdvisorChainFactory,   getAdvisors,   getAdvisorsInternal,   getConfigurationOnlyCopy,   getInterceptorsAndDynamicInterceptionAdvice,   getProxiedInterfaces,   getTargetClass,   getTargetSource,   indexOf,   indexOf,   isInterfaceProxied,   isPreFiltered,   removeAdvice,   removeAdvisor,   removeAdvisor,   removeInterface,   replaceAdvisor,   setAdvisorChainFactory,   setInterfaces,   setPreFiltered,   setTarget,   setTargetClass,   setTargetSource,   toProxyConfigString,   toString,   updateAdvisorArray
Methods from org.springframework.aop.framework.ProxyConfig:
copyFrom,   isExposeProxy,   isFrozen,   isOpaque,   isOptimize,   isProxyTargetClass,   setExposeProxy,   setFrozen,   setOpaque,   setOptimize,   setProxyTargetClass,   toString
Methods from java.lang.Object:
equals,   getClass,   hashCode,   notify,   notifyAll,   toString,   wait,   wait,   wait
Method from org.springframework.aop.framework.ProxyFactoryBean Detail:
 protected  void adviceChanged() 
    Blow away and recache singleton on an advice change.
 protected Class createCompositeInterface(Class[] interfaces) 
    Create a composite interface Class for the given interfaces, implementing the given interfaces in one single Class.

    The default implementation builds a JDK proxy class for the given interfaces.

 public Object getObject() throws BeansException 
    Return a proxy. Invoked when clients obtain beans from this factory bean. Create an instance of the AOP proxy to be returned by this factory. The instance will be cached for a singleton, and create on each call to getObject() for a proxy.
 public Class getObjectType() 
    Return the type of the proxy. Will check the singleton instance if already created, else fall back to the proxy interface (in case of just a single one), the target bean type, or the TargetSource's target class.
 protected Object getProxy(AopProxy aopProxy) 
    Return the proxy object to expose.

    The default implementation uses a getProxy call with the factory's bean class loader. Can be overridden to specify a custom class loader.

 public boolean isSingleton() 
 public  void setAdvisorAdapterRegistry(AdvisorAdapterRegistry advisorAdapterRegistry) 
    Specify the AdvisorAdapterRegistry to use. Default is the global AdvisorAdapterRegistry.
 public  void setAutodetectInterfaces(boolean autodetectInterfaces) 
    Set whether to autodetect proxy interfaces if none specified.

    Default is "true". Turn this flag off to create a CGLIB proxy for the full target class if no interfaces specified.

 public  void setBeanClassLoader(ClassLoader classLoader) 
 public  void setBeanFactory(BeanFactory beanFactory) 
 public  void setFrozen(boolean frozen) 
 public  void setInterceptorNames(String[] interceptorNames) 
    Set the list of Advice/Advisor bean names. This must always be set to use this factory bean in a bean factory.

    The referenced beans should be of type Interceptor, Advisor or Advice The last entry in the list can be the name of any bean in the factory. If it's neither an Advice nor an Advisor, a new SingletonTargetSource is added to wrap it. Such a target bean cannot be used if the "target" or "targetSource" or "targetName" property is set, in which case the "interceptorNames" array must contain only Advice/Advisor bean names.

    NOTE: Specifying a target bean as final name in the "interceptorNames" list is deprecated and will be removed in a future Spring version. Use the "targetName" property instead.

 public  void setProxyClassLoader(ClassLoader classLoader) 
    Set the ClassLoader to generate the proxy class in.

    Default is the bean ClassLoader, i.e. the ClassLoader used by the containing BeanFactory for loading all bean classes. This can be overridden here for specific proxies.

 public  void setProxyInterfaces(Class[] proxyInterfaces) throws ClassNotFoundException 
    Set the names of the interfaces we're proxying. If no interface is given, a CGLIB for the actual class will be created.

    This is essentially equivalent to the "setInterfaces" method, but mirrors TransactionProxyFactoryBean's "setProxyInterfaces".

 public  void setSingleton(boolean singleton) 
    Set the value of the singleton property. Governs whether this factory should always return the same proxy instance (which implies the same target) or whether it should return a new prototype instance, which implies that the target and interceptors may be new instances also, if they are obtained from prototype bean definitions. This allows for fine control of independence/uniqueness in the object graph.
 public  void setTargetName(String targetName) 
    Set the name of the target bean. This is an alternative to specifying the target name at the end of the "interceptorNames" array.

    You can also specify a target object or a TargetSource object directly, via the "target"/"targetSource" property, respectively.