FeignClient发送https请求时的证书验证原理分析

背景

微服务之间存在调用关系,且部署为 SSL 协议时,Feignt 请求报异常:

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

这个异常是怎么产生的,解决办法是什么呢?利用 DeepSeek 回忆一下这个问题。输入问题:

FeignClient发送 https 请求时的 SSL 验证原理是什么呢

FeignClient在发送HTTPS请求时,其SSL验证原理主要涉及SSL/TLS协议的握手过程、证书验证机制以及如何处理自定义的SSL配置,以下是详细的原理说明。

1. SSL/TLS握手过程

当FeignClient发起HTTPS请求时,首先会与目标服务器进行SSL/TLS握手。握手过程包括以下几个步骤:

  • 客户端发送支持的加密套件和压缩方法:客户端向服务器发送它支持的加密算法(如TLSv1.2)和压缩方法。
  • 服务器响应并选择加密套件:服务器选择一个加密套件并发送自己的数字证书。
  • 证书验证:客户端验证服务器的证书是否由受信任的证书颁发机构(CA)签发。如果证书有效,则继续握手。
  • 生成共享密钥:客户端生成一个随机数(premaster secret),并使用服务器的公钥加密后发送给服务器。
  • 服务器解密并生成会话密钥:服务器使用自己的私钥解密premaster secret,并生成会话密钥,用于后续的加密通信。
  • 加密通信:客户端和服务器使用会话密钥对数据进行加密和解密,确保数据传输的安全性。

2. 证书验证机制

在SSL/TLS握手过程中,证书验证是确保通信双方身份真实性的关键步骤。FeignClient在发送HTTPS请求时,会根据配置的SSL上下文(SSLContext)和信任管理器(X509TrustManager)来验证服务器的证书。

  • 默认验证:如果未配置自定义的SSL上下文,FeignClient会使用系统默认的SSL上下文,该上下文信任由Java自带的CA签发的证书。如果目标服务器的证书是自签名的或由不受信任的CA签发的,验证会失败,导致连接中断。
  • 自定义验证:通过配置自定义的SSL上下文和信任管理器,可以指定信任的证书或忽略证书验证。例如,使用X509TrustManager信任所有证书,或者通过NoopHostnameVerifier忽略主机名验证。

3. FeignClient的SSL配置

