没有在上下文中注册的bean解析器来解析对bean的访问

Kau*_*hik 15 java spring spring-security spring-el

我正在尝试使用Java Config实现方法安全性,但我收到一个错误: -

org.springframework.expression.spel.SpelEvaluationException: EL1057E:(pos 1): No bean resolver registered in the context to resolve access to bean 'appPermissionEvaluator'
Run Code Online (Sandbox Code Playgroud)

方法是: -

@PreAuthorize("@appPermissionEvaluator.hasSystemPermission()")
public String something() {
    ...
}
Run Code Online (Sandbox Code Playgroud)

Config类定义是(MethodSecurityConfig.java): -

@Configuration
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class MethodSecurityConfig extends GlobalMethodSecurityConfiguration {

    @Bean
    public AppPermissionEvaluator appPermissionEvaluator() {
        return new AppPermissionEvaluator();
    }

    @Override
    protected MethodSecurityExpressionHandler createExpressionHandler() {
        DefaultMethodSecurityExpressionHandler expressionHandler =
                new DefaultMethodSecurityExpressionHandler();
        expressionHandler.setPermissionEvaluator(appPermissionEvaluator());
        return expressionHandler;
    }

    ...
}
Run Code Online (Sandbox Code Playgroud)

我检查了我能够在同一个类中自动装配bean,我发现默认的hasPermission()方法正在我已经实现它们,唯一的问题是从SpEL读取bean.我不确定是什么问题.任何指针?

我正在使用Spring 4.1.5和Spring security 3.2.7

Rob*_*nch 17

您需要确保在DefaultMethodSecurityExpresssionHandler上设置ApplicationContext.例如:

@Autowired
private ApplicationContext context;

@Override
protected MethodSecurityExpressionHandler expressionHandler() {
    DefaultMethodSecurityExpressionHandler expressionHandler =
            new DefaultMethodSecurityExpressionHandler();
    expressionHandler.setPermissionEvaluator(appPermissionEvaluator());
    expressionHandler.setApplicationContext(context);
    return expressionHandler;
}
Run Code Online (Sandbox Code Playgroud)

或者更简洁,如果您将一个PermissionEvaluator定义为Bean,Spring Security将自动选择它(不需要覆盖expressionHandler()).例如:

@Bean
public PermissionEvaluator appPermissionEvaluator() {
    ...
}
Run Code Online (Sandbox Code Playgroud)