Class TransactionAspectSupport
- All Implemented Interfaces:
- Aware,- BeanFactoryAware,- InitializingBean
- Direct Known Subclasses:
- TransactionInterceptor
TransactionInterceptor
 or an AspectJ aspect.
 This enables the underlying Spring transaction infrastructure to be used easily to implement an aspect for any aspect system.
Subclasses are responsible for calling methods in this class in the correct order.
If no transaction name has been specified in the TransactionAttribute,
 the exposed name will be the fully-qualified class name + "." + method name
 (by default).
 
Uses the Strategy design pattern. A PlatformTransactionManager or
 ReactiveTransactionManager implementation will perform the actual transaction
 management, and a TransactionAttributeSource (e.g. annotation-based) is used
 for determining transaction definitions for a particular class or method.
 
A transaction aspect is serializable if its TransactionManager and
 TransactionAttributeSource are serializable.
- Since:
- 1.1
- Author:
- Rod Johnson, Juergen Hoeller, Stéphane Nicoll, Sam Brannen, Mark Paluch, Sebastien Deleuze, Enric Sala
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static interfaceSimple callback interface for proceeding with the target invocation.protected static final classOpaque object used to hold transaction information.
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidCheck that required properties were set.protected voidReset the TransactionInfo ThreadLocal.protected voidClear the transaction manager cache.protected voidExecute after successful completion of call, but not after an exception was handled.protected voidHandle a throwable, completing the transaction.protected TransactionAspectSupport.TransactionInfocreateTransactionIfNecessary(PlatformTransactionManager tm, TransactionAttribute txAttr, String joinpointIdentification) Create a transaction if necessary based on the given TransactionAttribute.protected static TransactionAspectSupport.TransactionInfoSubclasses can use this to return the current TransactionInfo.static TransactionStatusReturn the transaction status of the current method invocation.protected TransactionManagerDetermine the specific transaction manager to use for the given transaction.protected final BeanFactoryReturn the BeanFactory to use for retrievingTransactionManagerbeans.Return the transaction attribute source.Return the default transaction manager, ornullif unknown.protected final StringReturn the name of the default transaction manager bean.protected ObjectinvokeWithinTransaction(Method method, Class<?> targetClass, TransactionAspectSupport.InvocationCallback invocation) General delegate for around-advice-based subclasses, delegating to several other template methods on this class.protected StringmethodIdentification(Method method, Class<?> targetClass) Convenience method to return a String representation of this Method for use in logging.protected TransactionAspectSupport.TransactionInfoprepareTransactionInfo(PlatformTransactionManager tm, TransactionAttribute txAttr, String joinpointIdentification, TransactionStatus status) Prepare a TransactionInfo for the given attribute and status object.voidsetBeanFactory(BeanFactory beanFactory) Set the BeanFactory to use for retrievingTransactionManagerbeans.voidsetTransactionAttributes(Properties transactionAttributes) Set properties with method names as keys and transaction attribute descriptors (parsed via TransactionAttributeEditor) as values: e.g.voidsetTransactionAttributeSource(TransactionAttributeSource transactionAttributeSource) Set the transaction attribute source which is used to find transaction attributes.voidsetTransactionAttributeSources(TransactionAttributeSource... transactionAttributeSources) Set multiple transaction attribute sources which are used to find transaction attributes.voidsetTransactionManager(TransactionManager transactionManager) Specify the default transaction manager to use to drive transactions.voidsetTransactionManagerBeanName(String transactionManagerBeanName) Specify the name of the default transaction manager bean.
- 
Field Details- 
logger
 
- 
- 
Constructor Details- 
TransactionAspectSupportprotected TransactionAspectSupport()
 
- 
- 
Method Details- 
currentTransactionInfo@Nullable protected static TransactionAspectSupport.TransactionInfo currentTransactionInfo() throws NoTransactionExceptionSubclasses can use this to return the current TransactionInfo. Only subclasses that cannot handle all operations in one method, such as an AspectJ aspect involving distinct before and after advice, need to use this mechanism to get at the current TransactionInfo. An around advice such as an AOP Alliance MethodInterceptor can hold a reference to the TransactionInfo throughout the aspect method.A TransactionInfo will be returned even if no transaction was created. The TransactionInfo.hasTransaction()method can be used to query this.To find out about specific transaction characteristics, consider using TransactionSynchronizationManager's isSynchronizationActive()and/orisActualTransactionActive()methods.- Returns:
- the TransactionInfo bound to this thread, or nullif none
- Throws:
- NoTransactionException
- See Also:
 
- 
currentTransactionStatusReturn the transaction status of the current method invocation. Mainly intended for code that wants to set the current transaction rollback-only but not throw an application exception.This exposes the locally declared transaction boundary with its declared name and characteristics, as managed by the aspect. Ar runtime, the local boundary may participate in an outer transaction: If you need transaction metadata from such an outer transaction (the actual resource transaction) instead, consider using TransactionSynchronizationManager.- Throws:
- NoTransactionException- if the transaction info cannot be found, because the method was invoked outside an AOP invocation context
- See Also:
 
