Упорядочение аспектов с помощью Spring AOP && MVC

Я пытаюсь использовать Spring AOP с Spring MVC Controller. У меня есть 3 аспекта, и я хочу, чтобы они были в определенном порядке. Для этого я использую Упорядоченный интерфейс и реализую метод getOrder:

@Aspect
@Component
public class LoggingAspect implements Ordered{

public int getOrder() {
System.out.println("Abra");
return 1;
}

Рекомендуемый класс:

@Component
@Controller
public class HomeController {   

срезов в:

@Aspect
public class SystemArchitecture {

    @Pointcut("execution (* com.jajah.StorageManager.HomeController.*(..))")
    public void inHomeController(){}

    @Pointcut("execution (* com.jajah.StorageManager.HomeController.*(..))")
    public void loggable(){}

    @Pointcut("execution (* com.jajah.StorageManager.HomeController.*(..))")
    public void authenticated(){}

}

Конфигурация:

<?xml version="1.0" encoding="UTF-8"?>
<beans:beans xmlns="http://www.springframework.org/schema/mvc"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:beans="http://www.springframework.org/schema/beans"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop"   
    xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">

    <annotation-driven />
    <context:annotation-config /> 
    <aop:aspectj-autoproxy proxy-target-class="false"/>

    <beans:bean id="AuthenticationAspect" class="com.jajah.CommonAspects.SecurityAspects.OAuthAspect"/>
    <beans:bean id="ErrorHandlingAspect" class="com.jajah.StorageManager.Aspects.ErrorHandlingAspect"/>


    <!-- Handles HTTP GET requests for /resources/** by efficiently serving up static resources in the ${webappRoot}/resources directory -->
    <resources mapping="/resources/**" location="/resources/" />

    <!-- Resolves views selected for rendering by @Controllers to .jsp resources in the /WEB-INF/views directory -->
    <!-- <beans:bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <beans:property name="prefix" value="/WEB-INF/views/" />
        <beans:property name="suffix" value=".jsp" />

    </beans:bean> -->

    <beans:bean name="homeController" class="com.jajah.StorageManager.HomeController">
        <beans:constructor-arg>     
            <beans:ref bean="CloudStorage"/>
        </beans:constructor-arg>
        <beans:constructor-arg>     
            <beans:ref bean="ConfigurationContainer"/>
        </beans:constructor-arg>
    </beans:bean>

    <beans:bean id="CloudStorage" name="CloudStorage"       class="com.jajah.StorageManager.CloudStorageProxy"      scope="singleton">
        <beans:constructor-arg>     
         <beans:ref bean="ConfigurationContainer"/>
        </beans:constructor-arg>
    </beans:bean>

    <beans:bean id ="ConfigurationContainer" class="com.jajah.StorageManager.ConfigurationContainer" scope="singleton"/>





</beans:beans>

GetOrder не делает этого трюка. Я буду признателен за любые практические советы, или если у вас нет точного ответа, я буду признателен за любые теоретические знания про прокси и механизм ткачества Spring.

Я пошлю любой код/​​конфигурацию по требованию. Спасибо за чтение.

Обновление: 1. Я попробовал @Order (1) с тем же результатом. 2. Я попытался перенести аспекты в один и тот же пакет, изменил их порядок, но я все еще не мог его контролировать.

Ответ 1

Вам не нужно реализовывать упорядоченный интерфейс.

В Spring АОП вы можете сделать что-то намного проще.

@Aspect
@Order(1)
public class AspectA
{
  @Before("............")
   public void doit() {}
}

@Aspect
@Order(2)
public class AspectB
{
  @Before(".............")
  public void doit() {}
} 

Update:

@Aspect
@Order(1)
public class SpringAspect {

    @Pointcut("within(com.vanilla.service.MyService+)")
    public void businessLogicMethods(){}

     @Around("businessLogicMethods()")
     public Object profile(ProceedingJoinPoint pjp) throws Throwable {
             System.out.println("running Advice #1");   
         Object output = pjp.proceed();
         return output;
     }
}

@Aspect
@Order(2)
public class SpringAspect2 {

    @Pointcut("within(com.vanilla.service.MyService+)")
    public void businessLogicMethods(){}

     @Around("businessLogicMethods()")
     public Object profile(ProceedingJoinPoint pjp) throws Throwable {
             System.out.println("running Advice #2");   
         Object output = pjp.proceed();
         return output;
     }
}

Теперь приложение Context Configuration XML:

<context:annotation-config />
<aop:aspectj-autoproxy />

  <bean id="springAspect" class="com.vanilla.aspect.SpringAspect" />
    <bean id="springAspect2" class="com.vanilla.aspect.SpringAspect2" />

Вам необходимо включить прокси-сервер AOP:

<aop:aspectj-autoproxy />

в противном случае никакие советы не будут активированы.

Обновление 2:

Я просто делаю исследование по этой проблеме. @order аннотация работает только на Spring основе прокси-сервера AOP (который я использую в моем примере). В соответствии с документацией, если вы используете плетение, вы должны использовать параметр приоритета объявления.

Обновление 3

  • Я не вижу никаких советов в вашем коде, просто аспекты и точки.
  • Если ваши классы Advice: x.y.z.SystemArchitecture

тогда вам нужно настроить его как

<bean id="systemArchitecture" class="x.y.z.SystemArchitecture" /> 

и я не вижу его в вашем коде.

  1. "(* com.jajah.StorageManager.HomeController. * (..))" на что вы нацелились? Можете ли вы написать это с помощью слов?

В любом случае. Пожалуйста, напишите мне сообщение на facebook, и я пришлю вам рабочий пример, который делает именно то, что вы пытаетесь сделать.