저는 컴파일 타임에면을 사용하는 프로젝트가 있습니다. 두 개의 외부 jar에 의존합니다. 다음으로 https://github.com/eveoh/gradle-aspectjgradle + aspectj ---- 컴파일 외부 편을 짜는 중 에러가 발생했습니다
build.gradle : 난에서 Gradle을-AspectJ의 플러그인을 사용
buildscript {
repositories {
maven { url "http://nexus.**.org/nexus/content/groups/public/" }
}
dependencies {
classpath("nl.eveoh:gradle-aspectj:1.5")
}
}
ext {
springBootVersion = '1.2.3.RELEASE'
aspectjVersion = '1.8.5'
}
apply plugin: 'aspectj'
compileAspect {
additionalAjcArgs = ['encoding': 'UTF-8', 'source': '1.8', 'target': '1.8']
}
dependencies {
compile ("com.alibaba:fastjson:1.2.5")
compile ('commons-io:commons-io:2.4')
compile ('commons-lang:commons-lang:2.6')
compile ("ch.qos.logback:logback-classic:1.1.3")
compile ("ch.qos.logback:logback-core:1.1.3")
compile ("org.springframework:spring-jms:4.1.6.RELEASE")
compile ("org.apache.kafka:kafka-clients:0.8.2.2")
compile ("org.springframework.boot:spring-boot-starter-web:${springBootVersion}")
compile ("org.aspectj:aspectjrt:$aspectjVersion")
compile ("org.aspectj:aspectjweaver:$aspectjVersion")
compile("com.aa.bb:bb-core:1.0")
ajInpath ("com.aa.bb:bb-core:1.0")
}
난 Gradle을 빌드 실행 일부 컴파일 오류가 출력 :
20:35:12: Executing external task 'build'...
:myproject:compileAspect
[ant:iajc] trouble in:
[ant:iajc] public class org.springframework.http.converter.feed.AtomFeedHttpMessageConverter extends org.springframework.http.converter.feed.AbstractWireFeedHttpMessageConverter:
[ant:iajc] public void <init>():
[ant:iajc] ALOAD_0 // Lorg/springframework/http/converter/feed/AtomFeedHttpMessageConverter; this (line 38)
[ant:iajc] NEW org.springframework.http.MediaType
[ant:iajc] DUP
[ant:iajc] LDC "application"
[ant:iajc] LDC "atom+xml"
[ant:iajc] INVOKESPECIAL org.springframework.http.MediaType.<init> (Ljava/lang/String;Ljava/lang/String;)V
[ant:iajc] INVOKESPECIAL org.springframework.http.converter.feed.AbstractWireFeedHttpMessageConverter.<init> (Lorg/springframework/http/MediaType;)V
[ant:iajc] constructor-execution(void org.springframework.http.converter.feed.AtomFeedHttpMessageConverter.<init>())
[ant:iajc] | RETURN (line 39)
[ant:iajc] constructor-execution(void org.springframework.http.converter.feed.AtomFeedHttpMessageConverter.<init>())
[ant:iajc] end public void <init>()
[ant:iajc]
[ant:iajc] protected boolean supports(Class):
[ant:iajc] method-execution(boolean org.springframework.http.converter.feed.AtomFeedHttpMessageConverter.supports(java.lang.Class))
[ant:iajc] | LDC com.sun.syndication.feed.atom.Feed (line 43)
[ant:iajc] | ALOAD_1 // Ljava/lang/Class; clazz
[ant:iajc] | method-call(boolean java.lang.Class.isAssignableFrom(java.lang.Class))
[ant:iajc] | | INVOKEVIRTUAL java.lang.Class.isAssignableFrom (Ljava/lang/Class;)Z
[ant:iajc] | method-call(boolean java.lang.Class.isAssignableFrom(java.lang.Class))
[ant:iajc] | IRETURN
[ant:iajc] method-execution(boolean org.springframework.http.converter.feed.AtomFeedHttpMessageConverter.supports(java.lang.Class))
[ant:iajc] end protected boolean supports(Class)
[ant:iajc]
[ant:iajc] end public class org.springframework.http.converter.feed.AtomFeedHttpMessageConverter
[ant:iajc]
[ant:iajc]
[ant:iajc] Exception thrown from AspectJ 1.8.5
[ant:iajc]
[ant:iajc] This might be logged as a bug already -- find current bugs at
[ant:iajc] http://bugs.eclipse.org/bugs/buglist.cgi?product=AspectJ&component=Compiler
[ant:iajc]
[ant:iajc] Bugs for exceptions thrown have titles File:line from the top stack,
[ant:iajc] e.g., "SomeFile.java:243"
[ant:iajc]
[ant:iajc] If you don't find the exception below in a bug, please add a new bug
[ant:iajc] at http://bugs.eclipse.org/bugs/enter_bug.cgi?product=AspectJ
[ant:iajc] To make the bug a priority, please include a test program
[ant:iajc] that can reproduce this exception.
[ant:iajc] org.aspectj.weaver.MissingResolvedTypeWithKnownSignature cannot be cast to org.aspectj.weaver.ReferenceType
[ant:iajc]
[ant:iajc] when weaving type org.springframework.http.converter.feed.AtomFeedHttpMessageConverter
[ant:iajc] when weaving classes
[ant:iajc] when weaving
[ant:iajc] when batch building BuildConfig[null] #Files=49 AopXmls=#0
[ant:iajc] org.aspectj.weaver.MissingResolvedTypeWithKnownSignature cannot be cast to org.aspectj.weaver.ReferenceType
[ant:iajc] java.lang.ClassCastException: org.aspectj.weaver.MissingResolvedTypeWithKnownSignature cannot be cast to org.aspectj.weaver.ReferenceType
[ant:iajc] at org.aspectj.weaver.BoundedReferenceType.parameterize(BoundedReferenceType.java:109)
[ant:iajc] at org.aspectj.weaver.ResolvedType.parameterize(ResolvedType.java:2489)
[ant:iajc] at org.aspectj.weaver.ResolvedMemberImpl.parameterize(ResolvedMemberImpl.java:897)
[ant:iajc] at org.aspectj.weaver.ResolvedMemberImpl.parameterizedWith(ResolvedMemberImpl.java:794)
[ant:iajc] at org.aspectj.weaver.ResolvedMemberImpl.parameterizedWith(ResolvedMemberImpl.java:742)
[ant:iajc] at org.aspectj.weaver.ReferenceType.getDeclaredMethods(ReferenceType.java:859)
[ant:iajc] at org.aspectj.weaver.ResolvedType$MethodGetterIncludingItds.get(ResolvedType.java:252)
[ant:iajc] at org.aspectj.weaver.ResolvedType$MethodGetterIncludingItds.get(ResolvedType.java:250)
[ant:iajc] at org.aspectj.weaver.Iterators$4$1.hasNext(Iterators.java:213)
[ant:iajc] at org.aspectj.weaver.Iterators$4.hasNext(Iterators.java:230)
[ant:iajc] at org.aspectj.weaver.ResolvedType.lookupResolvedMember(ResolvedType.java:619)
[ant:iajc] at org.aspectj.weaver.JoinPointSignatureIterator.findSignaturesFromSupertypes(JoinPointSignatureIterator.java:192)
[ant:iajc] at org.aspectj.weaver.JoinPointSignatureIterator.hasNext(JoinPointSignatureIterator.java:68)
[ant:iajc] at org.aspectj.weaver.patterns.SignaturePattern.matches(SignaturePattern.java:317)
[ant:iajc] at org.aspectj.weaver.patterns.KindedPointcut.matchInternal(KindedPointcut.java:197)
[ant:iajc] at org.aspectj.weaver.patterns.Pointcut.match(Pointcut.java:137)
[ant:iajc] at org.aspectj.weaver.patterns.AndPointcut.matchInternal(AndPointcut.java:56)
[ant:iajc] at org.aspectj.weaver.patterns.Pointcut.match(Pointcut.java:137)
[ant:iajc] at org.aspectj.weaver.patterns.AndPointcut.matchInternal(AndPointcut.java:56)
[ant:iajc] at org.aspectj.weaver.patterns.Pointcut.match(Pointcut.java:137)
[ant:iajc] at org.aspectj.weaver.ShadowMunger.match(ShadowMunger.java:113)
[ant:iajc] at org.aspectj.weaver.Advice.match(Advice.java:109)
[ant:iajc] at org.aspectj.weaver.bcel.BcelAdvice.match(BcelAdvice.java:152)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.match(BcelClassWeaver.java:3304)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.match(BcelClassWeaver.java:2692)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.weave(BcelClassWeaver.java:480)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.weave(BcelClassWeaver.java:100)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weave(BcelWeaver.java:1689)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weaveWithoutDump(BcelWeaver.java:1633)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weaveAndNotify(BcelWeaver.java:1398)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weave(BcelWeaver.java:1184)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.AjPipeliningCompilerAdapter.weaveQueuedEntries(AjPipeliningCompilerAdapter.java:514)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.AjPipeliningCompilerAdapter.queueForWeaving(AjPipeliningCompilerAdapter.java:447)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.AjPipeliningCompilerAdapter.afterProcessing(AjPipeliningCompilerAdapter.java:432)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.CompilerAdapter.ajc$after$org_aspectj_ajdt_internal_compiler_CompilerAdapter$5$6b855184(CompilerAdapter.aj:103)
[ant:iajc] at org.aspectj.org.eclipse.jdt.internal.compiler.Compiler.process(Compiler.java:822)
[ant:iajc] at org.aspectj.org.eclipse.jdt.internal.compiler.Compiler.compile(Compiler.java:480)
[ant:iajc] at org.aspectj.org.eclipse.jdt.internal.compiler.Compiler.compile(Compiler.java:420)
[ant:iajc] at org.aspectj.ajdt.internal.core.builder.AjBuildManager.performCompilation(AjBuildManager.java:1036)
[ant:iajc] at org.aspectj.ajdt.internal.core.builder.AjBuildManager.performBuild(AjBuildManager.java:272)
[ant:iajc] at org.aspectj.ajdt.internal.core.builder.AjBuildManager.batchBuild(AjBuildManager.java:185)
[ant:iajc] at org.aspectj.ajdt.ajc.AjdtCommand.doCommand(AjdtCommand.java:112)
[ant:iajc] at org.aspectj.ajdt.ajc.AjdtCommand.runCommand(AjdtCommand.java:60)
[ant:iajc] at org.aspectj.tools.ajc.Main.run(Main.java:371)
[ant:iajc] at org.aspectj.tools.ajc.Main.runMain(Main.java:248)
[ant:iajc] at org.aspectj.tools.ajc.Main.main(Main.java:84)
[ant:iajc]
[ant:iajc] trouble in:
[ant:iajc] public class org.springframework.http.converter.feed.RssChannelHttpMessageConverter extends org.springframework.http.converter.feed.AbstractWireFeedHttpMessageConverter:
[ant:iajc] public void <init>():
[ant:iajc] ALOAD_0 // Lorg/springframework/http/converter/feed/RssChannelHttpMessageConverter; this (line 38)
[ant:iajc] NEW org.springframework.http.MediaType
[ant:iajc] DUP
[ant:iajc] LDC "application"
[ant:iajc] LDC "rss+xml"
[ant:iajc] INVOKESPECIAL org.springframework.http.MediaType.<init> (Ljava/lang/String;Ljava/lang/String;)V
[ant:iajc] INVOKESPECIAL org.springframework.http.converter.feed.AbstractWireFeedHttpMessageConverter.<init> (Lorg/springframework/http/MediaType;)V
[ant:iajc] constructor-execution(void org.springframework.http.converter.feed.RssChannelHttpMessageConverter.<init>())
[ant:iajc] | RETURN (line 39)
[ant:iajc] constructor-execution(void org.springframework.http.converter.feed.RssChannelHttpMessageConverter.<init>())
[ant:iajc] end public void <init>()
[ant:iajc]
[ant:iajc] protected boolean supports(Class):
[ant:iajc] method-execution(boolean org.springframework.http.converter.feed.RssChannelHttpMessageConverter.supports(java.lang.Class))
[ant:iajc] | LDC com.sun.syndication.feed.rss.Channel (line 43)
[ant:iajc] | ALOAD_1 // Ljava/lang/Class; clazz
[ant:iajc] | method-call(boolean java.lang.Class.isAssignableFrom(java.lang.Class))
[ant:iajc] | | INVOKEVIRTUAL java.lang.Class.isAssignableFrom (Ljava/lang/Class;)Z
[ant:iajc] | method-call(boolean java.lang.Class.isAssignableFrom(java.lang.Class))
[ant:iajc] | IRETURN
[ant:iajc] method-execution(boolean org.springframework.http.converter.feed.RssChannelHttpMessageConverter.supports(java.lang.Class))
[ant:iajc] end protected boolean supports(Class)
[ant:iajc]
[ant:iajc] end public class org.springframework.http.converter.feed.RssChannelHttpMessageConverter
[ant:iajc]
[ant:iajc]
[ant:iajc] Exception thrown from AspectJ 1.8.5
[ant:iajc]
[ant:iajc] This might be logged as a bug already -- find current bugs at
[ant:iajc] http://bugs.eclipse.org/bugs/buglist.cgi?product=AspectJ&component=Compiler
[ant:iajc]
[ant:iajc] Bugs for exceptions thrown have titles File:line from the top stack,
[ant:iajc] e.g., "SomeFile.java:243"
[ant:iajc]
[ant:iajc] If you don't find the exception below in a bug, please add a new bug
[ant:iajc] at http://bugs.eclipse.org/bugs/enter_bug.cgi?product=AspectJ
[ant:iajc] To make the bug a priority, please include a test program
[ant:iajc] that can reproduce this exception.
[ant:iajc] org.aspectj.weaver.MissingResolvedTypeWithKnownSignature cannot be cast to org.aspectj.weaver.ReferenceType
[ant:iajc]
[ant:iajc] when weaving type org.springframework.http.converter.feed.RssChannelHttpMessageConverter
[ant:iajc] when weaving classes
[ant:iajc] when weaving
[ant:iajc] when batch building BuildConfig[null] #Files=49 AopXmls=#0
[ant:iajc] org.aspectj.weaver.MissingResolvedTypeWithKnownSignature cannot be cast to org.aspectj.weaver.ReferenceType
[ant:iajc] java.lang.ClassCastException: org.aspectj.weaver.MissingResolvedTypeWithKnownSignature cannot be cast to org.aspectj.weaver.ReferenceType
[ant:iajc] at org.aspectj.weaver.BoundedReferenceType.parameterize(BoundedReferenceType.java:109)
[ant:iajc] at org.aspectj.weaver.ResolvedType.parameterize(ResolvedType.java:2489)
[ant:iajc] at org.aspectj.weaver.ResolvedMemberImpl.parameterize(ResolvedMemberImpl.java:897)
[ant:iajc] at org.aspectj.weaver.ResolvedMemberImpl.parameterizedWith(ResolvedMemberImpl.java:794)
[ant:iajc] at org.aspectj.weaver.ResolvedMemberImpl.parameterizedWith(ResolvedMemberImpl.java:742)
[ant:iajc] at org.aspectj.weaver.ReferenceType.getDeclaredMethods(ReferenceType.java:859)
[ant:iajc] at org.aspectj.weaver.ResolvedType$MethodGetterIncludingItds.get(ResolvedType.java:252)
[ant:iajc] at org.aspectj.weaver.ResolvedType$MethodGetterIncludingItds.get(ResolvedType.java:250)
[ant:iajc] at org.aspectj.weaver.Iterators$4$1.hasNext(Iterators.java:213)
[ant:iajc] at org.aspectj.weaver.Iterators$4.hasNext(Iterators.java:230)
[ant:iajc] at org.aspectj.weaver.ResolvedType.lookupResolvedMember(ResolvedType.java:619)
[ant:iajc] at org.aspectj.weaver.JoinPointSignatureIterator.findSignaturesFromSupertypes(JoinPointSignatureIterator.java:192)
[ant:iajc] at org.aspectj.weaver.JoinPointSignatureIterator.hasNext(JoinPointSignatureIterator.java:68)
[ant:iajc] at org.aspectj.weaver.patterns.SignaturePattern.matches(SignaturePattern.java:317)
[ant:iajc] at org.aspectj.weaver.patterns.KindedPointcut.matchInternal(KindedPointcut.java:197)
[ant:iajc] at org.aspectj.weaver.patterns.Pointcut.match(Pointcut.java:137)
[ant:iajc] at org.aspectj.weaver.patterns.AndPointcut.matchInternal(AndPointcut.java:56)
[ant:iajc] at org.aspectj.weaver.patterns.Pointcut.match(Pointcut.java:137)
[ant:iajc] at org.aspectj.weaver.patterns.AndPointcut.matchInternal(AndPointcut.java:56)
[ant:iajc] at org.aspectj.weaver.patterns.Pointcut.match(Pointcut.java:137)
[ant:iajc] at org.aspectj.weaver.ShadowMunger.match(ShadowMunger.java:113)
[ant:iajc] at org.aspectj.weaver.Advice.match(Advice.java:109)
[ant:iajc] at org.aspectj.weaver.bcel.BcelAdvice.match(BcelAdvice.java:152)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.match(BcelClassWeaver.java:3304)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.match(BcelClassWeaver.java:2692)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.weave(BcelClassWeaver.java:480)
[ant:iajc] at org.aspectj.weaver.bcel.BcelClassWeaver.weave(BcelClassWeaver.java:100)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weave(BcelWeaver.java:1689)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weaveWithoutDump(BcelWeaver.java:1633)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weaveAndNotify(BcelWeaver.java:1398)
[ant:iajc] at org.aspectj.weaver.bcel.BcelWeaver.weave(BcelWeaver.java:1184)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.AjPipeliningCompilerAdapter.weaveQueuedEntries(AjPipeliningCompilerAdapter.java:514)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.AjPipeliningCompilerAdapter.queueForWeaving(AjPipeliningCompilerAdapter.java:447)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.AjPipeliningCompilerAdapter.afterProcessing(AjPipeliningCompilerAdapter.java:432)
[ant:iajc] at org.aspectj.ajdt.internal.compiler.CompilerAdapter.ajc$after$org_aspectj_ajdt_internal_compiler_CompilerAdapter$5$6b855184(CompilerAdapter.aj:103)
[ant:iajc] at org.aspectj.org.eclipse.jdt.internal.compiler.Compiler.process(Compiler.java:822)
[ant:iajc] at org.aspectj.org.eclipse.jdt.internal.compiler.Compiler.compile(Compiler.java:480)
[ant:iajc] at org.aspectj.org.eclipse.jdt.internal.compiler.Compiler.compile(Compiler.java:420)
[ant:iajc] at org.aspectj.ajdt.internal.core.builder.AjBuildManager.performCompilation(AjBuildManager.java:1036)
[ant:iajc] at org.aspectj.ajdt.internal.core.builder.AjBuildManager.performBuild(AjBuildManager.java:272)
[ant:iajc] at org.aspectj.ajdt.internal.core.builder.AjBuildManager.batchBuild(AjBuildManager.java:185)
[ant:iajc] at org.aspectj.ajdt.ajc.AjdtCommand.doCommand(AjdtCommand.java:112)
[ant:iajc] at org.aspectj.ajdt.ajc.AjdtCommand.runCommand(AjdtCommand.java:60)
[ant:iajc] at org.aspectj.tools.ajc.Main.run(Main.java:371)
[ant:iajc] at org.aspectj.tools.ajc.Main.runMain(Main.java:248)
[ant:iajc] at org.aspectj.tools.ajc.Main.main(Main.java:84)
[ant:iajc]
[ant:iajc] 九月 08, 2016 8:35:41 下午 org.aspectj.weaver.tools.Jdk14Trace info
[ant:iajc] 信息: Dumping to D:\***\.\ajcore.20160908.203541.662.txt
[ant:iajc]
[ant:iajc] 2 fail|aborts
:myproject-common:compileAspect FAILED
제가 제거하면 스크립트
ajInpath ("com.aa.bb:bb-core:1.0")
gradle 빌드가 성공하며, 하지만 외부 병을 짜는 것이 필요해.
내 프로젝트는 아이디어 (16) + Gradle을 (2.12) + 스프링 부팅 (1.2.3)
어떤 도움이 이해할 수를 IntelliJ를 기반으로합니다.
============================================== =
업데이트 :
내가 제외 스프링 프레임 워크를 추가 한 후, 거기에는 컴파일 오류가 없지만 외부 항아리가 여전히 짠되지 않습니다.
ajInpath ("com.aa.bb:bb-core:1.0"){
exclude(group: "org.springframework")
}