Форум программистов, компьютерный форум, киберфорум
Java EE (J2EE)
Войти
Регистрация
Восстановить пароль
 
0 / 0 / 0
Регистрация: 27.01.2021
Сообщений: 1
1

Spring AspectJ - аспект вызывается дважды (хотя должен только 1 раз)

27.01.2021, 14:51. Просмотров 1041. Ответов 0

Пытаюсь использовать в проекте для логгирования аспекты. И возникла следующая довольно странная проблема.
Аспект выполняется не только в том методе, который в pointcut указан, но также - он еще раз выполняется и в том методе, который указанный в pointcut метод вызвал. Т.е. к примеру есть метод:

Java
1
2
3
4
5
6
7
8
9
        public class Handler {
    
        @LogServiceCall
        public ReturnType handle(ArgType message) {
          ReturnType response;
          //do something
          return response;
       }
    }
Есть класс, из которого этот метод вызывается:

Java
1
2
3
4
5
6
7
8
9
    public class Caller {
 
      @Autowired
      private Handler requestHandler;
 
      public ReturnType getResponse(ArgType message) {
        return requestHandler.handle(message);
    }
}
При вызове метода getResponse в Caller - аспект вызывается дважды (два раза до, и 2 раза после вызова метода) - сначала в методе handle, а затем еще раз - в методе getResponse.

Код аспекта:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@Aspect
public class LoggingAspect {
 
    @Autowired
    private ContextLoggerService loggerService;
 
    @Autowired
    private RequestContextHolderService contextHolder;
 
    @Around("@annotation(logServiceCall)")
    public Object logServiceCall(ProceedingJoinPoint serviceJoinPoint, LogServiceCall logServiceCall) throws Throwable {
        //do logging before method call
        Object response = serviceJoinPoint.proceed();
        //do logging after method call>
        return response;
    }
}
Аннотация:

Java
1
2
3
4
5
6
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LogServiceCall {
 
    ServiceProfile serviceName() default ServiceProfile.NO_SUCH_SERVICE;
}
Конфигурация контекста Spring:

XML
1
2
3
<aop:aspectj-autoproxy/>
<bean id="loggingAspect" class="logging.aspect.LoggingAspect"
      factory-method="aspectOf"/>
Также на всякий случай привожу конфигурацию mavan-aspectj-plugin:
XML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<plugin>
    <groupId>org.codehaus.mojo</groupId>
    <artifactId>aspectj-maven-plugin</artifactId>
    <version>1.11</version>
    <configuration>
        <complianceLevel>8</complianceLevel>
        <source>8</source>
        <target>8</target>
        <showWeaveInfo>true</showWeaveInfo>
        <verbose>true</verbose>
        <Xlint>ignore</Xlint>
        <encoding>UTF-8</encoding>
        <excludes>
            <exclude>**/*.java</exclude>
        </excludes>
        <forceAjcCompile>true</forceAjcCompile>
        <sources/>
        <aspectLibraries>
            <aspectLibrary>
                <groupId>org.springframework</groupId>
                <artifactId>spring-aspects</artifactId>
            </aspectLibrary>
        </aspectLibraries>
    </configuration>
    <executions>
        <execution>
            <id>default-compile</id>
            <phase>process-classes</phase>
            <goals>
                <goal>compile</goal>
            </goals>
            <configuration>
                <weaveDirectories>
                    <weaveDirectory>${project.build.directory}/classes</weaveDirectory>
                </weaveDirectories>
            </configuration>
        </execution>
        <execution>
            <id>default-testCompile</id>
            <phase>process-test-classes</phase>
            <goals>
                <goal>test-compile</goal>
            </goals>
            <configuration>
                <weaveDirectories>
                    <weaveDirectory>${project.build.directory}/test-classes</weaveDirectory>
                </weaveDirectories>
            </configuration>
        </execution>
    </executions>
</plugin>
Помогите разобраться пожалуйста - в чем косяк?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.01.2021, 14:51
Ответы с готовыми решениями:

Почему метод выполняется дважды хотя один раз вызывается
Добрый день. В программе вызывается нек. метод, по событию изменение текста в сомбобоксе...

Почему AuthorizeAttribute каждый раз вызывается дважды?
Привет! Есть свой класс, унаследованный от AuthorizeAttribute, в котором переопределен метод...

Почему вызывается переопределённый метод Object.equals, хотя должен вызываться ПЕРЕГРУЖЕННЫЙ?
Суть: необходимо создать авторский класс, перегрузить в нём метод equals, создать объект этого...

Функция срабатывает 2 раза, хотя вызывается 1 раз
Доброго времени суток! Образовалась такая проблема, что я вызываю функцию 1 раз, а срабатывает она...

0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
27.01.2021, 14:51

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

[Spring AOP] Написать аспект на println()
Необходимо написать аспект, который бы перед каждым sout в программе делал еще один sout с каким-то...

Внешнее прерывание вызывается только 1 раз
Не могу понять почему прерывание только 1 раз вызывается, хотя вроде все по схеме делал. Тестировал...

Spring - запустить инициализацию конфига FireBase только один раз
Всем доброго дня! Ковыряю Spring на тему взаимодействия с FireBase, в частности FCM - отправка...

MsgBox вызывается дважды
Доброго времени суток. У Меня такая проблема, MsgBox вызывается почему-то дважды, Я не могу понять...

Обработчик вызывается дважды
Пишу страничку для создания диаграмм, вот она: https://jsfiddle.net/e76msqn2/ В чем проблема:...

OnCreate вызывается дважды
Добрый день. Делаю простое приложение, которое при нажатии на кнопку, с помощью Intent должно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.