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

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 验证开启。

相关文章:

  • 王树森推荐系统公开课 排序06:粗排模型
  • SAP销售订单批导创建
  • LVS +Keepalived高可用群集
  • 国芯思辰| 国产四通道24位生理电采集模拟前端AFE全面替换ADS1294R,心电贴性能再飞跃
  • 【博客系统】博客系统第十一弹:部署博客系统项目到 Linux 系统
  • 前端 jQuery 简单实现一个网页格斗游戏示例
  • SQL Server 中创建链接服务器
  • python h5py 读取mat文件的<HDF5 object reference> 问题
  • TensorFlow Extended (TFX) 生产环境模型版本控制与回滚实战指南
  • 【请关注】关于VC++实现使用Redis不同方法,有效达到 Redis 性能优化、防击穿
  • Java八股-Java优缺点,跨平台,jdk、jre、jvm关系,解释和编译
  • [Vue2]判断引用组件是否注册了 $emit 对应的事件
  • 《Pytorch深度学习实践》ch1-线性模型
  • AI问答-Vue3+TS:reactive创建一个响应式数组,用一个新的数组对象来替换它,同时保持响应性
  • 003 flutter初始文件讲解(2)
  • Python训练营---Day39
  • Shortest path 代码
  • 【深度学习:进阶篇】--2.3.深度学习正则化
  • Magentic-UI:人机协作的网页自动化革命
  • 亡羊补牢与持续改进 - SRE 的安全日志、审计与事件响应
  • wordpress工具栏条/最好的关键词排名优化软件
  • 应用商店app下载安装最新版软件/无锡网站建设方案优化
  • 网站怎么制作 推广/灰色关键词排名技术
  • 百度公司可以做网站么/东莞网站推广哪里找
  • 阿里云 网站根目录/百度站长平台官网登录入口
  • 有多少专门做兼职的网站/百度经验官网登录