java evaluator 需要引用哪个类_java – 为什么我的自定义PermissionEvaluator没有被调用?...

我正在努力使用我的

Spring Security配置,到目前为止我无法使其工作.

我不知道为什么我的自定义PermissionEvaluator没有被调用,我的@PreAuthorize注释使用hasPermission表达式被忽略.

我正在使用Spring 4.2.4和Spring security 4.1.0

她是我的代码:

网络安全配置

@Configuration

@EnableWebSecurity

public class MyWebSecurityConfig extends WebSecurityConfigurerAdapter {

@Override

protected void configure(HttpSecurity http) throws Exception {

http //

.addFilterBefore(wafflePreAuthFilter(), AbstractPreAuthenticatedProcessingFilter.class) //

.authenticationProvider(preauthAuthProvider()) //

.csrf().disable() //

.authorizeRequests() //

.antMatchers("/ui/**").authenticated() //

.anyRequest().permitAll();

}

@Bean

public WafflePreAuthFilter wafflePreAuthFilter() throws Exception {

WafflePreAuthFilter filter = new WafflePreAuthFilter();

filter.setAuthenticationManager(authenticationManager());

return filter;

}

@Bean

public PreAuthenticatedAuthenticationProvider preauthAuthProvider() {

PreAuthenticatedAuthenticationProvider preauthAuthProvider = new PreAuthenticatedAuthenticationProvider();

preauthAuthProvider.setPreAuthenticatedUserDetailsService(userDetailsServiceWrapper());

return preauthAuthProvider;

}

@Bean

public UserDetailsByNameServiceWrapper userDetailsServiceWrapper() {

UserDetailsByNameServiceWrapper wrapper = new UserDetailsByNameServiceWrapper();

wrapper.setUserDetailsService(myUserDetailsService());

return wrapper;

}

@Bean

public UserDetailsService myUserDetailsService() {

return new myUserDetailsService();

}

}

方法安全配置

@Configuration

@EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true, proxyTargetClass = true)

public class MyServiceMethodSecurityConfig extends GlobalMethodSecurityConfiguration {

@Bean

public PermissionEvaluator myPermissionEvaluator() {

return new DcePermissionEvaluator();

}

@Override

public MethodSecurityExpressionHandler createExpressionHandler() {

DefaultMethodSecurityExpressionHandler expressionHandler = new DefaultMethodSecurityExpressionHandler();

expressionHandler.setPermissionEvaluator(myPermissionEvaluator());

return expressionHandler;

}

}

PermissionEvaluator

public class MyPermissionEvaluator implements PermissionEvaluator {

@Autowired

private MyService myAutowiredService;

@Override

public boolean hasPermission(Authentication authentication, Object targetDomainObject, Object permission) {

// checking permissions

return true;

}

@Override

public boolean hasPermission(Authentication authentication, Serializable targetId, String targetType, Object permission) {

// checking permissions

return true;

}

}

任何人都可以给我一个暗示该做什么的提示?

顺便说一句,如果我将MyServiceMethodSecurityConfig更改为this,则会处理myPermissionEvaluator,但依赖注入不起作用,因为它不受Spring管理:

@Configuration

@EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true, proxyTargetClass = false)

public class MyServiceMethodSecurityConfig extends GlobalMethodSecurityConfiguration {

@Override

public MethodSecurityExpressionHandler createExpressionHandler() {

DefaultMethodSecurityExpressionHandler expressionHandler = new DefaultMethodSecurityExpressionHandler();

expressionHandler.setPermissionEvaluator(new DcePermissionEvaluator());

return expressionHandler;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值