Почему AspectJ не компилирует во время компиляции работу Spring @Configurable? - PullRequest
25 голосов
/ 23 мая 2009

Обновление 5: Я загрузил последнюю версию Spring ToolsSuite IDE, основанную на последней версии Eclipse. Когда я импортирую свой проект как проект Maven, Eclipse / STS использует цели Maven для создания моего проекта. Это означает, что AspectJ наконец-то правильно работает в Eclipse.

Обновление 4: Я только что использовал плагин Maven + AspectJ для создания компиляции во время компиляции, эффективно обходя механизм Eclipse.

Обновление 3: Кажется, плагин Epectipse от AspectJ нарушает способность Eclipse правильно публиковать в Tomcat. Только удалив возможность AspectJ в проекте, я могу заставить его снова правильно опубликовать. Очень раздражает.

Обновление 2: У меня это сейчас работает в Eclipse. Мне очень неудобно об этом говорить, но я понятия не имею, как я это получил, работая со сборками Eclipse или Maven. Похоже, это проблема компиляции, а не проблема времени выполнения.

Обновление 1: Кажется, я заставил это работать через сборки Maven, но я понятия не имею, как. Затмение все еще не работает. Единственное, что я изменил в pom.xml , - это добавление этих (незначительных?) Параметров конфигурации:

<source>1.6</source>
<complianceLevel>1.6</complianceLevel>
<verbose>true</verbose>
<showWeaveInfo>true</showWeaveInfo>
<outxml>true</outxml>

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

Что касается Eclipse, я добился некоторого прогресса, взяв бинарные аспекты, которые я хочу сплести - в данном случае spring-aspect.jar - и скопировав их из моего пути к классам. Затем я добавляю этот теперь внешний jar в мой Aspect Path . После этого Eclipse правильно показывает мне маркеры AspectJ в моем коде. Раздражает, что я не могу просто оставить spring-aspect.jar в моем Java Build Path , который поддерживается Maven для меня через плагин Maven. Однако по какой-то причине плагин AspectJ не видит двоичные аспекты, если они явно не добавлены в Aspect Path .


Исходное сообщение: @Configurable - это аннотация Spring, позволяющая вставлять зависимости в объекты, созданные вне Spring (например, Hibernate или некоторым классом Factory).

Ранее я использовал эту аннотацию с ткачеством во время загрузки, и она в основном работала. Иногда я загружался, и ничего не вводили. Эта проблема породила этот вопрос StackOverflow . Было не так много ответов, но большинство предлагало вместо этого попробовать ткачество во время компиляции из-за большей надежности.

Я установил плагин AspectJ для Eclipse и Maven. Оба они производят то, что кажется правильно скомпилированными классами. Я открыл один из классов в текстовом редакторе перед компиляцией AspectJ и не нашел ссылок на AspectJ. Я открыл его после компиляции AspectJ, и сгенерированные версии Eclipse и Maven имеют ссылку на org.aspectj.weaver.MethodDeclarationLineNumber . Вот почему я предполагаю, что он правильно компилируется. Проблема в том, что после развертывания никакие зависимости не вводятся.

My Spring applicationContext.xml включает следующее:

    <context:spring-configured />

    <context:component-scan base-package="com.myapp" />

Нужно ли прежде всего, чтобы классы с пометкой @Configurable делали DI? Во время преобразования из ткачества во время загрузки в ткачество во время компиляции я удалил META-INF / aop.xml , из моего applicationContext.xml и ткач Springcat из моего context.xml .

Как я могу исследовать эту проблему дальше? Каковы возможные причины?

Ответы [ 4 ]

26 голосов
/ 28 мая 2009

У нас это работает на maven с использованием ткачества времени компиляции, попробуйте добавить следующие плагины:

<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
    <compilerVersion>1.6</compilerVersion>
    <fork>true</fork>
    <source>1.6</source>
    <target>1.6</target>
</configuration>
</plugin>

<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>aspectj-maven-plugin</artifactId>
<executions>
    <execution>
        <id>compile</id>
        <configuration>
            <source>1.6</source>
            <target>1.6</target>
            <verbose>false</verbose>
            <outxml>true</outxml>
            <aspectLibraries>
                <aspectLibrary>
                    <groupId>org.springframework</groupId>
                    <artifactId>spring-aspects</artifactId>
                </aspectLibrary>
            </aspectLibraries>
        </configuration>
        <goals>
            <goal>compile</goal>
        </goals>
    </execution>
    <execution>
        <id>test-compile</id>
        <configuration>
            <source>1.6</source>
            <target>1.6</target>
            <verbose>false</verbose>
            <aspectLibraries>
                <aspectLibrary>
                    <groupId>org.springframework</groupId>
                    <artifactId>spring-aspects</artifactId>
                </aspectLibrary>
            </aspectLibraries>
        </configuration>
        <goals>
            <goal>test-compile</goal>
        </goals>
    </execution>
</executions>
<dependencies>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.6.4</version>
    </dependency>
