JAVA实现HTTPS接口(POST方式)

来源:互联网 发布:淘宝认证照片拍摄技巧 编辑:程序博客网 时间:2024/06/12 03:24

前言:最近开发一个项目,需要回调其他公司的HTTPS远程接口,由于开发过程中遇到些困难,但最终还是解决,写这篇博客,记录一下过程。

1.实现X509证书信任管理器类(避免导证书)

import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;


import javax.net.ssl.X509TrustManager;


public class MyX509TrustManager implements X509TrustManager{

@Override  
public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {  
   
}  
 
@Override  
public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {  
                   
}  
 
@Override  
public X509Certificate[] getAcceptedIssuers() {   
    return null;  
}  
}

2.写一个发送POST请求的类

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.URL;

import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;

public class HttpRequest {

    /**
     * 向指定 URL 发送POST方法的请求
     * 
     * @param url
     *            发送请求的 URL
     * @param param
     *            请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
     * @return 所代表远程资源的响应结果
     */
    public static String sendPost(String url, String param) {
        PrintWriter out = null;
        BufferedReader in = null;
        String result = "";
        try {
       
        // 创建SSLContext对象,并使用我们指定的信任管理器初始化     
            TrustManager[] tm = { new MyX509TrustManager() };    
            SSLContext sslContext = SSLContext.getInstance("SSL");             
            sslContext.init(null, tm, new java.security.SecureRandom());    
              
            // 从上述SSLContext对象中得到SSLSocketFactory对象     
            SSLSocketFactory ssf = sslContext.getSocketFactory(); 
            
            // 打开和URL之间的连接
            URL realUrl = new URL(url);
            HttpsURLConnection conn = (HttpsURLConnection) realUrl.openConnection();
            conn.setSSLSocketFactory(ssf); 
            
            // 设置通用的请求属性
            conn.setRequestProperty("accept", "*/*");
            conn.setRequestProperty("connection", "Keep-Alive");
            conn.setRequestProperty("content-Type", "application/json");
            conn.setRequestProperty("user-agent",
                    "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
            // 发送POST请求必须设置如下两行
            conn.setDoOutput(true);
            conn.setDoInput(true);
            // 获取URLConnection对象对应的输出流
            out = new PrintWriter(conn.getOutputStream());
            // 发送请求参数
                     
            out.print(param);
            // flush输出流的缓冲
            out.flush();
            // 定义BufferedReader输入流来读取URL的响应
            in = new BufferedReader(
                    new InputStreamReader(conn.getInputStream()));
            String line;
            while ((line = in.readLine()) != null) {
                result += line;
            }
            System.out.println("-----result-----"+result);
        } catch (Exception e) {
            System.out.println("发送 POST 请求出现异常!"+e);
            e.printStackTrace();
        }
        //使用finally块来关闭输出流、输入流
        finally{
            try{
                if(out!=null){
                    out.close();
                }
                if(in!=null){
                    in.close();
                }
            }
            catch(IOException ex){
                ex.printStackTrace();
            }
        }
        return result;
    }   
 
}

3.调用POST请求测试代码

import java.util.HashMap;
import java.util.Map;


import com.alibaba.druid.support.json.JSONUtils;


public class Test {

private static String url = "https://192.168.1.101/"; 

public static void main(String[] args) throws Exception {

Map<String,Object> param = new HashMap<String,Object>();

//封装请求数据
param.put("service", "service");
   param.put("api", "api");    
   param.put("method", "method");  


   String message = JSONUtils.toJSONString(param);
   
   HttpRequest.sendPost(url, message);
}
}

这种方式的好处是绕过了证书认证,避免导证书,比较方便、简洁。

原创粉丝点击