Professional Documents
Culture Documents
Chapter 6. Aspect Oriented Programming With Spring: 6.1.1. AOP Concepts
Chapter 6. Aspect Oriented Programming With Spring: 6.1.1. AOP Concepts
6.1. Introduction
Aspect-Oriented Programming (AOP) complements Object-Oriented Programming (OOP) by providing another
way of thinking about program structure. The key unit of modularity in OOP is the class, whereas in AOP the
unit of modularity is the aspect. Aspects enable the modularization of concerns such as transaction
management that cut across multiple types and objects. (Such concerns are often
termed crosscutting concerns in AOP literature.)
One of the key components of Spring is the AOP framework. While the Spring IoC container does not depend
on AOP, meaning you do not need to use AOP if you don't want to, AOP complements Spring IoC to provide a
very capable middleware solution.
AOP is used in the Spring Framework to...
... provide declarative enterprise services, especially as Spring 2.0 AOP
a replacement for EJB declarative services. The most Spring 2.0 introduces a simpler and more
important such service is declarative transaction powerful way of writing custom aspects using
management. either a schema-based approach or
... allow users to implement custom aspects, the @AspectJ annotation style. Both of these
complementing their use of OOP with AOP. styles offer fully typed advice and use of the
AspectJ pointcut language, while still using
If you are interested only in generic declarative services or Spring AOP for weaving.
other pre-packaged declarative middleware services such as
The Spring 2.0 schema- and @AspectJ-based
pooling, you do not need to work directly with Spring AOP,
AOP support is discussed in this chapter.
and can skip most of this chapter.
Spring 2.0 AOP remains fully backwards
compatible with Spring 1.2 AOP, and the
6.1.1. AOP concepts lower-level AOP support offered by the Spring
Let us begin by defining some central AOP concepts and 1.2 APIs is discussed in the following chapter.
terminology. These terms are not Spring-specific...
unfortunately, AOP terminology is not particularly intuitive;
however, it would be even more confusing if Spring used its own terminology.
Aspect: a modularization of a concern that cuts across multiple classes. Transaction management is a
good example of a crosscutting concern in J2EE applications. In Spring AOP, aspects are implemented
using regular classes (the schema-based approach) or regular classes annotated with
the @Aspect annotation (the @AspectJ style).
Join point: a point during the execution of a program, such as the execution of a method or the handling
of an exception. In Spring AOP, a join point always represents a method execution.
Advice: action taken by an aspect at a particular join point. Different types of advice include "around,"
"before" and "after" advice. (Advice types are discussed below.) Many AOP frameworks, including Spring,
model an advice as an interceptor, maintaining a chain of interceptors around the join point.
Pointcut: a predicate that matches join points. Advice is associated with a pointcut expression and runs
at any join point matched by the pointcut (for example, the execution of a method with a certain name).
The concept of join points as matched by pointcut expressions is central to AOP, and Spring uses the
AspectJ pointcut expression language by default.
Introduction: declaring additional methods or fields on behalf of a type. Spring AOP allows you to
introduce new interfaces (and a corresponding implementation) to any advised object. For example, you
could use an introduction to make a bean implement an IsModified interface, to simplify caching. (An
introduction is known as an inter-type declaration in the AspectJ community.)
Target object: object being advised by one or more aspects. Also referred to as the advised object. Since
Spring AOP is implemented using runtime proxies, this object will always be a proxied object.
AOP proxy: an object created by the AOP framework in order to implement the aspect contracts (advise
method executions and so on). In the Spring Framework, an AOP proxy will be a JDK dynamic proxy or a
CGLIB proxy.
Weaving: linking aspects with other application types or objects to create an advised object. This can be
done at compile time (using the AspectJ compiler, for example), load time, or at runtime. Spring AOP, like
other pure Java AOP frameworks, performs weaving at runtime.
Types of advice:
Before advice: Advice that executes before a join point, but which does not have the ability to prevent
execution flow proceeding to the join point (unless it throws an exception).
After returning advice: Advice to be executed after a join point completes normally: for example, if a
method returns without throwing an exception.
After throwing advice: Advice to be executed if a method exits by throwing an exception.
https://docs.spring.io/spring-framework/docs/2.5.x/reference/aop.html 1/4
7/31/22, 1:30 PM Chapter 6. Aspect Oriented Programming with Spring
After (finally) advice: Advice to be executed regardless of the means by which a join point exits (normal
or exceptional return).
Around advice: Advice that surrounds a join point such as a method invocation. This is the most powerful
kind of advice. Around advice can perform custom behavior before and after the method invocation. It is
also responsible for choosing whether to proceed to the join point or to shortcut the advised method
execution by returning its own return value or throwing an exception.
Around advice is the most general kind of advice. Since Spring AOP, like AspectJ, provides a full range of
advice types, we recommend that you use the least powerful advice type that can implement the required
behavior. For example, if you need only to update a cache with the return value of a method, you are better off
implementing an after returning advice than an around advice, although an around advice can accomplish the
same thing. Using the most specific advice type provides a simpler programming model with less potential for
errors. For example, you do not need to invoke the proceed() method on the JoinPoint used for around
advice, and hence cannot fail to invoke it.
In Spring 2.0, all advice parameters are statically typed, so that you work with advice parameters of the
appropriate type (the type of the return value from a method execution for example) rather
than Object arrays.
The concept of join points, matched by pointcuts, is the key to AOP which distinguishes it from older
technologies offering only interception. Pointcuts enable advice to be targeted independently of the Object-
Oriented hierarchy. For example, an around advice providing declarative transaction management can be
applied to a set of methods spanning multiple objects (such as all business operations in the service layer).
https://docs.spring.io/spring-framework/docs/2.5.x/reference/aop.html 2/4
7/31/22, 1:30 PM Chapter 6. Aspect Oriented Programming with Spring
6.1.3. AOP Proxies
Spring AOP defaults to using standard J2SE dynamic proxies for AOP proxies. This enables any interface (or set
of interfaces) to be proxied.
Spring AOP can also use CGLIB proxies. This is necessary to proxy classes, rather than interfaces. CGLIB is
used by default if a business object does not implement an interface. As it is good practice to program to
interfaces rather than classes, business classes normally will implement one or more business interfaces. It is
possible to force the use of CGLIB, in those (hopefully rare) cases where you need to advise a method that is not
declared on an interface, or where you need to pass a proxied object to a method as a concrete type.
It is important to grasp the fact that Spring AOP is proxy-based. See the section entitled Section 6.6.1,
“Understanding AOP proxies” for a thorough examination of exactly what this implementation detail actually means.
6.2. @AspectJ support
@AspectJ refers to a style of declaring aspects as regular Java classes annotated with Java 5 annotations. The
@AspectJ style was introduced by the AspectJ project as part of the AspectJ 5 release. Spring 2.0 interprets the
same annotations as AspectJ 5, using a library supplied by AspectJ for pointcut parsing and matching. The AOP
runtime is still pure Spring AOP though, and there is no dependency on the AspectJ compiler or weaver.
Using the AspectJ compiler and weaver enables use of the full AspectJ language, and is discussed in Section 6.8,
“Using AspectJ with Spring applications”.
<aop:aspectj-autoproxy/>
This assumes that you are using schema support as described in Appendix A, XML Schema-based configuration.
See Section A.2.7, “The aop schema” for how to import the tags in the aop namespace.
If you are using the DTD, it is still possible to enable @AspectJ support by adding the following definition to
your application context:
You will also need two AspectJ libraries on the classpath of your
application: aspectjweaver.jar and aspectjrt.jar. These libraries are available in the 'lib' directory
of an AspectJ installation (version 1.5.1 or later required), or in the 'lib/aspectj' directory of the Spring-
with-dependencies distribution.
6.2.2. Declaring an aspect
With the @AspectJ support enabled, any bean defined in your application context with a class that is an
@AspectJ aspect (has the @Aspect annotation) will be automatically detected by Spring and used to configure
Spring AOP. The following example shows the minimal definition required for a not-very-useful aspect:
A regular bean definition in the application context, pointing to a bean class that has the @Aspect annotation:
</bean>
package org.xyz;
import org.aspectj.lang.annotation.Aspect;
@Aspect
https://docs.spring.io/spring-framework/docs/2.5.x/reference/aop.html 3/4
7/31/22, 1:30 PM Chapter 6. Aspect Oriented Programming with Spring
Aspects (classes annotated with @Aspect) may have methods and fields just like any other class. They may
also contain pointcut, advice, and introduction (inter-type) declarations.
Advising aspects
In Spring AOP, it is not possible to have aspects themselves be the target of advice from other
aspects. The @Aspect annotation on a class marks it as an aspect, and hence excludes it from auto-
proxying.
6.2.3. Declaring a pointcut
Recall that pointcuts determine join points of interest, and thus enable us to control when advice
executes. Spring AOP only supports method execution join points for Spring beans, so you can think of a
pointcut as matching the execution of methods on Spring beans. A pointcut declaration has two parts: a
signature comprising a name and any parameters, and a pointcut expression that determines exactly which
method executions we are interested in. In the @AspectJ annotation-style of AOP, a pointcut signature is
provided by a regular method definition, and the pointcut expression is indicated using
the @Pointcut annotation (the method serving as the pointcut signature must have a void return type).
An example will help make this distinction between a pointcut signature and a pointcut expression clear. The
following example defines a pointcut named 'anyOldTransfer' that will match the execution of any method
named 'transfer':
The pointcut expression that forms the value of the @Pointcut annotation is a regular AspectJ 5 pointcut
expression. For a full discussion of AspectJ's pointcut language, see the AspectJ Programming Guide (and for Java 5
based extensions, the AspectJ 5 Developers Notebook) or one of the books on AspectJ such as “Eclipse AspectJ” by
Colyer et. al. or “AspectJ in Action” by Ramnivas Laddad.
https://docs.spring.io/spring-framework/docs/2.5.x/reference/aop.html 4/4