当前位置: 首页 > backend >正文

openfeignFeign 客户端禁用 SSL

要针对特定的 Feign 客户端禁用 SSL 验证,可以通过自定义配置类实现。以下是完整解决方案:

1. 创建自定义配置类(禁用 SSL 验证)

import feign.Client;
import feign.httpclient.ApacheHttpClient;
import org.apache.http.conn.ssl.NoopHostnameVerifier;
import org.apache.http.conn.ssl.TrustSelfSignedStrategy;
import org.apache.http.ssl.SSLContexts;
import org.springframework.context.annotation.Bean;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;public class DisableSslConfig {@Beanpublic Client feignClient() throws Exception {// 创建信任所有证书的SSL上下文SSLContext sslContext = SSLContexts.custom().loadTrustMaterial(null, new TrustSelfSignedStrategy()).build();// 创建自定义Socket工厂SSLSocketFactory socketFactory = sslContext.getSocketFactory();// 构建禁用SSL验证的HttpClientreturn new ApacheHttpClient(org.apache.http.impl.client.HttpClients.custom().setSSLContext(sslContext).setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE).build());}
}

2. 应用到特定 Feign 客户端

@FeignClient 注解中引用自定义配置:

import org.springframework.cloud.openfeign.FeignClient;@FeignClient(name = "your-service",url = "https://your-service-url",configuration = DisableSslConfig.class // 应用自定义配置
)
public interface YourServiceClient {// 你的Feign接口方法@GetMapping("/endpoint")String getData();
}

3. 补充说明(重要)

安全警告

⚠️ 此配置会完全禁用 SSL 验证

  • 允许中间人攻击(MITM)
  • 暴露敏感数据风险
  • 仅限开发/测试环境使用
  • 生产环境必须使用有效证书
备选方案(推荐)

如果只是需要信任自签名证书,更安全的方式是将证书添加到信任库:

keytool -import -alias mycert -file server.crt -keystore truststore.jks

然后在 application.yml 配置:

server:ssl:trust-store: classpath:truststore.jkstrust-store-password: changeit

4. 全局禁用方式(不推荐)

如果确实需要全局禁用(所有 Feign 客户端),在 application.yml 添加:

feign:client:config:default: # 作用于所有客户端disable-ssl-validation: truehttpclient:disable-ssl-validation: true # 确保HTTP客户端生效

验证是否生效

在日志中添加检查:

@Bean
public Client feignClient() throws Exception {log.warn("⚠️ SSL验证已禁用 - 仅限测试环境使用!");// ... 同上 ...
}

关键点总结

方法作用范围推荐指数安全风险
自定义配置类单个客户端★★★★
信任库配置全局★★★★★
全局禁用SSL所有客户端★☆☆☆☆极高

最佳实践:优先使用信任库方案,仅在测试环境针对特定服务使用自定义配置类方案。生产环境务必保持 SSL 验证开启。

http://www.xdnf.cn/news/9816.html

相关文章:

  • 机顶盒CM311-5s纯手机免拆刷机,全网通,当贝桌面
  • 小表驱动大表更快吗,不是
  • RuoYi前后端分离框架集成手机短信验证码(一)之后端篇
  • 车载通信网络 --- 车载通信网络槪述
  • 计算机网络全维度解析:架构协议、关键设备、安全机制与新兴技术深度融合
  • Mysql中索引B+树、最左前缀匹配
  • LVS+KeepAlived
  • 【在线五子棋对战】一、项目简介 环境搭建
  • HTML实战:爱心图的实现
  • 本地Markdown开源知识库选型指南
  • 算法日记32:埃式筛、gcd和lcm、快速幂、乘法逆元
  • 基于esp32,控制IO1高低电平 和读取IO0按键的c程序
  • ByteBuddy入门:静态方法增强实战
  • 4.1.3 操作数据帧
  • 005 ElasticSearch 许可证过期问题
  • 深入剖析 Docker 容器化原理与实战应用,开启技术新征程!
  • VCS elab选项 -simprofile功能
  • 微软 Azure AI Foundry(国际版)十大重要更新
  • EXCEL中的TEXTJOIN用法(基础版),将Excel 多个单元格内容按条件合并到一个单元格
  • 【计算机网络】第2章:应用层—DNS
  • 详细说说Redis分布式锁和ZK分布式锁
  • 动手学深度学习pytorch学习笔记 —— 第四章(2)
  • 2023年6级第一套长篇阅读
  • Mybatis中的懒加载
  • 高密爆炸警钟长鸣:AI为化工安全戴上“智能护盾”
  • 基于MATLAB实现SFA(Slow Feature Analysis,慢特征分析)算法
  • Java八股-Java优缺点,跨平台,jdk、jre、jvm关系,解释和编译
  • Java 微服务架构设计:服务拆分与服务发现的策略
  • 信息学奥赛一本通 1551:维护序列
  • 为什么在我的Flask里面有两个路由,但是在网页里有一个却不能正确访问到智能体