2013-08-29 17 views
7

Ricevo "java.lang.ClassCastException" durante il tentativo di connettersi a un URL utilizzando javax.net.ssl.HttpsURLConnection.weblogic.net.http.SOAPHttpsURLConnection non può essere trasmesso a javax.net.ssl.HttpsURLConnection

Sto utilizzando Weblogic Server 10.3.4.

import javax.net.ssl.HostnameVerifier; 
import javax.net.ssl.HttpsURLConnection; 
import javax.net.ssl.SSLContext; 
import javax.net.ssl.SSLSession; 
import javax.net.ssl.TrustManager; 
import javax.net.ssl.X509TrustManager; 



import java.security.cert.X509Certificate; 


import java.io.BufferedReader; 
import java.io.InputStreamReader; 

import java.net.HttpURLConnection; 
import java.net.URL; 

/** 
* @author kmrgtm 
* 
*/ 
public class GatewayConnect { 


public void ConnectURL() 
{ 
    try 
    { 

     System.out.println("***** Inside Class File *****"); 
    // Create a trust manager that does not validate certificate chains 
    TrustManager[] trustAllCerts = new TrustManager[] {new X509TrustManager() { 
      public java.security.cert.X509Certificate[] getAcceptedIssuers() { 
       return null; 
      } 
      public void checkClientTrusted(X509Certificate[] certs, String authType) { 
      } 
      public void checkServerTrusted(X509Certificate[] certs, String authType) { 
      } 
     } 
    }; 

    // Install the all-trusting trust manager 
    SSLContext sc = SSLContext.getInstance("SSL"); 
    sc.init(null, trustAllCerts, new java.security.SecureRandom()); 
    HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory()); 

    // Create all-trusting host name verifier 
    HostnameVerifier allHostsValid = new HostnameVerifier() { 
     public boolean verify(String hostname, SSLSession session) { 
      return true; 
     } 
    }; 

    // Install the all-trusting host verifier 
    HttpsURLConnection.setDefaultHostnameVerifier(allHostsValid); 

    String urlstr="https://www.google.co.in"; 

    URL url = new URL(urlstr); 

    HttpsURLConnection conn = (HttpsURLConnection)url.openConnection(); 

    conn = (HttpsURLConnection)url.openConnection(); 


     if (conn instanceof javax.net.ssl.HttpsURLConnection) { 
     System.out.println("*** openConnection returns an instanceof javax.net.ssl.HttpsURLConnection"); 
     } 
     if (conn instanceof HttpURLConnection) { 
     System.out.println("*** openConnection returns an instnace of HttpURLConnection"); 
     } 
    conn.setRequestProperty("Content-Type","application/x-www-form-urlencoded"); 
    BufferedReader reader = null; 
    reader = new BufferedReader(new InputStreamReader(conn.getInputStream())); 
    for (String line; (line = reader.readLine()) != null;) { 
     System.out.println("##### line iz :::"+line); 
    } 




} 

catch(Exception e) 
{ 
    e.printStackTrace(); 
} 
} 



} 

L'eccezione che sto ottenendo è:

