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

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.lryc.cn/news/2397330.html

相关文章:

  • DeepSeek 赋能自动驾驶仿真测试:解锁高效精准新范式
  • 晨控CK-UR12与西门子PLC配置Modbus TCP通讯连接操作手册
  • 实验一:PyTorch基本操作实验
  • 可视化大屏通用模板Axure原型设计案例
  • 通配符(Wildcard)与正则表达式(Regular Expression)的关系及区别
  • 历年山东大学计算机保研上机真题
  • Java处理动态的属性:字段不固定、需要动态扩展的 JSON 数据结构
  • MAC电脑怎么通过触摸屏打开右键
  • 用 Whisper 打破沉默:AI 语音技术如何重塑无障碍沟通方式?
  • 【东枫科技】KrakenSDR 天线阵列设置
  • Spring Boot中的事件与JMS消息集成
  • ubuntu/windows系统下如何让.desktop/.exe文件 在开机的时候自动运行
  • 云计算数据治理
  • 【Net】TCP粘包与半包
  • 【Android】如何抓取 Android 设备的 UDP/TCP 数据包?
  • 深度解析 Nginx 配置:从性能优化到 HTTPS 安全实践
  • 触发器与存储过程详解
  • 游戏盾与高防CDN的协同防御策略分析
  • Scratch节日 | 六一儿童节射击游戏
  • GPU层次结构(Nvidia和Apple M芯片,从硬件到pytorch)
  • 一次借助ChatGPT抵御恶意攻击的经历,为个人服务器添加自动防御系统Fail2ban
  • (九)深度学习---自然语言处理基础
  • 【Java Web】速通Tomcat
  • Docker快速部署数据同步工具DataX-Web
  • 从零开始的云计算生活——第十四天,困难重重,安全管理。
  • 迁移学习模型构建指南(Python实现)
  • 【设计模式-4.6】行为型——状态模式
  • 【LeetCode 热题100】动态规划实战:打家劫舍、完全平方数与零钱兑换(LeetCode 198 / 279 / 322)(Go语言版)
  • 换ip是换网络的意思吗?怎么换ip地址
  • 【软件】在 macOS 上安装 MySQL