[prev in list] [next in list] [prev in thread] [next in thread]
List: soap-user
Subject: Re: Soap-Https connection problem
From: "Trimarchi Michele" <Michele.Trimarchi () crypto ! it>
Date: 2003-02-28 8:55:54
[Download RAW message or body]
Finally it works.
I forgot to set this property:
System.setProperty("javax.net.ss.trustStorePassword", "keystorePass");
System.setProperty("javax.net.ssl.keyStorePassword", "keystorePass");
thanks anyway
Michele
p.s. (charm,not sharm) :)
----- Original Message -----
From: "Trimarchi Michele" <Michele.Trimarchi@crypto.it>
To: <soap-user@ws.apache.org>
Sent: Thursday, February 27, 2003 4:55 PM
Subject: Soap-Https connection problem
> Hi there..
> i'm trying to connect to a webservice that requires client authentication
> with https protocol but i can't connect because my servlet throws
> this exception.
>
> [SOAPException: faultCode=SOAP-ENV:Client; msg=Error opening socket:
> java.net.SocketException: SSL implementation not available;
> targetException=java.lang.IllegalArgumentException: Error opening socket:
> java.net.SocketException: SSL implementation not available]
> at
>
org.apache.soap.transport.http.SOAPHTTPConnection.send(SOAPHTTPConnection.ja
> va:354)
> at org.apache.soap.rpc.Call.invoke(Call.java:248)
> at TestPagamentiSOAP.doPost(TestPagamentiSOAP.java:62)
> at javax.servlet.http.HttpServlet.service(HttpServlet.java:760)
> at javax.servlet.http.HttpServlet.service(HttpServlet.java:853)[...]
>
> I have used keyman and in a file called client3.keystore file i have
> imported correctly private key for client authentication and server
> certificate for CA.
>
> a snippet of my code..
> System.setProperty("java.protocol.handler.pkgs",
> "com.sun.net.ssl.internal.www.protocol");
> Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider());
> System.setProperty("javax.net.ssl.trustStore","C:\\Documents and
> Settings\\mymachine\\Desktop\\client3.keystore");
> System.setProperty("javax.net.ssl.keyStore", "C:\\Documents and
> Settings\\mymachine\\Desktop\\client3.keystore");
>
> String SOAPActionURI = "";
> Call call = createCall();
> call.setMethodName("HelloWorld");
> call.setEncodingStyleURI(Constants.NS_URI_SOAP_ENC);
> call.setTargetObjectURI("urn:Service1");
> Vector params = new Vector();
> Parameter valorePar = new Parameter("valore", int.class, new
> Integer(valore), Constants.NS_URI_SOAP_ENC);
> params.addElement(valorePar);
> Parameter nomePar = new Parameter("nome", java.lang.String.class, nome,
> Constants.NS_URI_SOAP_ENC);
> params.addElement(nomePar);
> call.setParams(params);
> URL nuovoURL=new
> URL("https://serverwithhttps/pagamentiinternet/pagamento.asmx");
> org.apache.soap.rpc.Response resp = call.invoke(nuovoURL,
SOAPActionURI);
>
> on invoke it throws the exception!!!!!
>
> It's very strange because with the following code everything works great.
>
> [..]
> System.setProperty("java.protocol.handler.pkgs",
> "com.sun.net.ssl.internal.www.protocol");
> Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider());
>
> SSLSocketFactory ssf;
> TrustManagerFactory tmf;
> KeyManagerFactory kmf;
> KeyStore ks;
> FileInputStream fis;
> String pathKeyStore="C:\\Documents and
> Settings\\mymachine\\Desktop\\client3.keystore";
> char[] passphrase = "keystore".toCharArray();
>
> fis=new FileInputStream(pathKeyStore);
> ks = KeyStore.getInstance("JKS");
> ks.load(fis, passphrase);
> tmf = TrustManagerFactory.getInstance("SunX509");
> tmf.init(ks);
> kmf = KeyManagerFactory.getInstance("SunX509");
> kmf.init(ks, passphrase);
> SSLContext ctx = SSLContext.getInstance("TLS");
> ctx.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
> fis.close();
>
> try {
> URL url = new
> URL("https://serverwithhttps/pagamentiinternet/pagamento.asmx");
> com.sun.net.ssl.HttpsURLConnection connection =
> (com.sun.net.ssl.HttpsURLConnection) url.openConnection();
> ssf = ctx.getSocketFactory();
> connection.setSSLSocketFactory(ssf);
> connection.connect();
> System.out.println("Connection OK:" + connection.getURL());
> [...]
>
>
> This code works like a sharm,so i'm pretty sure that keystore is
correct.
> I'm using:
> jdk 1.2.2
> jsse-1_0_3_01
> apache soap 2.3
>
> Any hints?
> Tnx in advance.
>
> Michele
>
>
>
>
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic