当前位置: 首页 > 知识库问答 >
问题:

Spring security antMatcher不工作

柳羽
2023-03-14

编辑:

我进一步深入研究了这个问题,发现即使使用单一配置,问题仍然存在。如果我使用单一配置并保持

http.antMatcher("/api/test/**")

网址不安全。删除antMatcher和antMatcher会立即保护网址。也就是说,如果我使用:

http.httpBasic()
    .and()
    .authorizeRequests()
    .anyRequest()
    .authenticated();

那么,只有Spring Security性可以保护url。为什么antMatcher不能正常工作?

(更新了标题以包含实际发行。)

原文:

我提出了以下问题:

>

  • Spring REST安全性-以不同的方式保护不同的URL

    使用具有不同身份验证提供程序的多个WebSecurityConfigrerAdapter(API的基本身份验证和Web应用程序的LDAP)

    和Spring Security文档:

    https://docs.spring.io/spring-security/site/docs/current/reference/htmlsingle/#multiple-httpsecurity

    但我无法配置多个http安全元素。当我遵循官方的spring文档时,它在我的情况下是有效的,因为第二个http安全元素是一个全面的,但只要我添加一个特定的url,所有的url都可以在没有任何身份验证的情况下访问。

    这是我的代码:

    @EnableWebSecurity
    @Configuration
    public class SecurityConfig {
    
        @Bean                                                             
        public UserDetailsService userDetailsService() throws Exception {
            InMemoryUserDetailsManager manager = new InMemoryUserDetailsManager();
            manager.createUser(User.withUsername("user").password("userPass").roles("USER").build());
            manager.createUser(User.withUsername("admin").password("adminPass").roles("ADMIN").build());
            return manager;
        }
    
    
        @Configuration
        @Order(1)                                                        
        public static class ApiWebSecurityConfigurationAdapter extends WebSecurityConfigurerAdapter {
    
            @Override       
            public void configure(AuthenticationManagerBuilder auth) 
              throws Exception {            
                auth.inMemoryAuthentication().withUser("user").password("user").roles("USER");
                auth.inMemoryAuthentication().withUser("admin").password("admin").roles("ADMIN");
            }
    
            protected void configure(HttpSecurity http) throws Exception {
                http
                    .antMatcher("/api/v1/**")                               
                    .authorizeRequests()
                    .antMatchers("/api/v1/**").authenticated()
                        .and()
                    .httpBasic();
            }
        }
    
        @Configuration
        @Order(2)
        public static class FormLoginWebSecurityConfigurerAdapter extends WebSecurityConfigurerAdapter {
    
            @Override       
            public void configure(AuthenticationManagerBuilder auth) 
              throws Exception {
    
                auth.inMemoryAuthentication().withUser("user1").password("user").roles("USER");
                auth.inMemoryAuthentication().withUser("admin1").password("admin").roles("ADMIN");
            }
    
            @Override
            protected void configure(HttpSecurity http) throws Exception {
                http
                    .antMatcher("/api/test/**")
                    .authorizeRequests()
                    .antMatchers("/api/test/**").authenticated()
                        .and()
                    .formLogin();
            }
        }
    }
    

    现在可以访问任何url。如果我从第二个配置中删除antMatcher,所有的URL都会变得安全。

  • 共有1个答案

    蒋高扬
    2023-03-14

    模式不能包含上下文路径,请参见AntPathRequest estMatcher

    Matcher,它将预定义的ant样式模式与HttpServletRequest的URL(servletPathpathInfo)进行比较。

    HttpServletRequest.html#getServletPath

    返回此请求的URL中调用servlet的部分。该路径以“/”字符开头,包括servlet名称或servlet路径,但不包括任何额外的路径信息或查询字符串。与CGI变量SCRIPT_NAME的值相同。

    HttpServletRequest.html#getContextPath

    返回请求URI中指示请求上下文的部分。在请求URI中,上下文路径总是排在第一位。路径以“/”字符开头,但不以“/”字符结尾。对于默认(根)上下文中的servlet,此方法返回“”。容器不解码此字符串。

    您修改和简化的代码:

        @Override
        protected void configure(HttpSecurity http) throws Exception {
            http
                .antMatcher("/test/**")
                .authorizeRequests()
                    .anyRequest().authenticated()
                    .and()
                .formLogin();
        }
    
     类似资料:
    • 我想在菜单栏文本被选中时更改它的颜色。 这里可能出了什么问题? 我尝试使用伪类':active',但没有得到应用。其中as':Hover'正在工作。 我还尝试使用'Router LinkActive',它应该添加类'Active-Link',但这也不起作用。 我在下面给出了HTML、SCCS和TS代码:

    • 我编写了一组简单的类,向一位朋友演示如何为AOP(而不是xml配置)使用注释。我们无法使@ComponentScan工作,并且AnnotationConfigApplicationContext getBean的行为也不正常。我想明白两件事。请参阅下面的代码: PersonOperationSI.java PersonOperations.java PersonOperationsConfigCl

    • 我正在Eclipse Neon中使用Hibernate工具(JBoss tools 4.4.0.Final)。现在,我想将数据库表反向工程为POJO对象和Hibernate映射文件。 我遵循了一些关于如何设置Eclipse来生成POJO对象的教程。在我运行配置之前,一切看起来都很好。什么都没发生,也没有抛出错误。有人能帮我吗?数据库是一个微软SQL服务器2014。 我的逆向工程配置文件看起来像:

    • 我正在尝试使用codeigniter insert\u batch将多行插入到我的数据库表中。根据错误报告,似乎没有设置表列。只是阵列的数量: 我的看法是: 我的控制器: 和型号:

    • 我尝试使用StreamWriter.WriteLine(不是静态地)将几行代码一次写到。txt文件中。 每个播放器对象都是字符串cosnatants。如果我使用不同的文件名(也称为BasicTestInfo2.txt),它会在bin.debug中创建该文件,但它是空的。我知道我到达了using块的内部(我在里面放了一个console.writeline),我知道我想要截断,这就是为什么我对appe

    • 我正在尝试使用yii2邮件组件发送电子邮件。 配置web。php 还有我的代码。 我收到了这个错误。 Swift\u TransportException预期响应代码为250,但收到代码“535”,消息“535-5.7.8用户名和密码不被接受。有关详细信息,请访问535 5.7.8https://support.google.com/mail/?p=BadCredentialsa13-v6sm41

    • 问题内容: 似乎不起作用,但确实起作用。有什么想法吗? 问题答案: 您不能在Java中将基本类型用作通用参数。改为使用: 使用自动装箱/拆箱,代码几乎没有区别。自动装箱意味着您可以编写: 代替: 自动装箱意味着将第一个版本隐式转换为第二个版本。自动拆箱意味着您可以编写: 代替: 如果未找到键,则隐式调用意味着将生成一个,例如: 原因是类型擦除。例如,与C#不同,泛型类型不会在运行时保留。它们只是显