[AspectJ] Problem z java.lang.ClassFormatError

0

Witam,

niestety kompletnie się nie znam na AOP, więc wybaczcie jak będe pisał od rzeczy.

W bibliotece której używam jest klasa oznaczona @Aspect z metodą @Around. Zmieniać tą bibliotekę mogę jedynie dla celów testowych.
Przy odpaleniu mvn clean install testy przechodzą bez błędów, jakoś ten aspekt sobie dołącza do projektu, jak powstawiam println'y w tej klasie to mi je wyświetla. Niestety przy odpaleniu już samej aplikacji wysadza błąd z tej klasy: java.lang.ClassFormatError - bez żadnych dodatkowych informacji. Może macie jakieś doświadczenie czy to mogą być złe wersje jakiś zależności czy cokolwiek... utknąłem ; )

<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.6.5</version>

springowe zależności do spring-aop i spring-aspects wersja 3.0.0.RC1

//stacktrace
SEVERE: Servlet.service() for servlet [query] in context with path [/query] threw exception [org.springframework.web.util.NestedServletException: Handler processing failed; nested exception is java.lang.ClassFormatError: /aspects/DebugViewAdvice] with root cause
java.lang.ClassFormatError: /aspects/DebugViewAdvice
at freemarker.core.Environment.include(Environment.java:1)
at freemarker.core.Environment.importLib(Environment.java:1554)
at freemarker.core.Environment.importLib(Environment.java:1503)
at freemarker.template.Configuration.doAutoImportsAndIncludes(Configuration.java:843)
at freemarker.core.Configurable.doAutoImportsAndIncludes(Configurable.java:835)
at freemarker.core.Configurable.doAutoImportsAndIncludes(Configurable.java:835)
at freemarker.core.Environment.process(Environment.java:188)
at freemarker.template.Template.process(Template.java:237)
at org.springframework.web.servlet.view.freemarker.FreeMarkerView.processTemplate(FreeMarkerView.java:366)
at org.springframework.web.servlet.view.freemarker.FreeMarkerView.doRender(FreeMarkerView.java:283)
at org.springframework.web.servlet.view.freemarker.FreeMarkerView.renderMergedTemplateModel(FreeMarkerView.java:233)
at org.springframework.web.servlet.view.AbstractTemplateView.renderMergedOutputModel(AbstractTemplateView.java:167)
at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:250)
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1072)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:808)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:726)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:636)
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:545)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at servlet.filter.CompatibilityFilter.doFilter(CompatibilityFilter.java:42)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at servlet.filter.SeparationFilter.doFilter(SeparationFilter.java:63)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at servlet.filter.DecodingFilter.doFilter(DecodingFilter.java:61)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:563)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:399)
at org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:306)
at org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process(Http11AprProtocol.java:322)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:1732)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)

0

Pytanie czy masz włączony aspectjowy javaagent w skrypcie uruchomieniowym tomcata?
http://www.mail-archive.com/[email protected]/msg02940.html

0

Nie mam i pierwsze słyszę ; ) - jakoś to magicznie działa bez tego, bo odpalam sobie inne aplikacje które używają tej samej biblioteki - działają i przez tomcata (v7) i przez jetty...

//edit - podpialem - ryczy w konsoli błędami - popatrze co i jak i dam znac

0

miałem nieźle pogrzane w swoim repo...

Obecnie mam taki stan:

  1. Przy dodanym javaagencie dla aspectj dostaję błąd java.lang.NoSuchMethodError: aspects.LoggingAdvice.aspectOf()Laspects/LoggingAdvice;

  2. Bez javaagenta:
    java.lang.ClassFormatError: Duplicate field name&signature in class file aspects/DebugViewAdvice

wujek google srednio radzi ; )

//edit:
wydaje sie, ze po migracji na nowsza wersje biblioteki zostaly smieci w aplikacji - klasy z aspektami o takich samych sygnaturach i tu lezy problem

1 użytkowników online, w tym zalogowanych: 0, gości: 1