**java.lang.ClassCastException: weblogic.net.http.SOAPHttpsURLConnection cannot be cast to javax.net.ssl.HttpsURLConnection 
Inside the MessageSendingAction 
***** Inside Class File ***** 
    at com.secureConnect.GatewayConnect.ConnectURL(GatewayConnect.java:68) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at com.sun.el.parser.AstValue.invoke(Unknown Source) 
    at com.sun.el.MethodExpressionImpl.invoke(Unknown Source) 
    at javax.faces.component._MethodExpressionToMethodBinding.invoke(_MethodExpressionToMethodBinding.java:78) 
    at org.apache.myfaces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:57) 
    at javax.faces.component.UICommand.broadcast(UICommand.java:127) 
    at org.ajax4jsf.component.AjaxViewRoot.processEvents(AjaxViewRoot.java:329) 
    at org.ajax4jsf.component.AjaxViewRoot.broadcastEventsForPhase(AjaxViewRoot.java:304) 
    at org.ajax4jsf.component.AjaxViewRoot.processPhase(AjaxViewRoot.java:261) 
    at org.ajax4jsf.component.AjaxViewRoot.processApplication(AjaxViewRoot.java:474) 
    at org.apache.myfaces.lifecycle.InvokeApplicationExecutor.execute(InvokeApplicationExecutor.java:32) 
    at org.apache.myfaces.lifecycle.LifecycleImpl.executePhase(LifecycleImpl.java:103) 
    at org.apache.myfaces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:76) 
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:183) 
    at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:227) 
    at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:125) 
    at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:300) 
    at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26) 
    at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56) 
    at org.ajax4jsf.webapp.BaseXMLFilter.doXmlFilter(BaseXMLFilter.java:206) 
    at org.ajax4jsf.webapp.BaseFilter.handleRequest(BaseFilter.java:290) 
    at org.ajax4jsf.webapp.BaseFilter.processUploadsAndHandleRequest(BaseFilter.java:388) 
    at org.ajax4jsf.webapp.BaseFilter.doFilter(BaseFilter.java:515) 
    at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56) 
    at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.wrapRun(WebAppServletContext.java:3715) 
    at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3681) 
    at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321) 
    at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:120) 
    at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2277) 
    at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2183) 
    at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1454) 
    at weblogic.work.ExecuteThread.execute(ExecuteThread.java:207) 
    at weblogic.work.ExecuteThread.run(ExecuteThread.java:176)** 

Qualsiasi possibile motivo di questo errore?

+0

Non ha molto senso inserire i test di 'instanceof' * dopo * il cast, e non vi è alcun punto nel cast di una classe che non si usa nemmeno. Basta usarlo come URLConnection. – EJP

+0

'instanceof' è stato utilizzato solo a scopo di test. L'errore di trasmissione sta arrivando a questa riga :: HttpsURLConnection conn = (HttpsURLConnection) url.openConnection(); – KmrGtm

+0

codice viene eseguito fine..here è l'uscita http://sebsauvage.net/paste/?987346d13f71f550#800M7Vwk73Y5OOPpLhwIleZdktYk+vf0VAZKOtOoqfw= –

risposta

29

Ho finalmente trovato la soluzione. Se stiamo usando WebLogic Server, dobbiamo definire:

set JAVA_OPTIONS=%JAVA_OPTIONS% -DUseSunHttpHandler=true

... nel percorso di classe all'interno del server di dominio.

Questo dirà al server weblogic di utilizzare i Sun Http Handler e di non installarne uno proprio.

+0

Ciao! Ho avuto lo stesso problema, ma non so dove inserire esattamente queste istruzioni ... Attraverso la Console di amministrazione, nella scheda Avvio del server, forse? – Aitor

+3

È necessario impostarlo nel file setDomainEnv all'interno della cartella bin. – KmrGtm

+0

Puoi pubblicare il percorso completo e il nome completo del file? – Accollativo

1

Maggiori dettagli su soluzioni @KmrGtm:

L'unica cosa da fare è aggiornare le impostazioni del dominio WebLogic nel file di script setDomainEnv.

Le impostazioni pertinenti si trovano nel file di script setDomainEnv (setDomainEnv.cmd per Windows e setDomainEnv.sh per Linux).

Il file si trova nella sottodirectory bin della directory di dominio (/ user_projects/domini // bin /) dove:

  • è la directory in cui è stato installato WebLogic.
  • è il nome del dominio in cui si sta installando Studio.

Nel file aggiungere l'argomento JAVA_OPTIONS vicino alla parte superiore del file:

  • Per setDomainEnv.cmd (Windows):

set JAVA_OPTIONS =% JAVA_OPTIONS% -DUseSunHttpHandler = true

  • Per setDomainEnv.sh (Linux):

JAVA_OPTIONS = "% JAVA_OPTIONS% -DUseSunHttpHandler = true"

JAVA_OPTIONS esportazione

2

Si può anche definire in modo esplicito gestore di protocollo. Basta creare URL usando un altro costruttore.

URL url = new URL(null, urlstr, new sun.net.www.protocol.http.Handler()); 

o

URL url = new URL(null, urlstr, new sun.net.www.protocol.https.Handler()); 

e renderà il codice indipendente dalla -DUseSunHttpHandler opzione.

Problemi correlati