关于 spring security 配置问题
想实现只对 /actuator/** 路径会进行鉴权,并且在源 ip 为内网的时候放行,否则需要通过 HTTP basic 认证
目前的配置可以实现内网放行,代码如下:
http.antMatcher("/actuator/**")
.authorizeRequests()
.anyRequest()
.access("hasIpAddress('::1')" +
" or hasIpAddress('127.0.0.1')" +
" or hasIpAddress('10.0.0.0/8')" +
" or hasIpAddress('172.16.0.0/12')" +
" or hasIpAddress('192.168.0.0/16')")
.and()
.httpBasic();
但是这样的话会导致配置文件中定义的用户名和密码失效:
spring.security.user.name=admin
spring.security.user.password=123456
之前不做 ip 白名单的时候配置的用户密码可以生效的:
http.antMatcher("/actuator/**").authorizeRequests()
.anyRequest().authenticated()
.and()
.httpBasic();
大佬们帮忙看看应该怎么配置,或者有没有什么最简单的办法能做自定义的权限校验。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
把路径设置未匿名可访问,在匿名过滤器后面添加一个类似于匿名过滤器,在其中校验路径,如果符合 检查 ip,如果符合,不做什么,如果不符合,就把 匿名用户删除 。`
`
具体可以参照
`
`AnonymousAuthenticationFilter