关于MAC下面 PKIX:unable to find valid certification path to requested target解决方法

一、背景

    最近在测试某个功能的时候,因为需要调用很多第三方的接口,是在太麻烦,而且要去线上环境,这就更加的困难了,于是想着写一个工具,自己去本地去调用这些接口,但是很不巧,遇到要给证书的问题,网上搜索了一大堆的解决方案,原因是确定的,就是缺少证书,但是怎么搞都不行,最后终于解决了,这里写个解决过程。

二、解决过程

   首先,我的mac环境是通过sdk安装的,不知道是不是这个原因,出现过很多问题,各种奇葩的报错,推荐还是通过命令行安装,然后配置环境变量,这种方式貌似能够避免很多不必要的麻烦。报错大概就是下面这个样子,去Google搜索一下,应该很多帖子,而且有多种解决方案,推荐用命令的方式来解决,这个在各个平台下面都能使用。

 
javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed:   
sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target  

问题的根本是:

缺少安全证书时出现的异常,这是因为我们去访问某个网站,没有安全证书,不受到信任导致的

解决问题方法:

获取这个网站的安全证书,然后导入到你的java环境中即可

听上去挺简单的,下面我们来尝试一下,首先需要一个java的代码去下载证书,具体源码如下,源码也是网友提供的

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.security.KeyStore;
import java.security.MessageDigest;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;

import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLException;
import javax.net.ssl.SSLSocket;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.TrustManagerFactory;
import java
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值