First of all. Do not choose aspect-oriented programming to solve everyday Java problems. Example of good cases are:
- Error Handling
The Logic class:
The Aspect class: Boilerplate XML configuration files
And now call it
The problem with the code above, is that in FooPojo there is no hint at all, that other code will be called. This can be very confusing for a junior programmer and also to a much more skilled programmer that is not familiar with AOP. So how to make AOP more clearer and more understandable? The answer is to look at other framework and how they have solved it. Take for example Spring. They use AOP very heavily under the hood, to solve common tasks as marking classes as transactional (@Transactional). And in J2EE, Oracle uses also Annotation, e.g. in JAX-WS they have the method Annotation @WebMethod, to signal that a method is a Web Service method. So lets copy that pattern, to write your own Annotation, as marker in the code that you want to apply apsect-oriented programming to. Our own Annotation, to trigger Aspect:
Our Aspect. Here we use interface implementation. This solution works on JBoss 4.3.0 - 5.1.0:
The JBoss AOP configuration file, META-INF/jboss-aop.xml
Now lets create a Test class, that we annotate with our own Annotation:
And a Unit Test to verify it is working.
And here is the maven pom.xml
To make the example complete, we also need to supply a log4j configuration file.
To run/debug this inside Eclipse we need to copy the argLine from the maven pom file to the unit test file configuration.
For more about JBoss AOP Maven plugin , see http://community.jboss.org/wiki/JBossAOPMavenPlugin.