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

6 java rest spring spring-mvc spring-security

我在Spring 4下使用基本身份验证工作REST API.这些REST服务位于/ api/v1/**URL下.但是,我想在不同的url/api/v2/**下添加另一组REST端点,但使用基于令牌的身份验证进行保护.

是否可以使用一个servlet执行此操作?如何配置Spring Security以对不同的URL使用不同形式的身份验证?

谢谢.

Kre*_*sek 18

这是Java配置中的代码示例,它使用UserDetailsService不同的URL端点并具有不同的安全配置:

@Configuration
@EnableWebMvcSecurity
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Autowired
    UserDetailsService userDetailsService;

    @Autowired
    public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
        auth.userDetailsService(userDetailsService);
    }

    @Configuration
    @Order(1)
    public static class ApiWebSecurityConfig extends WebSecurityConfigurerAdapter{

        @Override
        protected void configure(HttpSecurity http) throws Exception {
            http
                    .antMatcher("/api/v1/**")
                    .httpBasic()
                        .realmName("API")
                        .and()
                    .csrf().disable()
                    .authorizeRequests()
                    .antMatchers("/api/v1/**").authenticated();
        }
    }

    @Configuration
    @Order(2)
    public static class ApiTokenSecurityConfig extends WebSecurityConfigurerAdapter{

        @Override
        protected void configure(HttpSecurity http) throws Exception {
            http
                    .antMatcher("/api/v2/**")
                    /* other config options go here... */
        }

    }
}
Run Code Online (Sandbox Code Playgroud)

  • 如果我想为每个端点使用不同的 userDetailsS​​ervice 该怎么办? (4认同)
  • 我的用例几乎没有什么不同。是否可以将`/ api / **`配置为使用基本身份验证,其余应用程序配置为使用表单登录? (2认同)
  • 是。在API安全性配置的第一行中使用`http.antMatcher(“ / api / **”)),在配置中使用`http.requestMatcher(new NegatedRequestMatcher(new AntPathRequestMatcher(“ / api / **”)))`其余的应用程序。 (2认同)