代码之家  ›  专栏  ›  技术社区  ›  Manuel Garcia de Vinuesa

在Weblogic 10.3.6中结合2waySSL和代理使用JAX-WS

  •  0
  • Manuel Garcia de Vinuesa  · 技术社区  · 7 年前

    我在weblogic 10.3.6中用JAX-WS实现了一个到不同类型webservice的连接器,该连接器可以配置为2waySSL和代理,并将两者结合起来。

    错误是:

        ACTIVE] ExecuteThread: '19' for queue: 'weblogic.kernel.Default (self-tuning)', READ: TLSv1.2 Alert, length = 64
    Padded plaintext after DECRYPTION:  len = 64
    0000: F0 E5 6E 9F 6F F4 BB 2E   07 29 56 FE 34 0A 10 0B  ..n.o....)V.4...
    0010: 02 28 7E 75 92 F7 03 4E   CD 3A 7E 0B E2 6A 7C 8E  .(.u...N.:...j..
    0020: 3B F8 4E F5 98 A3 D3 B4   67 76 20 49 1B 77 07 5E  ;.N.....gv I.w.^
    0030: 9D 66 0D 0D 0D 0D 0D 0D   0D 0D 0D 0D 0D 0D 0D 0D  .f..............
    [ACTIVE] ExecuteThread: '19' for queue: 'weblogic.kernel.Default (self-tuning)', RECV TLSv1.2 ALERT:  fatal, handshake_failure
    [ACTIVE] ExecuteThread: '19' for queue: 'weblogic.kernel.Default (self-tuning)', fatal: engine already closed.  Rethrowing javax.net.ssl.SSLException: Received fatal alert: handshake_failure
    [ACTIVE] ExecuteThread: '19' for queue: 'weblogic.kernel.Default (self-tuning)', fatal: engine already closed.  Rethrowing javax.net.ssl.SSLException: Received fatal alert: handshake_failure
    <13-sep-2017 09H32' CEST> <Debug> <SecuritySSL> <BEA-000000> <[Thread[[ACTIVE] ExecuteThread: '19' for queue: 'weblogic.kernel.Default (self-tuning)',5,Pooled Threads]]weblogic.security.SSL.jsseadapter: SSLENGINE: Exception occurred during SSLEngine.unwrap(ByteBuffer,ByteBuffer[]).
    javax.net.ssl.SSLException: Received fatal alert: handshake_failure
        at com.sun.net.ssl.internal.ssl.Alerts.getSSLException(Alerts.java:188)
        at com.sun.net.ssl.internal.ssl.SSLEngineImpl.fatal(SSLEngineImpl.java:1614)
        at com.sun.net.ssl.internal.ssl.SSLEngineImpl.fatal(SSLEngineImpl.java:1582)
        at com.sun.net.ssl.internal.ssl.SSLEngineImpl.recvAlert(SSLEngineImpl.java:1751)
        at com.sun.net.ssl.internal.ssl.SSLEngineImpl.readRecord(SSLEngineImpl.java:1043)
        at com.sun.net.ssl.internal.ssl.SSLEngineImpl.readNetRecord(SSLEngineImpl.java:865)
        at com.sun.net.ssl.internal.ssl.SSLEngineImpl.unwrap(SSLEngineImpl.java:740)
    

    调试和反编译weblogic源代码时,我可以看到HttpsClient在使用代理时没有使用自定义SSLSocketFactory。

        protected HttpURLConnection openConnection(Packet paramPacket)
                                  …
    
     localSSLSocketFactory = (javax.net.ssl.SSLSocketFactory)this.context.invocationProperties.get("com.sun.xml.ws.transport.https.client.SSLSocketFactory");
            if ((localSSLSocketFactory != null) && ((localSSLSocketFactory instanceof javax.net.ssl.SSLSocketFactory)))
            {
              if (LOGGER.isLoggable(Level.FINE)) {
                LOGGER.fine("set (jdk) ssl socketfactory to wls socketfactory");
              }
              ((weblogic.net.http.HttpsURLConnection)localObject3).setSSLSocketFactory(new MySSLSocketFactory((javax.net.ssl.SSLSocketFactory)localSSLSocketFactory));
            }
    …
    

    如您所见,设置自定义SSLSocketFactory。

    this.serverSocket = localSocketFactory.createSocket(arrayOfInetAddress[i], paramInt);
    

    localSocketFactory是自定义SSLSocketFactory。

    private void makeConnectionUsingProxy(String s, int i, boolean flag)
        throws IOException
    {
        javax.net.ssl.SSLSocketFactory sslsocketfactory;
        int j;
        SSLContextWrapper sslcontextwrapper = SSLSetup.getSSLContext(sslInfo);
        sslcontextwrapper.getHostnameVerifier().setProxyMapping(s, host);
        sslcontextwrapper.getTrustManager().setProxyMapping(s, host);
        sslsocketfactory = sslcontextwrapper.getSSLSocketFactory();
    

    sslInfo是一个没有在SSLSocketFactory中通知密钥库或信任库的对象。我没有看到任何通知对象sslInfo(weblogic.security.SSL.SSLClientInfo)的方法

    -Dweblogic.security.SSL.nojce=true -Djavax.net.debug=all -Dssl.debug=true
    -Djavax.net.ssl.keyStore=XXXXXs -Djavax.net.ssl.keyStorePassword=XXXXX
    -Djdk.tls.enableRC4CipherSuites=true -Djsse.enableSNIExtension=false -Dweblogic.ssl.JSSEEnabled=true -Dweblogic.security.SSL.enableJSSE=true -Dweblogic.security.SSL.nojce=true -Dweblogic.security.SSL.ignoreHostnameVerification=true
    

    自定义SSLSocketFactory是使用此参数和默认信任库创建的。当没有使用代理时,一切都正常工作。

    我不理解为什么与代理连接weblogic不使用相同的SSLSocketFactory。

    有什么想法吗?

    1 回复  |  直到 7 年前
        1
  •  0
  •   Manuel Garcia de Vinuesa    7 年前

    Oracle人员已经向我们确认,这是该实现中的一个“bug”,只有使用属性DuseUnhtphandler=true才能解决。

    在Oracle 12中,可以使用ClientProxyFeature的setter方法setUseSunHttpHandler。但用weblogic实现是不可能解决的。