Java 跳过证书方式调用https 接口

 Java 跳过证书方式调用https 接口地址实例:

package com.xuxueli.executor.sample.jboot;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.URL;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import com.xxl.job.core.log.XxlJobLogger;


/**
 * Jboot app
 */
public class JbootApp {
    public static void main(String[] args) {
         //JbootApplication.run(args);
    	try {
			JbootApp.execute("GET");
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
    }
    
    //UUAP 接口地址
   	private static String url="https://XXXXX";
   	final static HostnameVerifier DO_NOT_VERIFY = new HostnameVerifier() {
   	 
		public boolean verify(String hostname, SSLSession session) {
			return true;
		}
	};

    
    public static void execute(String param) throws Exception {
		XxlJobLogger.log("组织数据同步开始----start-----");
        XxlJobLogger.log("传入参数值:"+param);
        
        HttpsURLConnection connection = null;
        BufferedReader bufferedReader = null;
        try {
        	
	    	 SSLContext sslContext = SSLContext.getInstance("SSL");
	    	 sslContext.init(null, trustAllCerts, new java.security.SecureRandom());
	    	 
	    	// 从上述SSLContext对象中得到SSLSocketFactory对象     
	         SSLSocketFactory ssf = sslContext.getSocketFactory(); 
	    	// 打开和URL之间的连接
	    	URL realUrl = new URL(url);
	    	connection = (HttpsURLConnection) realUrl.openConnection();
	    	connection.setSSLSocketFactory(ssf);
	    	
            connection.setDoOutput(true);
            connection.setDoInput(true);
            connection.setRequestMethod("GET");
            connection.setRequestProperty("accept", "*/*");
            connection.setRequestProperty("connection", "Keep-Alive");
            connection.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)"); 
            connection.setRequestProperty("Content-Type", "application/json;charset=UTF-8");
            connection.setRequestProperty("Accept-Charset", "application/json;charset=UTF-8");
            connection.connect(); 
            
            // valid StatusCode
            int statusCode = connection.getResponseCode();
            XxlJobLogger.log("接口调用状态:"+statusCode);
            if (statusCode != 200) {
                throw new RuntimeException("Http Request StatusCode(" + statusCode + ") Invalid.");
            }

            // result
            bufferedReader = new BufferedReader(new InputStreamReader(connection.getInputStream(), "UTF-8"));
            StringBuilder result = new StringBuilder();
            String line;
            while ((line = bufferedReader.readLine()) != null) {
                result.append(line);
            }
            String responseMsg = result.toString();

            XxlJobLogger.log(responseMsg);
        } catch (Exception e) {
            XxlJobLogger.log(e);
        } finally {
            try {
                if (bufferedReader != null) {
                    bufferedReader.close();
                }
                if (connection != null) {
                    connection.disconnect();
                }
            } catch (Exception e2) {
                XxlJobLogger.log(e2);
            }
        }
        
	}
    
     // 创建SSLContext对象,并使用我们指定的信任管理器初始化     
	 public static TrustManager[] trustAllCerts = new TrustManager[]{new X509TrustManager() {
		    public java.security.cert.X509Certificate[] getAcceptedIssuers() {
		      return new java.security.cert.X509Certificate[]{};
		    }
		 
		    @Override
		    public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
		    }
		 
		    @Override
		    public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
		    }
	 }};

     
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值