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

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

27.01.2021, 14:51. Показов 2306. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru