通过HttpClient实现访问HTTPS网站

文章的HttpClient版本为3.

实现SSL访问有2种方法.

第一种方式是通过浏览器导出需要的证书,然后将证书运用到代码中使用.

第二种方式,实现SSL管理,直接接收服务器发送到证书.

本文只讨论第二种方式.

该方法具体是实现一个SecureProtocolSocketFactory处理SSL.

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.SecureProtocolSocketFactory;

/**
 * @author yansheng723@gmail.com
 */
public class MySecureProtocolSocketFactory implements SecureProtocolSocketFactory {  
    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[]{};  
        }  
    }     
  
}  

调用实现的Factory,注册到Protocol中

@SuppressWarnings("deprecation")
Protocol protocol = new Protocol("https", new
		MySecureProtocolSocketFactory (), 443) {
};
Protocol.registerProtocol("https", protocol);


01-21
### C# 中的管道 (Pipe) 实现与用法 在 C# 和 ASP.NET 应用程序中,管道的概念主要用于处理请求和响应的过程中。通过使用中间件组件来构建应用程序管线,可以更灵活地处理 HTTP 请求。 #### 使用 `Named Pipes` 进行进程间通信 C# 提供了对命名管道的支持,允许不同进程之间进行高效的双向通信: ```csharp using System; using System.IO.Pipes; using System.Text; using System.Threading.Tasks; public class PipeServerExample { public static async Task StartServerAsync() { using var server = new NamedPipeServerStream("testpipe", PipeDirection.InOut); Console.WriteLine("等待客户端连接..."); await server.WaitForConnectionAsync(); Console.WriteLine("已建立连接"); using var reader = new StreamReader(server, Encoding.UTF8); using var writer = new StreamWriter(server, Encoding.UTF8); string messageFromClient = await reader.ReadLineAsync(); Console.WriteLine($"收到消息: {messageFromClient}"); await writer.WriteLineAsync("你好,来自服务器的消息"); await writer.FlushAsync(); server.Disconnect(); } } ``` 此代码展示了如何创建一个简单的命名管道服务端[^1]。 对于客户端部分,则可以通过如下方式与其交互: ```csharp using System; using System.IO.Pipes; using System.Text; using System.Threading.Tasks; public class PipeClientExample { public static async Task ConnectToServerAsync() { using var client = new NamedPipeClientStream(".", "testpipe", PipeDirection.InOut); await client.ConnectAsync(); Console.WriteLine("成功连接到服务器"); using var reader = new StreamReader(client, Encoding.UTF8); using var writer = new StreamWriter(client, Encoding.UTF8); await writer.WriteLineAsync("你好,我是客户端"); await writer.FlushAsync(); string response = await reader.ReadLineAsync(); Console.WriteLine($"服务器回复: {response}"); } } ``` 这段代码实现了向上述服务器发送一条消息并接收其回应的功能。 除了基本的读写操作外,在实际应用中还可以考虑加入异常处理机制以及超时设置等功能以增强稳定性。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值