首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Spring-Security验证方法参数

使用Spring-Security验证方法参数
EN

Stack Overflow用户
提问于 2013-07-04 22:26:54
回答 1查看 242关注 0票数 1

我使用的是Spring Security 3.1.4。

我有一个UsersManager类,如下所示:

代码语言:javascript
复制
public class UsersManager {

@Secured("ROLE_ADMIN")
public void update(User user){
    ....
            ....
}
}

public class User{
    Integer id;
    String name;
    Integer departmentId;

}

要求如下:用户只能更新其部门的用户。考虑到用户依赖于安全会话,有没有办法用Spring Security做到这一点?

EN

回答 1

Stack Overflow用户

发布于 2013-07-04 22:35:29

您需要扩展org.springframework.security.core.userdetails.User并添加departmentId属性。然后确保Spring Security使用此对象作为主体(提供您的UserDetailsService,在登录时设置departmentId )。然后您可以执行以下操作:

代码语言:javascript
复制
@PreAuthorize("hasRole('ROLE_ADMIN') and #principal.departmentId==#user.departmentId")
public void update(User user){
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17472782

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档