- 
setTransactionManagerBeanNameSpecify the name of the default transaction manager bean.This can either point to a traditional PlatformTransactionManageror aReactiveTransactionManagerfor reactive transaction management.
- 
getTransactionManagerBeanNameReturn the name of the default transaction manager bean.
- 
setTransactionManagerSpecify the default transaction manager to use to drive transactions.This can either be a traditional PlatformTransactionManageror aReactiveTransactionManagerfor reactive transaction management.The default transaction manager will be used if a qualifier has not been declared for a given transaction or if an explicit name for the default transaction manager bean has not been specified. 
- 
getTransactionManagerReturn the default transaction manager, ornullif unknown.This can either be a traditional PlatformTransactionManageror aReactiveTransactionManagerfor reactive transaction management.
- 
setTransactionAttributesSet properties with method names as keys and transaction attribute descriptors (parsed via TransactionAttributeEditor) as values: e.g. key = "myMethod", value = "PROPAGATION_REQUIRED,readOnly".Note: Method names are always applied to the target class, no matter if defined in an interface or the class itself. Internally, a NameMatchTransactionAttributeSource will be created from the given properties. 
- 
setTransactionAttributeSourcespublic void setTransactionAttributeSources(TransactionAttributeSource... transactionAttributeSources) Set multiple transaction attribute sources which are used to find transaction attributes. Will build a CompositeTransactionAttributeSource for the given sources.
- 
setTransactionAttributeSourcepublic void setTransactionAttributeSource(@Nullable TransactionAttributeSource transactionAttributeSource) Set the transaction attribute source which is used to find transaction attributes. If specifying a String property value, a PropertyEditor will create a MethodMapTransactionAttributeSource from the value.
- 
getTransactionAttributeSourceReturn the transaction attribute source.
- 
setBeanFactorySet the BeanFactory to use for retrievingTransactionManagerbeans.- Specified by:
- setBeanFactoryin interface- BeanFactoryAware
- Parameters:
- beanFactory- owning BeanFactory (never- null). The bean can immediately call methods on the factory.
- See Also:
 
- 
getBeanFactoryReturn the BeanFactory to use for retrievingTransactionManagerbeans.
- 
afterPropertiesSetpublic void afterPropertiesSet()Check that required properties were set.- Specified by:
- afterPropertiesSetin interface- InitializingBean
 
- 
invokeWithinTransaction@Nullable protected Object invokeWithinTransaction(Method method, @Nullable Class<?> targetClass, TransactionAspectSupport.InvocationCallback invocation) throws Throwable General delegate for around-advice-based subclasses, delegating to several other template methods on this class. Able to handleCallbackPreferringPlatformTransactionManageras well as regularPlatformTransactionManagerimplementations andReactiveTransactionManagerimplementations for reactive return types.- Parameters:
- method- the Method being invoked
- targetClass- the target class that we're invoking the method on
- invocation- the callback to use for proceeding with the target invocation
- Returns:
- the return value of the method, if any
- Throws:
- Throwable- propagated from the target invocation
 
- 
clearTransactionManagerCacheprotected void clearTransactionManagerCache()Clear the transaction manager cache.
- 
determineTransactionManager@Nullable protected TransactionManager determineTransactionManager(@Nullable TransactionAttribute txAttr) Determine the specific transaction manager to use for the given transaction.
- 
methodIdentificationConvenience method to return a String representation of this Method for use in logging. Can be overridden in subclasses to provide a different identifier for the given method.The default implementation returns null, indicating the use ofDefaultTransactionAttribute.getDescriptor()instead, ending up asClassUtils.getQualifiedMethodName(Method, Class).- Parameters:
- method- the method we're interested in
- targetClass- the class that the method is being invoked on
- Returns:
- a String representation identifying this method
- See Also:
 
- 
createTransactionIfNecessaryprotected TransactionAspectSupport.TransactionInfo createTransactionIfNecessary(@Nullable PlatformTransactionManager tm, @Nullable TransactionAttribute txAttr, String joinpointIdentification) Create a transaction if necessary based on the given TransactionAttribute.Allows callers to perform custom TransactionAttribute lookups through the TransactionAttributeSource. - Parameters:
- txAttr- the TransactionAttribute (may be- null)
- joinpointIdentification- the fully qualified method name (used for monitoring and logging purposes)
- Returns:
- a TransactionInfo object, whether a transaction was created.
 The hasTransaction()method on TransactionInfo can be used to tell if there was a transaction created.
- See Also:
 
- 
prepareTransactionInfoprotected TransactionAspectSupport.TransactionInfo prepareTransactionInfo(@Nullable PlatformTransactionManager tm, @Nullable TransactionAttribute txAttr, String joinpointIdentification, @Nullable TransactionStatus status) Prepare a TransactionInfo for the given attribute and status object.- Parameters:
- txAttr- the TransactionAttribute (may be- null)
- joinpointIdentification- the fully qualified method name (used for monitoring and logging purposes)
- status- the TransactionStatus for the current transaction
- Returns:
- the prepared TransactionInfo object
 
- 
commitTransactionAfterReturningprotected void commitTransactionAfterReturning(@Nullable TransactionAspectSupport.TransactionInfo txInfo) Execute after successful completion of call, but not after an exception was handled. Do nothing if we didn't create a transaction.- Parameters:
- txInfo- information about the current transaction
 
- 
completeTransactionAfterThrowingprotected void completeTransactionAfterThrowing(@Nullable TransactionAspectSupport.TransactionInfo txInfo, Throwable ex) Handle a throwable, completing the transaction. We may commit or roll back, depending on the configuration.- Parameters:
- txInfo- information about the current transaction
- ex- throwable encountered
 
- 
cleanupTransactionInfoReset the TransactionInfo ThreadLocal.Call this in all cases: exception or normal return! - Parameters:
- txInfo- information about the current transaction (may be- null)
 
 
-