在Spring Cloud项目中,FeignClient的SSL配置通常通过以下方式实现:

  • 使用@FeignClient注解:在Feign客户端接口中指定URL为HTTPS地址,例如:
  @FeignClient(name = "cloud-paltform", url = "https://xxx:9999")
  • 配置SSL上下文:通过自定义的Client配置类,设置SSL上下文和信任管理器。例如:
  @Configurationpublic class FeignHttpsConfig {@Beanpublic Client feignClient() {return new Client.Default(getSSLSocketFactory(), new NoopHostnameVerifier());}private SSLSocketFactory getSSLSocketFactory() throws Exception {SSLContext sslContext = SSLContext.getInstance("TLSv1.2");X509TrustManager tm = new X509TrustManager() {@Overridepublic void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {// 忽略客户端证书验证}@Overridepublic void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {// 忽略服务器证书验证}@Overridepublic X509Certificate[] getAcceptedIssuers() {return new X509Certificate[0];}};sslContext.init(null, new TrustManager[]{tm}, new SecureRandom());return sslContext.getSocketFactory();}}

通过上述配置,FeignClient在发送HTTPS请求时会忽略SSL证书验证,从而绕过证书信任问题。

  • Spring Boot配置:在application.ymlapplication.properties中配置SSL相关参数,例如:
  feign:httpclient:disable-ssl-validation: true

4. 绕过SSL验证的注意事项

虽然绕过SSL验证可以解决证书信任问题,但需要注意以下几点:

  • 安全性风险:忽略SSL验证会导致中间人攻击(MITM)的风险,攻击者可以拦截和修改通信内容,因此仅在测试环境中使用。
  • 证书管理:如果使用自签名证书,需要将其添加到信任库中,否则客户端无法验证证书的有效性。
  • 依赖管理:确保项目中引入了正确的依赖,例如feign-httpclient,以便使用HttpClient的SSL配置。

5. 总结

FeignClient在发送HTTPS请求时,通过SSL/TLS协议进行加密通信,并通过证书验证确保服务器身份的真实性。

默认情况下,FeignClient会使用系统默认的SSL上下文,但可以通过自定义配置绕过SSL验证。

在实际应用中,建议使用受信任的CA签发的证书,并正确配置SSL上下文以确保通信的安全性。

解决办法:

  1. 通过配置 feign.httpclient.disable-ssl-validation: true 禁用 SSL 校验 。测试了,不生效。需要跟源码看看具体生效配置是什么。
  2. 基于 spring-cloud-loadbalancer 的 Feign 客户端配置禁用 SSL 校验

结论:最好还是应该通过配置来控制,方法二需要添加一个条件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/news/907243.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

性能优化关键:link、script和meta的正确打开方式

link 标签的主要属性及其作用 属性是否必填作用描述示例值rel是定义当前文档与链接资源的关系(必须属性)。常见值:stylesheet, icon, preload, preconnect 等。rel"stylesheet" rel"icon"href是指定链接资源的URL。href…

Linux `less` 命令深度解析与高阶应用指南

Linux `less` 命令深度解析与高阶应用指南 一、核心功能解析1. 基本作用2. 与类似工具对比二、选项系统详解1. 常用基础选项2. 高阶选项组合三、高阶应用场景1. 日志分析系统2. 代码审查系统3. 数据管道处理四、特殊文件处理1. 大文件优化查看2. 二进制文件分析五、交互式命令大…

影刀RPA-20-高级操作题2

一、题目 二、链接 方法一:影刀应用分享: 高级考试题2-第二次 方法二:影刀应用分享: 高级考试题2 三、代码 方法一: import xbot from xbot import print, sleep from .import package from .package import variables as glv from xbot…

C# NX二次开发-获取面法向和UV等数据

通过ufun函数UF_MODL_ask_face_props可以获取到面的法向数据和UV和半径等数据。 代码如下: double[] uvs new double[4];double[] param new double[2];double[] point new double[3];double[] u1 new double[3];double[] v1 new double[3];double[] u2 new d…

SpringBoot整合Sa-Token:实现RBAC权限模型

Java系列文章 文章目录 Java系列文章前言一、基础概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 环境准备 二、表结构设计2.1 ER图示例2.2 数据库表设计2.2.1 用户表2.2.2 角色表2.2.3 部门表2.2.4 权限表 三、SpringBoot整合Sa-Token3.1 sa-token基础配置3.1.1 Maven配置3…

工商业储能的“智慧大脑”:解密 Acrel-2000ES EMS 的核心功能与价值

安科瑞电气顾强 市场背景:工商业储能加速崛起 2022年中国已并网的储能项目中,用户侧并网占比为8.36%,其中工商业储能占据了用户侧高达98.6%的份额。驱动这一市场发展的关键因素日益显著: 1.峰谷价差扩大: 全国各省市…

vue+threeJs 根据屏幕调整gltf模型的大小、重心、并更换骑车整体颜色

嗨,我是小路。今天主要和大家分享的主题是“vuethreeJs 根据屏幕调整gltf模型的大小、重心、并更换骑车整体颜色”。 项目案例示意图 1.整体更换gltf模型的颜色 定义:整体代码如下。颜色是事先设定的 const colorAry reactive(["rgb(21…

03 基于 java udp 做一个dns服务器 和 一个dns代理服务器

前言 这个也是 来自于一个朋友的需求 最终的目的是实现一个 dns 代理服务器, 当然 这本质也是一个 dns 服务器 并且 dns 代理服务器是依赖于 一个 dns 服务器的, 因此 顺便给一个 dns 服务器的 demo 这里 主要是 基于 udp 的一个 dns 请求, 响应数据的交互 dns 服务器 …

【HITCSAPP 哈工大计算机系统期末大作业】 程序人生-Hello’s P2P

计算机系统 大作业 题 目 程序人生-Hello’s P2P 专 业 计算机与电子通信类 学   号 2023112915 班   级 23L0505 学 生 杨昕彦 指 导 教 师 刘宏伟 计算机科学…

第十周作业

一、CSRF 1、DVWA-High等级 2、使用Burp生成CSRF利用POC并实现攻击 二、SSRF:file_get_content实验,要求获取ssrf.php的源码 三、RCE 1、 ThinkPHP 2、 Weblogic 3、Shiro

PTA刷题笔记(难度预警!!!有详解)

7-18 二分法求多项式单根 代码如下&#xff1a; ​ #include <stdio.h> #include <math.h>// 定义多项式函数 double polynomial(double x, double a3, double a2, double a1, double a0) {return a3 * x * x * x a2 * x * x a1 * x a0; }// 二分法求根函数 do…

打破传统范式,线上 3D 画展彰显多元亮点

&#xff08;一&#xff09;沉浸式体验&#xff0c;身临其境赏画​ 线上 3D 画展运用先进的 3D 建模和虚拟现实&#xff08;VR&#xff09;技术&#xff0c;高度还原了真实的展厅环境 。展厅内的布局、灯光&#xff0c;甚至墙壁的质感都被完美复刻&#xff0c;让观众仿佛置身于…

Docker架构详解

一,Docker的四大要素&#xff1a;Dockerfile、镜像(image)、容器(container)、仓库(repository) 1.dockerfile&#xff1a;在dockerfile文件中写构建docker的命令,通过dockerbuild构建image 2.镜像&#xff1a;就是一个只读的模板&#xff0c;镜像可以用来创建docker容器&…

【工具类】常用的工具类——CollectionUtil

目录 cn.hutool.core.collection.CollectionUtil集合创建集合清空集合判空集合去重集合过滤集合转换集合合并集合交集集合差集集合是否包含元素集合是否包含指定元素&#xff08;自定义条件&#xff09;集合分页集合分组集合转字符串元素添加元素删除根据属性转Map获取元素获取…

从零起步搭建基于华为云构建碳排放设备管理系统的产品设计

目录 &#x1f33f; 华为云 IoT&#xff1a;轻松上手碳排放设备管理系统搭建 &#x1f30d; 逐步搭建搭建规划 &#x1f680; 一、系统蓝图&#xff1a;5大核心模块&#xff0c;循序渐进 1️⃣ 设备管理与数据采集层 2️⃣ 数据传输与协议转换层 3️⃣ 数据处理与分析层…

华为OD机试真题—— 小明减肥(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现

2025 B卷 100分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…

数据结构 -- 插入排序(直接插入排序和希尔排序)

插入排序 算法思想 每次将⼀个待排序的记录按其关键字大小插入到前面已排好序的子序列中&#xff0c;直到全部记录插入完成。 代码实现 void InsertSort(int A[],int n){int i,j,temp;for(i 1;i<n;i){if(A[i]<A[i-1]){temp A[i]; //用temp暂存A[i]for(ji-1;j>…

word中表格拉不动以及插入图片有间距

word中的表格宽度和高度怎么调整都改不了&#xff0c;可以将选中表格—右键—段落—取消勾选下图中的两项。 word中表格插入图片始终有间隙&#xff0c;怎么也消除不了间隙&#xff0c;可以在表布局—单元格边距—修改上下左右边距为0即可

网络抓包命令tcpdump及分析工具wireshark使用

文章目录 环境文档用途详细信息 环境 系统平台&#xff1a;Linux x86-64 Red Hat Enterprise Linux 8,Linux x86-64 Red Hat Enterprise Linux 7,Linux x86-64 SLES 12,银河麒麟 &#xff08;鲲鹏&#xff09;,银河麒麟 &#xff08;X86_64&#xff09;,银河麒麟&#xff08;龙…

Eigen矩阵存储顺序以及转换

一、Eigen矩阵存储顺序 在矩阵运算和线性代数中,"行优先"(Row-major)和"列优先"(Column-major)是两种不同的存储方式,它们决定了多维数组(如矩阵)在内存中的布局顺序。 1. 行优先(Row-major) 定义:矩阵按行顺序存储在内存中,即第一行的所有元…