java - Spring REST security - 以不同方式保护不同的 URL

标签 java spring rest spring-mvc spring-security

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

是否可以用一个 servlet 做到这一点?如何配置 Spring Security 以对不同的 URL 使用不同形式的身份验证?

谢谢。

最佳答案

下面是 Java 配置中的代码示例,它使用 UserDetailsS​​ervice 并且针对不同的 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... */
        }

    }
}

关于java - Spring REST security - 以不同方式保护不同的 URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33037559/

相关文章:

java - Spring - 服务层方法通用与特定

用于测试的 HTTP Post Multipart 工具

java - 使用 Jersey 的 JAX RS 的内存问题

java - 在拨号器应用程序顶部检测来电并在后台打开服务

java - 无法从 JSF 读取 Java 文件

java - 如何在 Spring MVC 中将 JSON 有效负载发布到 @RequestParam

java - Camel 将 Java DSL 转换为 Spring DSL

java - 基于性能的 JAR 和 WAR 部署之间的区别

java - 为我的登录页面创建 session 并计算登录失败的次数

javascript - 如何在父作用域获取静态数据后在子作用域中运行函数