每周问题积累

1.

2019年第13周

今天接口自动化测试,java程序发送curl命令,结果报错

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

原因:访问请求是https请求,网站有证书,java不会主动找电脑系统上的证书,它使用keytool管理自己的证书,所以需要访问网站,将网站证书下载下来,再使用keytool命令添加证书

示例:

sudo keytool -import -alias charles -file /Users/didi/nouse/charles-ssl-proxying-certificate.cer  -keystore /Library/Java/JavaVirtualMachines/jdk1.8.0_121.jdk/Contents/Home/jre/lib/security/cacerts

参考:https://www.cnblogs.com/wupher/archive/2012/08/05/2623561.html

但是我安装成功之后,运行java程序发送请求还是报错,可能需要设置System.property吧,具体我没有研究下去,因为安装证书后引起了其他的小问题 我就没再使用这种方式,删除了这个证书。

继续研究--

由于我charles代理,请求是ok的,所以我就参考https://blog.csdn.net/nbda1121440/article/details/90574096

System.setProperty("https.proxyHost", "127.0.0.1"); System.setProperty("https.proxyPort", "8888");

使用keytool安装charles的证书,再打开charles,运行java程序发送请求,通过charls代理请求,返回成功

 

 

 

你可能感兴趣的:(每周问题积累)