1

また私です。そして今日、私はある種の奇妙な問題に直面しています。何かが正しく理解できなかったか、木の前の森が見当たらないだけです。

次のシナリオ:

  • JDK1.7にバンドルされているJavaFXを使用しています
  • デスクトップ(jar)とアプレット(ブラウザ内のjnlp)の両方のクライアントランタイムが必要です
  • プロジェクト用にMavenプロジェクトを設定しています
  • 親pomとさまざまなサブモジュールがあります
  • クライアントがWebサービスと通信する必要があります。これは、Webサービスに接続するためのフレームワークとしてCXFを選択したためです(実行時にWebサービスを切り替えることができる必要があります)。
  • 「Webサービスへの接続」は、wsConnectorと呼ばれる独自のMavenサブモジュールです。

ここにいくつかの環境情報と私のpomスニペットがあります:

mvn -version
Apache Maven 3.0.4 (r1232337; 2012-01-17 09:44:56+0100)
Maven home: C:\Program Files (x86)\Apache\maven-3.0.4\bin\..
Java version: 1.7.0_07, vendor: Oracle Corporation
Java home: C:\Program Files\Java\jdk1.7.0_07\jre
Default locale: de_DE, platform encoding: Cp1252
OS name: "windows 7", version: "6.1", arch: "amd64", family: "windows"

wsConnectorサブモジュールをコンパイルできるようにするには、これもすべてのWebサービス接続を処理するため、CXFが必要とするため、JDKからtools.jarを統合する必要があります。

親pom.xmlの関連プロパティ:

<properties>
    <maven.compiler.source>1.7</maven.compiler.source>
    ...
</properties>
        

サブモジュールpom.xml:

<properties>
    <cxf.version>2.6.2</cxf.version>
</properties>

<dependencies>
    <dependency>
        ... // some other sub modules
    </dependency>
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-frontend-jaxws</artifactId>
        <version>${cxf.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-transports-http</artifactId>
        <version>${cxf.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-transports-http-jetty</artifactId>
        <version>${cxf.version}</version>
    </dependency>
    <dependency>
        <groupId>com.oracle</groupId>
        <artifactId>tools</artifactId>
        <version>${maven.compiler.source}]</version>
        <scope>system</scope>
        <systemPath>${java.home}/../lib/tools.jar</systemPath>
    </dependency>
</dependencies>

私が走ればmvn clean package、すべてがうまく機能し、ダンディです。クライアントアプリのデプロイディレクトリ(jar、生成​​されたHTML、jnlpファイルもあります)にも、がありtools.jarます。

JNLPファイルを見ると、次のエントリが見つかります。

<jar href="tools.jar" size="15226565" download="eager" />

今私の問題は、クライアントをで実行するとjava -jar client.jar、すべてが機能するということです。しかし、HTML / JNLPファイルを呼び出すと、ClassNotFoundExceptiontools.jarがクラスパス上にないことを示すが表示されます。したがって、サーバーまたはローカルホストからアプレットを開いてもかまいません。

スタックトレースは次のとおりです。

java.lang.IllegalStateException: Unable to create schema compiler
 at org.apache.cxf.common.jaxb.JAXBUtils.createSchemaCompilerWithDefaultAllocator(JAXBUtils.java:694)
 at org.apache.cxf.endpoint.dynamic.DynamicClientFactory.createClient(DynamicClientFactory.java:303)
 at org.apache.cxf.endpoint.dynamic.DynamicClientFactory.createClient(DynamicClientFactory.java:270)
 at org.apache.cxf.endpoint.dynamic.DynamicClientFactory.createClient(DynamicClientFactory.java:263)
 at org.apache.cxf.endpoint.dynamic.DynamicClientFactory.createClient(DynamicClientFactory.java:198)
 at com.multiguide.ws.WebServiceConnector.setWsdlUrl(WebServiceConnector.java:45)
 at com.multiguide.ws.WebServiceConnector.setWsdlUrl(WebServiceConnector.java:31)
 at com.multiguide.view.administration.WebServiceInformationPanel.connect(WebServiceInformationPanel.java:130)
 at com.multiguide.view.administration.WebServiceInformationPanel.refresh(WebServiceInformationPanel.java:70)
 at com.multiguide.view.administration.WebServiceInformationPanel.<init>(WebServiceInformationPanel.java:45)
 at com.multiguide.view.administration.WebServiceInformationPanel$$FastClassByGuice$$da5f387e.newInstance(<generated>)
 at com.google.inject.internal.cglib.reflect.$FastConstructor.newInstance(FastConstructor.java:40)
 at com.google.inject.internal.DefaultConstructionProxyFactory$1.newInstance(DefaultConstructionProxyFactory.java:60)
 at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:85)
 at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:254)
 at com.google.inject.internal.SingleParameterInjector.inject(SingleParameterInjector.java:38)
 at com.google.inject.internal.SingleParameterInjector.getAll(SingleParameterInjector.java:62)
 at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:84)
 at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:254)
 at com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46)
 at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1031)
 at com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40)
 at com.google.inject.Scopes$1$1.get(Scopes.java:65)
 at com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:40)
 at com.google.inject.internal.SingleParameterInjector.inject(SingleParameterInjector.java:38)
 at com.google.inject.internal.SingleParameterInjector.getAll(SingleParameterInjector.java:62)
 at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:84)
 at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:254)
 at com.google.inject.internal.FactoryProxy.get(FactoryProxy.java:54)
 at com.google.inject.internal.SingleParameterInjector.inject(SingleParameterInjector.java:38)
 at com.google.inject.internal.SingleParameterInjector.getAll(SingleParameterInjector.java:62)
 at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:84)
 at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:254)
 at com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46)
 at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1031)
 at com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40)
 at com.google.inject.Scopes$1$1.get(Scopes.java:65)
 at com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:40)
 at com.google.inject.internal.InjectorImpl$4$1.call(InjectorImpl.java:978)
 at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1024)
 at com.google.inject.internal.InjectorImpl$4.get(InjectorImpl.java:974)

