AspectJ с JSF1.2 - PullRequest
       16

AspectJ с JSF1.2

1 голос
/ 14 октября 2011

Я использую JSF1.2 Framework. Я не интегрировал свое приложение с Spring . Я хочу выполнить профилирование при вызове методов. файл моего приложения EAR (EJB + WAR) . я могу получить время выполнения методов сессионных компонентов с помощью перехватчика, но для модуля WAR мне предложили использовать AspectJ в этом блоге. поэтому я написал некоторый код. Есть ли что-то, что мне нужно сделать, как детали конфигурации . Я добавил требуемый jar-файл AspectJ , поддерживает ли JSF AspectJ с какой-либо конфигурацией? мой код:

import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
@Aspect
public class AopInterceptor implements MethodInterceptor{

public AopInterceptor() {
}

@Pointcut("execution (* *.*(..))")
public void profile(){}

@Around("profile()")
public Object invoke(MethodInvocation mi) throws Throwable {
    System.out.println("test start");
    Object obj=mi.proceed();
    System.out.println("test end");
    return obj;
 }
}

1 Ответ

0 голосов
/ 21 октября 2011

Я создал цель в файле WAR build.xml и добавил файлы JAR AspectJ.Теперь я получаю все вызванные методы.Вот код targer:

 <taskdef  classpath="C:/Users/s.kosna/Downloads/aspectj-1.6.11/lib/aspectjtools.jar"
 resource="org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties"/>
<target name="aspectj">
<echo level="info">--- aspectj (start) ---</echo>
<condition property="targetos" value="windows" else="unix">
    <os family="windows"/>
</condition>
<pathconvert targetos="${targetos}" property="javac.convertedClasspath" >
    <path path="${javac.classpath}" />
</pathconvert>
<iajc source="1.6" target="1.6" showweaveinfo="true" verbose="true" destdir="${build.classes.dir}"  >
    <inpath>
        <pathelement location="${build.classes.dir}"/>
    </inpath>
    <classpath>
        <pathelement location="${javac.convertedClasspath}" />
    </classpath>
</iajc>
<echo level="info">LORDDOSKIAS BRUTAL TEST ---</echo>
</target>

<target name="-post-compile" depends="aspectj"></target>

поместите приведенный выше код в один пакет и добавьте вышеупомянутый муравейный скрипт в вашу войну build.xml, вот и будет работать

...