2015-10-14 5 views
0

Я хочу издеваться над 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 
+1

Во-первых, и самое главное: [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» для своего проекта и включить его в свой вопрос? –

+0

Да, но у меня нет выбора для Java 1.6, а JAdler использует Jetty 8 max. Я добавляю свое дерево зависимостей в свой вопрос. –

+1

Не вижу в вопросе 'dependency: tree'. –

ответ

0

Наконец с обновлением моего JDK (6 -> 7) и мой котом (6 -> 7 для сервлета-апи 3 .x) ошибка исправлена. Благодаря Joakim Erdelft. Я думаю, что это сервлет-api 3.x, который исправил мою проблему.

Моя новая зависимость: дерево:

+- 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:provided 
|  +- commons-validator:commons-validator:jar:1.1.4:provided 
|  +- oro:oro:jar:2.0.7:provided 
| \- xalan:xalan:jar:2.5.1:provided 
+- oracle:orai18n:jar:14:compile 
+- com.oracle:ojdbc6:jar:11.2.0.4:provided 
+- oracle:xdb:jar:11.2.0.3.0:compile 
+- javax.servlet:javax.servlet-api:jar:3.0.1:provided 
+- javax.servlet:jsp-api:jar:2.0:provided 
| \- javax.servlet:servlet-api:jar:2.4: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.2.14.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.11.v20130520:test 
|  |  +- org.eclipse.jetty:jetty-continuation:jar:8.1.11.v20130520:test 
|  | \- org.eclipse.jetty:jetty-http:jar:8.1.11.v20130520:test 
|  |  \- org.eclipse.jetty:jetty-io:jar:8.1.11.v20130520:test 
|  |  \- org.eclipse.jetty:jetty-util:jar:8.1.11.v20130520:test 
| \- org.eclipse.jetty.orbit:javax.servlet:jar:3.0.0.v201112011016:test 
    \- net.jadler:jadler-junit:jar:1.1.2:test 
1

У вас есть сервлет-АФИ в дереве зависимостей дважды.

+- javax.servlet:servlet-api:jar:2.4:provided 
+- javax.servlet:javax.servlet-api:jar:3.0.1:test 

Отбросьте javax.servlet:servlet-api:jar:2.4

А затем отметьте javax.servlet:javax.servlet-api:jar:3.0.1 в <scope>provided</scope>

+0

Да, я знаю, но это не проблема. Мой проект требует servlet-api 2.4, поэтому я помещаю их в предоставленные. Но для использования jetty 8 мне пришлось добавить servlet-api 3 в тесте scope вместо org.eclipse.jetty.orbit: javax-servlet, потому что используемый класс AsyncContext находится в этой библиотеке. Я поставил свою первую зависимость jadler в моем вопросе, прежде чем устанавливать servlet-api 3. AsyncContext: https://tomcat.apache.org/tomcat-8.0-doc/servletapi/javax/servlet/AsyncContext.html –

+0

Ящики сервлетов запечатаны и содержать подписанные/защищенные классы, вы не можете одновременно иметь оба пути в classpath. Это не будет работать. –

Смежные вопросы