• httpclient 无信任证书使用https


    1、当不需要使用任何证书访问https网页时,只需配置信任任何证书

    HttpClient http = new HttpClient();
    String url = "https://payment.cib.com.cn/payment/api/rest";
    Protocol myhttps = new Protocol("https", new MySSLProtocolSocketFactory(), 443); 
    Protocol.registerProtocol("https", myhttps); 
    PostMethod post = new PostMethod(url);

    2、其中信任任何证书的类

    import java.io.IOException;
    import java.net.InetAddress;
    import java.net.InetSocketAddress;
    import java.net.Socket;
    import java.net.SocketAddress;
    import java.net.UnknownHostException;
    import java.security.KeyManagementException;
    import java.security.NoSuchAlgorithmException;
    import java.security.cert.CertificateException;
    import java.security.cert.X509Certificate;
     
    import javax.net.SocketFactory;
    import javax.net.ssl.SSLContext;
    import javax.net.ssl.TrustManager;
    import javax.net.ssl.X509TrustManager;
     
    import org.apache.commons.httpclient.ConnectTimeoutException;
    import org.apache.commons.httpclient.params.HttpConnectionParams;
    import org.apache.commons.httpclient.protocol.ProtocolSocketFactory;
     
     
     
    /**
     * author by lpp
     *
     * created at 2010-7-26 上午09:29:33
     */
    public class MySSLProtocolSocketFactory implements ProtocolSocketFactory {
     
      private SSLContext sslcontext = null; 
      
      private SSLContext createSSLContext() { 
          SSLContext sslcontext=null; 
          try { 
              sslcontext = SSLContext.getInstance("SSL"); 
              sslcontext.init(null, new TrustManager[]{new TrustAnyTrustManager()}, new java.security.SecureRandom()); 
          } catch (NoSuchAlgorithmException e) { 
              e.printStackTrace(); 
          } catch (KeyManagementException e) { 
              e.printStackTrace(); 
          } 
          return sslcontext; 
      } 
      
      private SSLContext getSSLContext() { 
          if (this.sslcontext == null) { 
              this.sslcontext = createSSLContext(); 
          } 
          return this.sslcontext; 
      } 
      
      public Socket createSocket(Socket socket, String host, int port, boolean autoClose) 
              throws IOException, UnknownHostException { 
          return getSSLContext().getSocketFactory().createSocket( 
                  socket, 
                  host, 
                  port, 
                  autoClose 
              ); 
      } 
     
      public Socket createSocket(String host, int port) throws IOException, 
              UnknownHostException { 
          return getSSLContext().getSocketFactory().createSocket( 
                  host, 
                  port 
              ); 
      } 
      
      
      public Socket createSocket(String host, int port, InetAddress clientHost, int clientPort) 
              throws IOException, UnknownHostException { 
          return getSSLContext().getSocketFactory().createSocket(host, port, clientHost, clientPort); 
      } 
     
      public Socket createSocket(String host, int port, InetAddress localAddress, 
              int localPort, HttpConnectionParams params) throws IOException, 
              UnknownHostException, ConnectTimeoutException { 
          if (params == null) { 
              throw new IllegalArgumentException("Parameters may not be null"); 
          } 
          int timeout = params.getConnectionTimeout(); 
          SocketFactory socketfactory = getSSLContext().getSocketFactory(); 
          if (timeout == 0) { 
              return socketfactory.createSocket(host, port, localAddress, localPort); 
          } else { 
              Socket socket = socketfactory.createSocket(); 
              SocketAddress localaddr = new InetSocketAddress(localAddress, localPort); 
              SocketAddress remoteaddr = new InetSocketAddress(host, port); 
              socket.bind(localaddr); 
              socket.connect(remoteaddr, timeout); 
              return socket; 
          } 
      } 
      
      //自定义私有类 
      private static class TrustAnyTrustManager implements X509TrustManager { 
         
          public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException { 
          } 
     
          public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException { 
          } 
     
          public X509Certificate[] getAcceptedIssuers() { 
              return new X509Certificate[]{}; 
          } 
      }   
     
     
    }
  • 相关阅读:
    python中将集合进行切割的方法
    Tomcat单库多实例部署
    (二) storm的基本使用
    工作流表结构解析
    [TCO 2012 Round 3A Level3] CowsMooing (数论,中国剩余定理,同余方程)
    [HEOI 2013 day2] 钙铁锌硒维生素 (线性代数,二分图匹配)
    [HEOI 2013 day2] SAO (树形动态规划)
    关于react和Angular的思考
    angular 中的modal
    从易到难,写一个JavaScript加载器之一
  • 原文地址:https://www.cnblogs.com/daohangtaiqian/p/5392029.html
Copyright © 2020-2023  润新知