https下的证书信任

package org.jiahao.weixin.util;
 
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
 
import javax.net.ssl.X509TrustManager;
/**
 * 自定义信任管理器类
 * @author Alvin
 * 自定义信任管理器类的所有方法都是空的实现,表示信任任何服务器端、客户端的证书。
 */
public class MyX509TrustManager implements X509TrustManager {
 
    // 检查客户端证书
    @Override
    public void checkClientTrusted(X509Certificate[] arg0, String arg1)
            throws CertificateException {
 
    }
 
    // 检查服务器端证书
    @Override
    public void checkServerTrusted(X509Certificate[] arg0, String arg1)
            throws CertificateException {
 
    }
 
    // 返回受信任的X509证书数组
    @Override
    public X509Certificate[] getAcceptedIssuers() {
        return null;
    }
 
}

一般这种方法是存在危险的,因为它能对任何https网站的证书信任,通常情况下,会在checkClientTrusted和checkServerTrusted两个方法下进行逻辑验证的处理。

/**
 * 处理https GET/POST请求
 *
 * @param requestUrl
 *            请求的地址
 * @param requestMethod
 *            请求的方法(GET/POST)
 * @param inputString
 *            请求体
 * @return
 */
public static String httpsRequest(String requestUrl, String requestMethod,
        String outputStr) {
    StringBuffer buffer = null;
    try {
        // 创建SSLContext
        SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
        TrustManager[] tm = { new MyX509TrustManager() };
        // 初始化
        sslContext.init(null, tm, new java.security.SecureRandom());
        // 获取SSLSocketFacroty对象
        SSLSocketFactory ssf = sslContext.getSocketFactory();
 
        URL url = new URL(requestUrl);
        HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
        conn.setRequestMethod(requestMethod);
        // 设置当前实例使用的SSLSocketFactory对象
        conn.setSSLSocketFactory(ssf);
        conn.connect();
 
        // 往服务器端写内容
        if (null != outputStr) {
            OutputStream os = conn.getOutputStream();
            os.write(outputStr.getBytes("utf-8"));
        }
 
        // 读取服务器返回的内容
        InputStream is = conn.getInputStream();
        InputStreamReader isr = new InputStreamReader(is, "utf-8");
        BufferedReader br = new BufferedReader(isr);
 
        buffer = new StringBuffer();
        String line = null;
        while ((line = br.readLine()) != null) {
            buffer.append(line);
        }
        // System.out.println(buffer.toString());
 
    } catch (Exception e) {
        e.printStackTrace();
    }
    return buffer.toString();
}



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值