Форум программистов, компьютерный форум, киберфорум
Java EE (J2EE)
Войти
Регистрация
Восстановить пароль
Другие темы раздела
Java EE Переадресация с сохранением данных https://www.cyberforum.ru/ java-j2ee/ thread2775143.html
Делаю небоьшой проект и столкнулся с такой проблемой - При создании пользователя идет переадресация на другую страницу и там я хочу создать ему банковскую карту. Проблема в том,что при...
Java EE Как данный код на freemaker будет выглядеть в thymeleaf?
<!-- Фрагмент для получения данных сессии --> <!-- Определение переменной сессии и приведение ее к bool--> <#assign known = Session.SPRING_SECURITY_CONTEXT?? > <#if known> <!--...
Java EE Генератор договоров docx c возможностью редактирования некоторых частей и переносом блоков
День добрый! Встала такая задача, написать ВЕБ приложение, похожее на www.freshdoc.ru, только для внутреннего использования. Есть шаблон документа, разбитый на блоки, то есть пункты в договоре 3.2,...
Java EE Entity можно ли отнаследоваться и расширить функционал Жили были классы в виде библиотеки т.е. редактироваь их нельз а использовать нужно и можно(это только пример) @Entity @Data @EqualsAndHashCode(callSuper = true) @Table(name = "app") public... https://www.cyberforum.ru/ java-j2ee/ thread2771718.html
Java EE Как подружить thymeleaf c интеграционным тестом? https://www.cyberforum.ru/ java-j2ee/ thread2771323.html
<!DOCTYPE HTML> <html xmlns="http://www.w3.org/1999/xhtml" xmlns:th="http://www.thymeleaf.org"> <head> <link rel="stylesheet"...
Почему функция не вызывается на p: commandButton? Java EE
Почему функция не вызывается в p: commandButton? В отладке видно, что программа вызывает функции конвертера, но функция кнопки не вызывается Jsf page <h:form> <p:panel...
Почему spring Data использует старое название поля таблицы БД в запросе? Java EE
По какой-то причине Spring использует имя поля в запросах при добавлении, чего я больше нигде не называю. Раньше я использовал название «Статус разработки», а теперь «status». Так что вместо "...
Java EE Spring. Передать данные из валидатора в представление Модель package com.luchkin.blogAfkArena.model; import javax.persistence.*; import javax.validation.constraints.Size; @Entity public class MyUser { @Id https://www.cyberforum.ru/ java-j2ee/ thread2770034.html
Java EE Как добавить новые записи в поле с @OneToOne в spring Data? https://www.cyberforum.ru/ java-j2ee/ thread2769732.html
Я делаю приложение jsf + spring. База данных содержит таблицу игр и отображается на одной из страниц сайта. У каждой игры есть список жанров и статус разработки. Эти поля помечены @OneToMany и...
Java EE Конверсия данных, полученных в при отправке формы, в объекты <artifactId>spring-boot-starter-parent</artifactId> <version>2.4.1</version> https://pastebin.com/GYYWcDtm Сверху мой код. Снизу - спринговый интерфейс Парсер. С этим кодом у меня... https://www.cyberforum.ru/ java-j2ee/ thread2769410.html
Java EE JVM Apache Tomcat https://www.cyberforum.ru/ java-j2ee/ thread2769029.html
Добрый день, не получается установить JVM в Tomcat больше 900MB. параметры через manager tomcat сейчас такие: Free memory: 403.38 MB Total memory: 491.50 MB Max memory: 910.50 MB при этом...
Java EE Как сделать в JSF форму, в которой можно выбрать обекты из списка элементов? У меня в JSF есть страница,которая выводит список игр.Одно из полей - список всех сотрудников,которые участвовали в разработке. Так же должна быть возможность добавлять новые игры. И если со всеми... https://www.cyberforum.ru/ java-j2ee/ thread2768971.html
0 / 0 / 0
Регистрация: 27.01.2021
Сообщений: 1
0

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

27.01.2021, 14:51. Просмотров 1460. Ответов 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>
Помогите разобраться пожалуйста - в чем косяк?

Вернуться к обсуждению:
Spring AspectJ - аспект вызывается дважды (хотя должен только 1 раз)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.01.2021, 14:51
Готовые ответы и решения:

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

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

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

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

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