http请求绕过https的ssl证书

在本地环境中使用HttpClient调用HTTPS接口正常,但在服务器环境中出现PKIX路径构建失败的SSL证书异常。问题在于服务器缺少特定接口的SSL证书。通过创建忽略SSL证书验证的HttpClient来解决此问题,但这种方法可能存在安全风险。
摘要由CSDN通过智能技术生成

报错信息:PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException
ubable to find valid certification path to requested garget

网上有好多种解决办法,都一一试了下并没有直接解决该问题;
我遇到的问题是在本地电脑环境上使用httpClient 调用https接口正常,但是在服务器中就报以上异常。
根据网上搜索到大部分解决思路是 根据 SSLContextBuilder创建httpClient 方向是正确的,但是有的是创建时获取系统默认的证书方式绕过ssl证书验证(我系统上要是访问接口的ssl证书就不报上面的异常了)。
在这说下我本地电脑环境为什么可以访问接口成功但是服务器中不可以,因为之前我在浏览器中调试过,浏览器自动把该接口的ssl证书下载到系统当中了,所以才可以。


/**
* 忽略SSL证书的HTTP Client
* @return
*/
public static CloseableHttpClient createIgnoreSSLHttpClient(){
	try{
		SSLContext sslContext = SSLContextBuilder
				.create()
				.setTrustManagers(DefaultTrustManagers.INSTANCE)
				.build();
		SSLConnectionSocketFactory sslConnectionSocketFactory = new SSLConnectionSocketFactory(sslContext,NoopHostnameVerifier.INSTANCE);
		return HttpClients.custom().setSSLSocketFactory(sslConnectionSocketFactory).build();
	}catch(Exception e){
		//打印 创建忽略SSL证书的HTTP Client 异常日志
	}
	return HttpClient.createDefault();
}



    /**
     * http post 请求
     * @param url
     * @param json
     * @param token
     * @return
     */
    public static String doPost(String url,String json,String token){
        
        CloseableHttpClient httpClient = createIgnoreSSLHttpClient();
        CloseableHttpResponse response = null;
        String resultString = "";
        try {
            //创建Http post请求
            HttpPost httpPost = new HttpPost(url);
            // 如果不需传token验证则无需该行代码
            httpPost.setHeader("Authorization",token);
            // 创建请求内容
            StringEntity entity = new StringEntity(json, ContentType.APPLICATION_JSON);
            httpPost.setEntity(entity);
            //执行http请求
            response = httpClient.execute(httpPost);
            resultString = EntityUtils.toString(response.getEntity(),"utf-8");
        }catch (Exception e){
    
            //HttpClient--post请求异常日志
        }finally {
            close(response,httpClient);
        }
        return resultString;
    }

	/**
     * 关闭流
     * @param response
     * @param httpClient
     */
    public static void close(CloseableHttpResponse response,CloseableHttpClient httpClient){
        try {
            if(response != null){
                response.close();
            }
            if(httpClient != null){
                httpClient.close();
            }
        }catch (Exception e){
            // msg 关闭流异常日志
        }
    }
HTTPS是一种安全的HTTP协议,它通过SSL/TLS加密来保护数据传输,确保了通信过程的安全性和隐私性。默认情况下,浏览器或HTTP客户端在发送HTTPS请求时会验证服务器的SSL证书,包括证书的有效期、发行者以及证书链的完整性,以防止中间人攻击。 如果你想强制HTTPS请求不绕过SSL验证,通常是在一些特定场景下,比如测试环境需要模拟生产环境,或者为了某种原因(如性能测试)暂时禁用严格的SSL检查。这时,可以采取以下几种方法: 1. **Python** (requests库):使用`verify=False`或提供自签名证书路径,如`verify=False`或`cert=('/path/to/cert.pem', '/path/to/key.pem')`。 ```python import requests response = requests.get('https://example.com', verify=False) ``` 2. **JavaScript** (fetch API): 设置`credentials: 'include'` 和 `rejectUnauthorized: false` 可能会导致警告,因为这会让敏感信息暴露在未授权的环境中。 ```javascript fetch('https://example.com', { mode: 'no-cors', credentials: 'include', rejectUnauthorized: false }) ``` 3. **浏览器控制台**: 短期内,可以在开发者工具网络面板中勾选“忽略SSL证书错误”进行调试,但这仅适用于当前会话,并不推荐用于生产环境。 然而,不验证SSL是出于安全考虑的一个明确妥协,所以在实际应用中应谨慎使用,并确保对后果有充分理解。除非有特殊需求,否则强烈建议始终启用严格的SSL验证,以保护用户的数据安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值