2016-04-25 14 views
2

WindowsとLinuxの両方のシステム用インストーラを生成しています。ようこそ画面の後、私はユーザーの詳細を取得し、javax.ws.rs.client.ClientBuilderを使用してサーバーに送信するCustomFormコンポーネントを持っています。しかし、Windowsでは、My ClassがClientBuilderからクライアントを構築しようとすると、インストーラはjava.lang.LinkageError: ClassCastExceptionを投げます。全体のログは以下に記載されていますInstall4j:Windowsインストーラがjava.lang.LinkageErrorを表示しています:ClassCastException

java.lang.LinkageError: ClassCastException: attempting to cast 
jar:file:/C:/Users/lutful.kabir/AppData/Local/Temp/e4j363A.tmp_dir1460795758/user/javaee-api-7.0.jar!/javax/ws/rs/client/ClientBuilder.class to 
jar:file:/C:/Users/lutful.kabir/AppData/Local/Temp/e4j363A.tmp_dir1460795758/user/javaee-api-7.0.jar!/javax/ws/rs/client/ClientBuilder.class 
at javax.ws.rs.client.ClientBuilder.newBuilder(ClientBuilder.java:97) 
at javax.ws.rs.client.ClientBuilder.newClient(ClientBuilder.java:114) 
at install4j.AuthorizationHandler.verifyAuthorization(AuthorizationHandler.java:21) 
at install4j.backendsetup.VerifyBackend.install(VerifyBackend.java:27) 
at com.install4j.runtime.installer.InstallerContextImpl$2.fetchValue(InstallerContextImpl.java:167) 
at com.install4j.runtime.installer.InstallerContextImpl$2.fetchValue(InstallerContextImpl.java:164) 
at com.install4j.runtime.installer.helper.comm.actions.FetchObjectAction.execute(FetchObjectAction.java:14) 
at com.install4j.runtime.installer.helper.comm.HelperCommunication.executeActionDirect(HelperCommunication.java:272) 
at com.install4j.runtime.installer.helper.comm.HelperCommunication.executeActionInt(HelperCommunication.java:247) 
at com.install4j.runtime.installer.helper.comm.HelperCommunication.executeActionChecked(HelperCommunication.java:185) 
at com.install4j.runtime.installer.helper.comm.HelperCommunication.fetchObjectChecked(HelperCommunication.java:168) 
at com.install4j.runtime.installer.InstallerContextImpl.performActionIntStatic(InstallerContextImpl.java:164) 
at com.install4j.runtime.installer.InstallerContextImpl.performActionInt(InstallerContextImpl.java:152) 
at com.install4j.runtime.installer.ContextImpl.performAction(ContextImpl.java:1099) 
at com.install4j.runtime.installer.controller.Controller.executeAction(Controller.java:367) 
at com.install4j.runtime.installer.controller.Controller.executeActions(Controller.java:333) 
at com.install4j.runtime.installer.controller.Controller.handleCommand(Controller.java:194) 
at com.install4j.runtime.installer.controller.Controller.start(Controller.java:94) 
at com.install4j.runtime.installer.Installer.runInProcess(Installer.java:59) 
at com.install4j.runtime.installer.Installer.main(Installer.java:46) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:606) 
at com.exe4j.runtime.LauncherEngine.launch(LauncherEngine.java:62) 
at com.exe4j.runtime.WinLauncher.main(WinLauncher.java:101) 
at com.install4j.runtime.launcher.WinLauncher.main(WinLauncher.java:26) 

AuthorizationHandlerのためのコードは次のとおりです。今

package install4j; 

import java.net.ConnectException; 

import javax.ws.rs.client.Client; 
import javax.ws.rs.client.ClientBuilder; 
import javax.ws.rs.client.Invocation; 
import javax.ws.rs.client.Invocation.Builder; 
import javax.ws.rs.client.WebTarget; 
import javax.ws.rs.core.MediaType; 
import javax.ws.rs.core.Response; 

import com.install4j.api.Util; 
import com.install4j.api.context.InstallerContext; 

import installerconfigparams.utils.InstallerParameter; 

public class AuthorizationHandler { 

    public static boolean verifyAuthorization(String authToken, InstallerContext context) throws ConnectException { 
     Client client = ClientBuilder.newClient(); 
     WebTarget target = client.target(InstallerParameter.CENTRAL_SERVER_URL.getStringValue()) 
       .path(InstallerParameter.PATH_BACKEND_VERIFICATION.getStringValue()); 
     Builder builder = target.request(MediaType.APPLICATION_JSON); 
     builder.header(InstallerParameter.AUTHORIZATION_HEADER.getStringValue(), authToken); 
     Invocation invocation = builder.buildGet(); 
     Response response; 
     response = invocation.invoke(); 
     response.getStringHeaders(); 
     int status = response.getStatus(); 
     if (InstallerParameter.HTTP_200.getIntValue() != status) { 
      String args = response.getHeaderString("error"); 
      Util.showErrorMessage(context.getMessage("installer.backend.login.invalid") + args); 
      return false; 
     } 
     Util.showMessage(context.getMessage("installer.backend.login.successful")); 
     return true; 
    } 

は、私の知る限り知っていると私のインターネットの研究に基づいて、これは(重複資源があるかもしれない場合に発生することができますログからは、使用しているクラスClientBuilderも同じパスのものであることがわかります)。インストーラが混乱を招くように、重複したjarファイルが追加されていないことを確認しました。私はClassLoadersやInstall4jの仕組みについてよく知りません。私はまた、Run Scriptアクションを使用しようとしましたが、そこに直接コードを書きますが、同じ例外が発生しました。

私はインストーラをビルドして以来、同じクラスとメソッドを使用しています。今日まで問題はなかった。私はこの問題に直面する前に私の古いCommitにチェックアウトしました。しかし結果は同じです。この問題は、Windowsのインストーラでのみ発生します。

+1

これはコンテキストクラスローダの問題でしょうか?メソッドの先頭に 'Thread.currentThread()。setContextClassLoader(getClass()。getClassLoader());を追加してみてください。 –

+0

うわー!!私のローカルマシンでは、少なくとも動作します。答えの問題を詳細に説明してください。 – ShaDooW

答えて

2

JAX-WSは、いくつかの操作にコンテキストクラスローダを使用します。呼び出す

Thread.currentThread().setContextClassLoader(getClass().getClassLoader()); 

は、スクリプトをロードするのと同じクラスローダーに設定します。これは、install4j 6.1以降のシステムクラスローダーとは異なります。

install4j 6.1.2以降、コンテキスト・クラス・ローダーは自動的に調整されるため、上記の回避策は不要になります。

関連する問題