如何在java中实现权限控制?

时间:2011-11-04 13:31:30

标签: java permissions spring-security

我们开发了一个应用程序,需要实现权限控制,这意味着有人只能搜索数据库中的特定记录:

  1. 员工只能搜索自己的记录。
  2. 主管可以搜索其下属的记录。
  3. 主管可以看到批准申请的“批准”按钮
  4. 而工作人员只能提交申请。
  5. 我知道spring安全性,但实际上我们如何使用spring security来实现上面的功能呢?

    我们可以用SQL实现权限控制,这意味着首先选择他的角色,然后选择他所有的下属记录:

    select * from table where staffid in (.......)   
    

    但这种方法看起来太原始,难以维护。所以我的问题是:我们可以使用任何框架和实践来实现一个体面的权限控制机制吗?如何在应用程序中实现权限控制?

4 个答案:

答案 0 :(得分:2)

1)员工只能搜索自己的记录。 2)主管可以搜索其下属的记录。

这些似乎是您必须在DAO层实施的规则

3)主管可以看到批准申请的“批准”按钮

- 这可以通过JSF中基于UI角色的渲染来实现

4)工作人员只能提交申请。

Spring安全方法拦截器可以在这里使用:http://static.springsource.org/spring-security/site/docs/3.0.x/reference/secure-object-impls.html

答案 1 :(得分:0)

使用postgres数据库, 您可以从表继承表。即:

CREATE TABLE access{
  admin bool default false,
  supervisor bool default false,
  staff_user_id bigint default null,
   ...
}
CREATE TABLE flower(
  flower_id serial,
  name varchar(24)
)inherits (access)

然后您可以创建更新/删除触发器,并区分连接用户。

这可能是一种解决方案。

答案 2 :(得分:0)

正如您所说,实体“角色”和“业务数据”必须在数据库中保持独立 - 您可以加入角色表并仅选择适当的数据,而不是多次调用数据库。

答案 3 :(得分:0)

如果您尚未确定它太复杂,您应该查看Spring Security ACLs