springBoot+springSecurity+swagger2 Unable to infer base url. This is common when using dynamic

项目场景:

springBoot+springSecurity+swagger2, 访问http://localhost:8080/swagger-ui.html#/时出现:

在这里插入图片描述


问题原因:

在这里插入图片描述

上图时springSecurity的filterChain,可以在类FilterChainProxy中查看
在这里插入图片描述

http.antMatchers(whiteUrl).permitAll()起作用的拦截器时最后一个FilterSecurityInterceptor, 也就是说访问swagger的请求出现问题, 很可能是某个url被某个过滤器拦截了,尤其注意自定义的filter

解决方案:

如果是默认的过滤器FilterSecurityInterceptor拦截的:

在配置访问白名单的时候将swagger相关路径添加进去,

 String[] whiteUrl = new String[] {"/swagger-ui.html", "/swagger-resources/**",
			"/v2/api-docs", "/webjars/springfox-swagger-ui/**" };
 http.antMatchers(whiteUrl).permitAll()

注意下 /swagger-resources/**后面的*号;

关键代码在DefaultFilterInvocationSecurityMetadataSource
在这里插入图片描述

如果是自定义的Filter拦截的,注意配置拦截器的拦截条件。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值