... 9 more
Caused by: javax.xml.bind.JAXBException - with linked exception:

java.lang.ClassNotFoundException: com/sun/tools/internal/xjc/api/XJC
 at org.apache.cxf.common.jaxb.JAXBUtils.createSchemaCompiler(JAXBUtils.java:679)
 at org.apache.cxf.common.jaxb.JAXBUtils.createSchemaCompilerWithDefaultAllocator(JAXBUtils.java:686)

... 49 more
Caused by:

java.lang.ClassNotFoundException: com/sun/tools/internal/xjc/api/XJC
 at java.lang.Class.forName0(Native Method)
 at java.lang.Class.forName(Unknown Source)
 at org.apache.cxf.common.jaxb.JAXBUtils.createSchemaCompiler(JAXBUtils.java:672)

... 50 more

guiceを使用しているので、クラスの読み込みの問題ですか?この例外を除いて、アプリは魅力のように機能しています。接続、URLの切り替えなど、必要なすべてのWebサービスを実行できます。したがって、それが理由になるとは思いません。

その他の注意:今はここでは問題ではないと思いますが、私はguiceを使用しているので、もちろん私のJNLPファイルには

<security>
  </all-permissions>
</security>

国旗。

誰かがそれを経験したことがありますか?たぶん私は本当に何かが恋しいですが、どんな助けでも(いつものように;))大歓迎です:)

4

1 に答える 1

1

最後に、クラスパスにtools.jarを取得しました。配信しているjarファイルのマニフェストに、クライアントアプリケーションが含まれていることが欠落していることがわかりました。

これはJavaFXアプリケーションであるため、クライアントサブモジュールのマニフェストファイルの構成のクラスパスタグ内にtools.jar依存関係を追加する必要がありました。

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <configuration>
                <archive>
                    <manifestEntries>
                        ...
                        <Class-Path>jfxrt.jar tools.jar</Class-Path>
                    </manifestEntries>
                    <manifest>
                        <addClasspath>true</addClasspath>
                    </manifest>
                </archive>
            </configuration>
        </plugin>

クラスパスにtools.jarを含めた後、CXFはJavaコンパイラを呼び出そうとします。エラーメッセージを参照してください。

org.apache.cxf.common.jaxb.JAXBUtils logGeneratedClassNames
INFO: Created classes: <list of my generated JAVA files from the wsdl file here>
[ERROR] IOException during exec() of compiler "javac". Check your path environment variable.
Okt 23, 2012 3:46:20 PM org.apache.cxf.endpoint.dynamic.DynamicClientFactory createClient
SEVERE: Could not compile java files for <url to wsdl file here>.

つまり、これは、クライアントマシンでJDKを実行してセットアップする必要があることを意味します。私もjavacにサービスを提供する場合(考えただけで私を責めることはありません:))、これはクライアントマシンで何かを実行する必要があることを意味します。

そのために、私が最初に望んでいたものの代替ソリューションを見つけます(ソリューションはgenerate-ws-accessing-classesをアウトソーシングします)。

ただし、tools.jarをクラスパスに統合する方法に関する最初の質問では、上記で記述した内容によって問題が解決しました。

于 2012-10-23T15:50:23.730 に答える