我有一个 spring 安全配置方法。我希望仅当条件匹配时才链接特定方法 antMatchers("/**/**").permitAll()
。像这样的 {dev == true ? .antMatchers("/**/**").permitAll(): ()->{}}
。当然这不是一个有效的语法,最简洁的实现方式是什么。寻找最低编码。
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.csrf().disable()
.cors().disable()
.authorizeRequests()
{dev == true ? .antMatchers("/**/**").permitAll(): ()->{}} //dev only. NEVER enable on prod
.antMatchers("/", "/signup", "/static/**", "/api/sigin", "/api/signup", "**/favicon.ico").permitAll()
.anyRequest().authenticated()
.and()
.formLogin()
.loginPage("/")
.loginProcessingUrl("/api/signin")
.successHandler(authSuccessHandler())
.failureHandler(authFailureHandler())
.permitAll()
.and()
.logout()
.permitAll();
}
最佳答案
唯一的方法是将中间对象分配给一个变量。
WhateverAuthorizeRequestsReturns partial = http
.csrf().disable()
.cors().disable()
.authorizeRequests();
if (dev) // note: you don't need 'dev == true' like you had
{
partial.someOptionalThing();
// if the type is immutable then you need to reassign e.g.:
// partial = partial.someOptionalThing()
}
partial.something()
.somethingElse()
.andTheRest();
关于java - 如何在 Java 8 中进行条件方法链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54152360/