0

HttpClientAPI との通信を処理するために Apache ライブラリを使用しています。展開されたコードを単体テストすると、すべてのコードがエラーなしでコンパイルおよび実行されます。ただし、ソースを JAR し、分離された統合テストでコードをテストすると、次のエラーが発生します。

Exception in thread "main" java.lang.NoClassDefFoundError: org/jboss/logmanager/Logger$AttachmentKey
    at org.slf4j.impl.Slf4jLoggerFactory.<clinit>(Slf4jLoggerFactory.java:31)
    at org.slf4j.impl.StaticLoggerBinder.getLoggerFactory(StaticLoggerBinder.java:33)
    at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:240)
    at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:208)
    at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:155)
    at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:131)
    at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:645)
    at org.apache.http.impl.client.AbstractHttpClient.<init>(AbstractHttpClient.java:159)
    at org.apache.http.impl.client.DefaultHttpClient.<init>(DefaultHttpClient.java:178)
    at opart.api.client.trasnsport.Transport.get(Transport.java:81)
    at opart.api.client.dao.objects.ObjectsDao.getInterestingObjects(ObjectsDao.java:70)
    at opart.api.client.OpartApiClient.getInterestingObjects(OpartApiClient.java:79)
    at ApiTest.interesting(ApiTest.java:32)
    at ApiTest.main(ApiTest.java:21)
Caused by: java.lang.ClassNotFoundException: org.jboss.logmanager.Logger$AttachmentKey
    at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
    ... 14 more

このように DefaultHttpClient オブジェクトをインスタンス化しようとすると:

DefaultHttpClient defaultHttpClient = new DefaultHttpClient();

JAR に含めたライブラリは次のとおりです。

  • グアバ-r09.jar
  • commons-logging-1.1.1.jar
  • httpclient-4.1.2.jar
  • httpcore-4.1.2.jar
  • gson-1.7.1.jar

JBoss を参照しようとしている理由について何か考えはありますか?

4

1 に答える 1

1

私が見つけた解決策zipfilesetは、uber JAR のルート内の JARchive の内容を安全に爆発させる ant ターゲットを使用することでした。

于 2012-05-06T20:48:09.327 に答える