Я хочу издеваться над http-запросом в моем тестировании Junit. Поэтому я использую Jadler Project. Когда я запускаю мой тест и отправить свой запрос HTTP, у меня есть исключение:Java Jadler: конфликт Jetty
java.lang.SecurityException: class "javax.servlet.AsyncContext"'s signer information does not match signer information of other classes in the same package
at java.lang.ClassLoader.checkCerts(ClassLoader.java:806)
at java.lang.ClassLoader.preDefineClass(ClassLoader.java:487)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:625)
at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
at org.eclipse.jetty.server.AbstractHttpConnection.<init>(AbstractHttpConnection.java:162)
at org.eclipse.jetty.server.AsyncHttpConnection.<init>(AsyncHttpConnection.java:50)
at org.eclipse.jetty.server.nio.SelectChannelConnector.newConnection(SelectChannelConnector.java:285)
at org.eclipse.jetty.server.nio.SelectChannelConnector$ConnectorSelectorManager.newConnection(SelectChannelConnector.java:325)
at org.eclipse.jetty.server.nio.SelectChannelConnector.newEndPoint(SelectChannelConnector.java:272)
at org.eclipse.jetty.server.nio.SelectChannelConnector$ConnectorSelectorManager.newEndPoint(SelectChannelConnector.java:331)
at org.eclipse.jetty.io.nio.SelectorManager$SelectSet.createEndPoint(SelectorManager.java:842)
at org.eclipse.jetty.io.nio.SelectorManager$SelectSet.doSelect(SelectorManager.java:496)
at org.eclipse.jetty.io.nio.SelectorManager$1.run(SelectorManager.java:290)
at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)
at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)
at java.lang.Thread.run(Thread.java:662)
В начале моих зависимостей выглядит, что для JAdler:
<dependency>
<groupId>net.jadler</groupId>
<artifactId>jadler-core</artifactId>
<version>1.1.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>net.jadler</groupId>
<artifactId>jadler-jetty</artifactId>
<version>1.1.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>net.jadler</groupId>
<artifactId>jadler-junit</artifactId>
<version>1.1.2</version>
<scope>test</scope>
</dependency>
После Serveral поиска, я понимаю, почему у меня есть это исключение. Чтобы решить эту проблему, я должен был изменить свою зависимость так:
<dependency>
<groupId>net.jadler</groupId>
<artifactId>jadler-core</artifactId>
<version>1.1.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>net.jadler</groupId>
<artifactId>jadler-jetty</artifactId>
<version>1.1.2</version>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-server</artifactId>
</exclusion>
<exclusion>
<groupId>org.eclipse.jetty.orbit</groupId>
<artifactId>javax.servlet</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-server</artifactId>
<version>8.1.18.v20150929</version>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.eclipse.jetty.orbit</groupId>
<artifactId>javax.servlet</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.0.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>net.jadler</groupId>
<artifactId>jadler-junit</artifactId>
<version>1.1.2</version>
<scope>test</scope>
</dependency>
Я понимаю, что мол не использует javax.servlet.AsyncContext из org.eclipse.jetty.orbit: javax.servlet но он использует javax. сервлет: javax.servlet-api v3.0.1.
Кто-нибудь знает почему? Лучшее решение?
My JDK версия 1.6.45.
Если вам нужна дополнительная информация, как, например, мои тестовые источники, скажите мне.
EDIT 1: МВН зависимость: дерево
+- commons-beanutils:commons-beanutils:jar:1.6:compile
+- commons-collections:commons-collections:jar:3.2.1:compile
+- commons-digester:commons-digester:jar:1.5:compile
| \- xml-apis:xml-apis:jar:1.0.b2:compile
+- commons-fileupload:commons-fileupload:jar:1.0:compile
+- commons-lang:commons-lang:jar:2.6:compile
+- commons-logging:commons-logging:jar:1.1.1:compile
+- ant:ant-jakarta-oro:jar:1.6:compile
+- log4j:log4j:jar:1.2.17:compile
+- struts:struts:jar:1.2.9:compile
| +- commons-validator:commons-validator:jar:1.1.4:compile
| +- oro:oro:jar:2.0.7:compile
| \- xalan:xalan:jar:2.5.1:compile
+- oracle:orai18n:jar:14:compile
+- oracle:ojdbc6:jar:11.1.0.7.0:provided
+- oracle:xdb:jar:11.1.1.2.0:compile
+- javax.servlet:servlet-api:jar:2.4:provided
+- javax.servlet:jsp-api:jar:2.0:provided
+- org.slf4j:slf4j-api:jar:1.7.5:compile
+- org.slf4j:slf4j-log4j12:jar:1.7.12:test (scope not updated to compile)
+- antlr:antlr:jar:2.7.6:compile
+- com.fasterxml.jackson.core:jackson-databind:jar:2.6.0:compile
| +- com.fasterxml.jackson.core:jackson-annotations:jar:2.6.0:compile
| \- com.fasterxml.jackson.core:jackson-core:jar:2.6.0:compile
+- net.sf.ehcache:ehcache:jar:2.10.0:compile
+- org.springframework:spring-context:jar:3.2.14.RELEASE:compile
| +- org.springframework:spring-aop:jar:3.2.14.RELEASE:compile
| +- org.springframework:spring-beans:jar:3.2.14.RELEASE:compile
| +- org.springframework:spring-core:jar:3.2.14.RELEASE:compile
| \- org.springframework:spring-expression:jar:3.2.14.RELEASE:compile
+- org.springframework:spring-context-support:jar:3.2.14.RELEASE:compile
+- junit:junit:jar:4.12:test
| \- org.hamcrest:hamcrest-core:jar:1.3:test
+- org.springframework:spring-test:jar:3.0.6.RELEASE:test
+- net.jadler:jadler-core:jar:1.1.2:test
| +- org.hamcrest:hamcrest-library:jar:1.3:test
| \- commons-io:commons-io:jar:2.4:test
+- net.jadler:jadler-jetty:jar:1.1.2:test
+- org.eclipse.jetty:jetty-server:jar:8.1.18.v20150929:test
| +- org.eclipse.jetty:jetty-continuation:jar:8.1.18.v20150929:test
| \- org.eclipse.jetty:jetty-http:jar:8.1.18.v20150929:test
| \- org.eclipse.jetty:jetty-io:jar:8.1.18.v20150929:test
| \- org.eclipse.jetty:jetty-util:jar:8.1.18.v20150929:test
+- javax.servlet:javax.servlet-api:jar:3.0.1:test
\- net.jadler:jadler-junit:jar:1.1.2:test
Во-первых, и самое главное: [Java 1.6 был EOL (конец жизни) еще в 2013 году] (http://www.oracle.com/technetwork/java/eol-135779.html) и [Jetty 8 был EOL в 2014 году] (https://dev.eclipse.org/mhonarc/lists/jetty-announce/msg00069.html). Во-вторых, вы можете сделать «mvn dependency: tree» для своего проекта и включить его в свой вопрос? –
Да, но у меня нет выбора для Java 1.6, а JAdler использует Jetty 8 max. Я добавляю свое дерево зависимостей в свой вопрос. –
Не вижу в вопросе 'dependency: tree'. –