关于 spring security 配置问题

发布于 2022-09-12 04:30:25 字数 965 浏览 20 评论 0

想实现只对 /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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

顾挽 2022-09-19 04:30:25

把路径设置未匿名可访问,在匿名过滤器后面添加一个类似于匿名过滤器,在其中校验路径,如果符合 检查 ip,如果符合,不做什么,如果不符合,就把 匿名用户删除 。`

private boolean isPath(ServletRequest req){
    // ...
    return false;
}

private boolean isNotMyIp(ServletRequest req){
    // ...
    return false;
}

public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
        throws IOException, ServletException {
    if(isPath(req) && isNotMyIp(req)){
        if (SecurityContextHolder.getContext().getAuthentication() != null) {
            SecurityContextHolder.getContext().setAuthentication(null);
        }
    }

    chain.doFilter(req, res);
}

`
具体可以参照``
AnonymousAuthenticationFilter

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文