2016-05-30 89 views
1

我有一個使用MyEclipse製作的Spring MVC應用程序,它包含生成的源以及我自己的源,以及我在生成的類上定義的方面。在MyEclipse中編譯好的所有東西,但我現在想切換到Maven,以便使用持續集成服務器。maven aspectj編織NullPointerException

我一直在擺弄pom.xml很長一段時間了,我打了一道牆,我似乎無法繞過。當Maven到達織造方面的那一刻,我得到下面的異常(只是第幾行爲了簡潔):

[INFO] [aspectj:compile {execution: default}] 
[INFO] Showing AJC message detail for messages of types: [error, warning, fail] 
[ERROR] ABORT 
May 30, 2016 11:48:05 AM org.aspectj.weaver.tools.Jdk14Trace info 
INFO: Dumping to /var/atlassian/application-data/bamboo/xml-data/build-dir/OW-BUIL-JOB1/./ajcore.20160530.114805.876.txt 
[INFO] ------------------------------------------------------------------------ 
[ERROR] BUILD ERROR 
[INFO] ------------------------------------------------------------------------ 
[INFO] AJC compiler errors: 
abort ABORT -- (NullPointerException) null 
null 
java.lang.NullPointerException 
    at org.aspectj.org.eclipse.jdt.internal.compiler.apt.dispatch.AnnotationDiscoveryVisitor.resolveAnnotations(AnnotationDiscoveryVisitor.java:238) 
    at org.aspectj.org.eclipse.jdt.internal.compiler.apt.dispatch.AnnotationDiscoveryVisitor.visit(AnnotationDiscoveryVisitor.java:217) 
    at org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration.traverse(TypeDeclaration.java:1348) 
    at org.aspectj.org.eclipse.jdt.internal.compiler.ast.CompilationUnitDeclaration.traverse(CompilationUnitDeclaration.java:748) 
    ... 

我的pom.xml太長,它粘貼在這裏,但構建的部分是作爲如下(讓我知道,如果你想看到的一些相關性):

<build> 
    <directory>bin</directory> 
    <plugins> 
     <plugin> 
      <groupId>org.codehaus.mojo</groupId> 
      <artifactId>build-helper-maven-plugin</artifactId> 
      <version>1.7</version> 
      <executions> 
       <execution> 
        <id>add-source</id> 
        <phase>generate-sources</phase> 
        <goals> 
         <goal>add-source</goal> 
        </goals> 
        <configuration> 
         <sources> 
          <source>src</source> 
          <source>generated</source> 
          <source>resources</source> 
         </sources> 
        </configuration> 
       </execution> 
      </executions> 
     </plugin> 
     <plugin> 
      <artifactId>maven-compiler-plugin</artifactId> 
      <version>2.1</version> 
      <configuration> 
       <source>1.6</source> 
       <target>1.6</target> 
       <excludes> 
        <exclude>main/</exclude> 
        <exclude>test/</exclude> 
       </excludes> 
       <useIncrementalCompilation>true</useIncrementalCompilation> 
      </configuration> 
     </plugin> 
     <plugin> 
      <groupId>org.codehaus.mojo</groupId> 
      <artifactId>aspectj-maven-plugin</artifactId> 
      <version>1.8</version> 
      <configuration> 
       <showWeaveInfo>true</showWeaveInfo> 
       <source>1.6</source> 
       <target>1.6</target> 
       <Xlint>ignore</Xlint> 
       <complianceLevel>1.6</complianceLevel> 
       <encoding>UTF-8</encoding> 
       <verbose>true</verbose> 
       <aspectLibraries> 
        <aspectLibrary> 
         <groupId>org.springframework</groupId> 
         <artifactId>spring-aspects</artifactId> 
        </aspectLibrary> 
       </aspectLibraries> 
      </configuration> 
      <executions> 
       <execution> 
        <phase>process-sources</phase> 
        <goals> 
         <goal>compile</goal> 
        </goals> 
       </execution> 
      </executions> 
     </plugin> 
     <plugin> 
      <groupId>org.apache.maven.plugins</groupId> 
      <artifactId>maven-war-plugin</artifactId> 
      <configuration> 
       <webXml>${project.basedir}/WebRoot/WEB-INF/web.xml</webXml> 
       <warName>oligoWorld</warName> 
       <outputDirectory>${project.basedir}</outputDirectory> 
      </configuration> 
     </plugin> 
    </plugins> 
    <pluginManagement> 
     <plugins> 
      <!--This plugin's configuration is used to store Eclipse m2e settings only. It has no influence on the Maven build itself. --> 
      <plugin> 
       <groupId>org.eclipse.m2e</groupId> 
       <artifactId>lifecycle-mapping</artifactId> 
       <version>1.0.0</version> 
       <configuration> 
        <lifecycleMappingMetadata> 
         <pluginExecutions> 
          <pluginExecution> 
           <pluginExecutionFilter> 
            <groupId>org.codehaus.mojo</groupId> 
            <artifactId>aspectj-maven-plugin</artifactId> 
            <versionRange>[1.8,)</versionRange> 
            <goals> 
             <goal>compile</goal> 
            </goals> 
           </pluginExecutionFilter> 
           <action> 
            <execute /> 
           </action> 
          </pluginExecution> 
         </pluginExecutions> 
        </lifecycleMappingMetadata> 
       </configuration> 
      </plugin> 
     </plugins> 
    </pluginManagement> 
</build> 

任何人看到任何錯誤或遺漏可能會導致異常?僅供參考,我的aspectj依賴項(aspectjrt,aspectjtools和aspectjweaver)的版本是1.8.7。

+0

這有幫助嗎? http://stackoverflow.com/questions/11044213/internal-compiler-error-in-eclipse-npe –

+0

謝謝,但不是真的。編譯發生在持續集成服務器(Bamboo)上,不在Eclipse內部,因此這些步驟不適用。 – timber

+0

您應該將解決方案轉移到下面的答案。 –

回答

0

我似乎發現了這個問題。在pom.xml中,我在aspectj-maven-plugin定義之外,對pj文件的dependencies部分中的所有其他依賴項列出了aspectjtools的依賴項。相反,我將其移入插件中;另外,我將aspectj庫的版本更改爲1.8.9,因爲它看起來像1.8.7展現了一個類似於我發現的bug。之後,一切都奏效了。所以這裏是我爲aspectj-maven插件修改的定義以供參考:

 <plugin> 
      <groupId>org.codehaus.mojo</groupId> 
      <artifactId>aspectj-maven-plugin</artifactId> 
      <version>1.8</version> 
      <dependencies> <!-- The change that fixed it starts here... --> 
       <dependency> 
        <groupId>org.aspectj</groupId> 
        <artifactId>aspectjtools</artifactId> 
        <version>1.8.9</version> 
       </dependency> 
      </dependencies> <!-- ...and ends here. --> 
      <configuration> 
       <showWeaveInfo>true</showWeaveInfo> 
       <source>1.6</source> 
       <target>1.6</target> 
       <Xlint>ignore</Xlint> 
       <complianceLevel>1.6</complianceLevel> 
       <encoding>UTF-8</encoding> 
       <verbose>true</verbose> 
       <aspectLibraries> 
        <aspectLibrary> 
         <groupId>org.springframework</groupId> 
         <artifactId>spring-aspects</artifactId> 
        </aspectLibrary> 
       </aspectLibraries> 
      </configuration> 
     </plugin> 
相關問題