AOP
Lösung für Querschnittsaufgaben
Was ist AOP ?
AOP ist kein Ersatz für OOP
AOP ergänzt OOP
AOP beinhaltet die Behandlung von
Querschnittsaufgaben (crosscutting
concerns)
AOP = Aspekte + Aufrufregeln +
Verbindungs-/Schnittpunkte
Hinweis
AOP „Aspekt-orientierte
Programmierung“
ist kein systematisch gebildeter Begriff.
Nichts ist da an Aspekten orientiert, es
ist lediglich eine Alliteration auf OOP.
Inhalt
Grundlagen
AOP-Libraries, -Pakete, -Compiler
AOP in JSE, JEE
AOP als Klasse, als Annotation, per
Deployment Deskriptor (in XML)
Gedankliches Modell
Aspekte sind Programmergänzungen
Die Schreibweise ist ähnlich der von
Klassen
Verbindungspunkt / Joinpoint: ein
benannter Punkt im Programmablauf,
z. B. ein Funktionsaufruf
Gedankliches Modell
Pointcut / Schnittpunktmenge:
definiert eine Menge gleich zu
behandelnder Verbindungspunkte.
Empfehlung / Advice ist die
Beschreibung, auf welche Art an einer
Schnittpunktmenge der Programmablauf verändert werden soll.
MusterAspekt.aj (bisher im Client)
package basisweb.muster.gui;
import java.awt.event.ActionEvent;
import basisweb.global.gui.AbstractMainPanel;
public aspect MusterAspekt {
pointcut neuPanel() : (call(public AbstractMainPanel+.new()));
after() : neuPanel() {
System.err.println("neues AbstractMainPanel: " + thisJoinPoint.getSourceLocation());
}
pointcut actPerf() : (execution(public void AbstractMainPanel+.doActionPerformed(ActionEvent))) ;
before() : actPerf() {
System.err.println("ActionPerformed: " + thisJoinPoint.getSourceLocation());
}
pointcut setPresentierer() : (execution(* basisweb.*.gui.*Panel.setPresenter(..)));
before() : setPresentierer() {
System.err.println("Hurra ich bekomm einen Presentierer!! " + thisJoinPoint.getSourceLocation());
}
}
AufrufPruefer (Klasse)
package basisweb.global.ejbs.eb.interceptors;
import org.jboss.aop.joinpoint.MethodInvocation;
import basisweb.recht.dto.LoginDTO;
public class AufrufPruefer {
public Object aufrufPruefAdvice (MethodInvocation mi) throws Throwable {
Object [ ] args = mi.getArguments ( ) ;
if ( args.length > 0 ) {
Object a0 = args [ 0 ];
if ( a0 instanceof LoginDTO ) {
String user = ( ( LoginDTO ) a0 ) .getName ( ) ;
System.out.println ( "aufrufPruefAdvice: User "
+ ( user != null ? user : "(null)" )
+ " calls "+ mi.getMethod().getName());
}
}
return ret;
}
}
AufrufPruefer (Deskriptor)
jboss-aop.xml:
<aop>
<aspect name="basisWebAufrufPruefer"
class="basisweb.global.ejbs.eb.interceptors.AufrufPruefer" scope="PER_VM" />
<pointcut name="SBAufruf"
expr="execution(* basisweb.med.ejbs->*SBBean(basisweb.recht.dto.LoginDTO,..))" />
<bind pointcut="SBAufruf">
<advice name="aufrufPruefAdvice" aspect="basisWebAufrufPruefer" />
</bind>
</aop>
AOP-Libraries
Zuerst gab es nur AspectJ
seit JBoss 4 gibt es JBoss-AOP als
MBean-Interceptoren
seit JSE5 gibt es AspectJ5 Annotations
in JEE6 sind auch EJB Interceptoren
(ähnlich JBoss) definiert. Werden auch in
JBoss7 unterstützt.
für Servlets etc. gibt es Spring-AOP.
Varianten
Aspekte auf Klassen können den
Programmablauf ändern, ohne den Text der
Klasse zu ändern, aber Weaving ist nötig
Aspekte auf Annotations setzen voraus,
daß diese schon im Text stehen, und
Weaving ist auch nötig
Aspekte über XML können administrativ
geändert werden auch ohne Weaving
Nutzbarkeit in Basis
Aspekte auf Klassen sind im Client
leicht nutzbar.
im Server in EJBs sind Interceptoren
der beste Weg.
Weitere Informationen
Bücher:
AspectJ: „Aspektorientierte
Programmierung mit AspectJ5“, Böhm
EJB 2: „JBoss“, Rupp, Kapitel 8
EJB 3: „EJB 3.1“, Eberling, Kap. 9.2
Dokumentation im Netz:
zu JEE6 – Oracle
zu AspectJ – Eclipse
zu JBoss – JBoss-Community