IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> spring cloud项目 用restTemplate 访问第三方https接口报错:ValidatorException: PKIX path building failed: -> 正文阅读

[网络协议]spring cloud项目 用restTemplate 访问第三方https接口报错:ValidatorException: PKIX path building failed:

场景:

今天有一个功能,spring cloud项目需要调用远程https 接口,使用 RestTemplate,本地测试无异常;部署到测试环境后报证书问题:异常如下:

I/O error on POST request for "https://gateway.xxx.com/yao/user/login": sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target; nested exception is 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

解决办法1:因为是https证书问题,所以配置了信任所有证书,响应正常。

解决办法2:代码方式证书配置

代码如下:
? ? @Bean(name="restTemplateRemote")
? ? public RestTemplate restTemplateRemote() throws Exception {
? ? ? ? TrustManager[] trustAllCerts =new TrustManager[] {
? ? ? ? ? ? ? ? new X509TrustManager() {
? ? ? ? ? ? ? ? ? ? @Override
? ? ? ? ? ? ? ? ? ? public java.security.cert.X509Certificate[] getAcceptedIssuers() {
? ? ? ? ? ? ? ? ? ? ? ? return new java.security.cert.X509Certificate[0];
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? @Override
? ? ? ? ? ? ? ? ? ? public void checkClientTrusted(
? ? ? ? ? ? ? ? ? ? ? ? ? ? java.security.cert.X509Certificate[] certs, String authType) {
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? @Override
? ? ? ? ? ? ? ? ? ? public void checkServerTrusted(
? ? ? ? ? ? ? ? ? ? ? ? ? ? java.security.cert.X509Certificate[] certs, String authType) {
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? };
? ? ? ? SSLContext sslContext =SSLContext.getInstance("SSL");
? ? ? ? sslContext.init(null, trustAllCerts, new java.security.SecureRandom());
? ? ? ? CloseableHttpClient httpClient =HttpClients.custom()
? ? ? ? ? ? ? ? .setSSLContext(sslContext)
? ? ? ? ? ? ? ? .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE)
? ? ? ? ? ? ? ? .build();
? ? ? ? HttpComponentsClientHttpRequestFactory customRequestFactory =new HttpComponentsClientHttpRequestFactory();
? ? ? ? customRequestFactory.setHttpClient(httpClient);
? ? ? ? return new RestTemplate(customRequestFactory);
? ? }
?

service层代码:

??此处因为是调用第三方https接口,并不是nacos注册中心的服务,所以不用@LoadBalanced注解

@Autowired
? ? @Qualifier(value = "restTemplateRemote")
? ? private RestTemplate restTemplate;

接口入参出参均为json格式数据

private String refreshToken(LoginVo vo){
? ? ? ? try {
? ? ? ? ? ? HttpHeaders httpHeaders = new HttpHeaders();
? ? ? ? ? ? httpHeaders.setContentType(MediaType.parseMediaType("application/json; charset=UTF-8"));
? ? ? ? ? ? httpHeaders.add("Accept", MediaType.APPLICATION_JSON.toString());
? ? ? ? ? ? HttpEntity<String> formEntity = new HttpEntity<String>(JSONObject.toJSONString(vo), httpHeaders);
? ? ? ? ? ? String post = restTemplate.postForObject("https://gateway.xxx.com/yao/user/login", formEntity, String.class);
? ? ? ? ? ? if (StringUtils.isNotBlank(post)) {
? ? ? ? ? ? ? ? JSONObject jsonObject = JSONObject.parseObject(post);
? ? ? ? ? ? ? ? if (jsonObject.getString("code").endsWith("200")) {
? ? ? ? ? ? ? ? ? ? JSONObject data = jsonObject.getJSONObject("data");
? ? ? ? ? ? ? ? ? ? String token = data.getString("token");
? ? ? ? ? ? ? ? ? ? return token;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? } catch (Exception e) {
? ? ? ? ? ? log.error("获取token异常:{}", e);
? ? ? ? ? ? throw new FundException("获取token异常:" + e.getMessage());
? ? ? ? }
? ? ? ? return null;
? ? }

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-11-23 12:43:57  更:2021-11-23 12:44:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 7:42:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码