</dependencies>
</plugin>

Это сделано в виде двух отдельных шагов выполнения, чтобы позволить вам добавлять разные библиотеки аспектов для модульного тестирования и компиляции.

Вам также понадобится добавить следующую зависимость для библиотеки аспектов Spring:

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aspects</artifactId>
        <scope>compile</scope>
    </dependency>
7 голосов
/ 28 мая 2009

Я успешно настроил время загрузки в своем приложении, если это альтернатива для вас.

Мое окружение:

  • JDK-1,6
  • Весна-2.5.6
  • JPA с eclipselink-1.1.0

Детали конфигурации:

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

<context:annotation-config/>
<context:spring-configured/>
<context:load-time-weaver/>

<bean id="baseEntity" class="package.name.BaseEntity" scope="prototype">
  <property name="historyHandler" ref="historyHandler" />
</bean>

<bean id="historyHandler" class="package.name.HistoryJpaHandler" scope="prototype">
  <property name="historyDao" ref="historyDao" />
</bean>

<bean id="historyDao" class="package.name.HistoryJpaDao">
  <property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>

Весенние аннотации

@Configurable("baseEntity")
public abstract class BaseEntity

@Configurable("historyHandler")
public class HistoryJpaHandler extends SessionEventAdapter implements HistoryHandler 

Java VM Параметр

<JAVA_HOME>/bin/java -javaagent:/full/path/to/spring-agent-2.5.6.jar

Экземпляры historyHandler и baseEntitty создаются ecliselink. historyHandler в baseEntitty и historyDao в historyHandler задается ткачеством загрузки.

Вы можете установить параметр виртуальной машины в конфигурации запуска Eclipse или в Tomcats catalina.sh/bat.

4 голосов
/ 08 марта 2014

создание поля класса @configurable Autowired создает исключение NullPointerException, если вы не настроили свою пружину должным образом для этой аннотации. выполните следующие шаги, чтобы аннотации @configurable работали правильно

Этот метод называется Время сборки AspectJ для добавления пружинных бобов в классы, не созданные весной * .

Первый шаг - установить эти плагины в eclipse:

С этих двух сайтов обновлений установите все, что предлагает Eclipse:

http://download.eclipse.org/tools/ajdt/43/update
http://dist.springsource.org/release/AJDT/configurator/ 

После установки щелкните правой кнопкой мыши на проекте и выполните:

Configure > Convert to Aspectj
Maven > Update

Далее вам нужно добавить их в ваш pom.xml:

Под зависимостями Добавить:

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-aspects</artifactId>
    <version>4.0.2.RELEASE</version>
</dependency>

Под плагинами Добавить:

        <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>aspectj-maven-plugin</artifactId>
            <version>1.5</version>
            <configuration>
                <showWeaveInfo>true</showWeaveInfo>
                <source>1.7</source>
                <target>1.7</target>
                <Xlint>ignore</Xlint>
                <complianceLevel>1.7</complianceLevel>
                <encoding>UTF-8</encoding>
                <verbose>false</verbose>
                <aspectLibraries>
                    <aspectLibrary>
                        <groupId>org.springframework</groupId>
                        <artifactId>spring-aspects</artifactId>
                    </aspectLibrary>
                </aspectLibraries>
            </configuration>
            <executions>
                <execution>
                    <goals>
                        <goal>compile</goal>
                        <goal>test-compile</goal>
                    </goals>
                </execution>
            </executions>
            <dependencies>
                <dependency>
                    <groupId>org.aspectj</groupId>
                    <artifactId>aspectjrt</artifactId>
                    <version>1.7.0</version>
                </dependency>
                <dependency>
                    <groupId>org.aspectj</groupId>
                    <artifactId>aspectjtools</artifactId>
                    <version>1.7.0</version>
                </dependency>
            </dependencies>
        </plugin>

Важно: НЕ ИСПОЛЬЗУЙТЕ тег <pluginManagment> в теге <build>. ваш pom.xml должен выглядеть примерно так:

<project ....>
    ....
    <dependencies>
        <dependency> 
                    ....
        </dependency>
                ....
    </dependencies>
    <build>
        <plugins>
            <plugin>
                            ....
            </plugin>
                        ....
        </plugins>
    </build>
</project>

наконец добавьте <context:spring-configured /> в конфигурационный файл вашего весеннего приложения.

Теперь вы можете аннотировать класс POJO как @Configurable и вставлять в него пружинные бины, используя аннотацию @Autowired. таким образом, всякий раз, когда вы создаете новый экземпляр этого POJO, он автоматически настраивается (например, вводится с зависимостями).

2 голосов
/ 13 сентября 2009

Что касается ваших проблем с Eclipse, вы можете найти это полезным.

Плагин m2eclipse имеет дополнительную AJDT интеграцию . Интеграция считывает раздел aspectLibraries в конфигурации aspectj-maven-plugin и добавляет файлы jar в Aspect Path Eclipse.

...