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