Форум программистов, компьютерный форум, киберфорум
Java: Spring, Spring Boot
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 27.01.2021
Сообщений: 1

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

27.01.2021, 14:51. Показов 2331. Ответов 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
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.01.2021, 14:51
Ответы с готовыми решениями:

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

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

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

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.01.2021, 14:51
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru