浏览 8905 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-01-21
首先要解释的是Liferay的权限模型。首先看一下Liferay的定义 A permission is defined as an action acting on a resource 在Liferay中,权限作用是判断当前用户是否允许在Resource上进行某项操作(action)。 Resource代表着一个个的可操作的实体。在Portal系统中,最直观的Resource就是一个个的Portlet。但是由于应用的原因,在Portlet下还可以根据应用的功能再细分,最典型的就是Message Board Portlet下还分Category和Message两类Resource。这些Resource是很直观的。此外还存在一些特殊的Resource可以控制,比如每张Page也是Resource。另外由于在Liferay中可以配置多个Community,每个Community都可以多次放置同一种Portlet作为多个Instance的,所以对于Resource又附加了Scope的概念。Resource有三种Scope:Enterprise、Community和Individual。Enterprise代表整个Portal系统中的一类资源,Community需要指明是哪个Community下的一类资源,Individual则是独立的Resource。 举个例子,我们要定义一个Permission View+Message Board Topic / Enterprise 上面的定义说明,“查看当前Portal系统中任一个Message Board的Topic”。 再举个例子 Update Message Board Topic / "Developer" Community Scope 上面的定义说明,“修改 Developer 这个 Community 下的任一个 Message Board Topic ”。 在Liferay Portal中所有Portlet都会有默认的View/Configuration Action。其他的Resource和Action都需要开发人员预先设计,并在代码中调用PermissionChecker检验当前用户是否拥有权限。这是后话,今后在开发相关的文章中再讨论。 如果理解了上面关于Resource、Scope和Action,接下去我们就可以讨论Liferay中如何进行设置,将Permission和User联系起来从而将权限赋予某人。 首先说最简单的Individual类型的Resource的配置方法。如果以管理员身份登录系统,那么在任何一个portlet的右上角都有一个齿轮图标,点击该图标后选择Permissions标签就可进行该portlet得配置。 假设我们以管理员身份登录后切换到support Community,对Message Boards权限进行配置。 新出现的页面第一排中如果选择Users、Organizations、Locations、User Groups,下方还将出现Current和Available。 Current中是当前已经配置的结果,Available是可供选择的人员、机构的列表。 我们选择User->Available->Test HKG 1上打钩。点击Update Permissions。将所有权限都选择到Current下。配置后再查看Users->Current,现在Test HKG 1已经在Current下了。 使用test.hkg.1@liferay.com账户登录系统,可以看到Support下的Message Boards上出现了配置图标。而且有Add Category按钮。 然后看一下如何配置其他scope的权限。 首先以管理员身份登录系统,将Enterprise Admin添加到页面上。选择Roles,添加一个Role名称为SupportMBAdmin,选择Delegate。 在portlet列表中选择Message Boards,随后将Configuration后的Scope选择为Community,Next->Available->选择Support->Finish。随后使用SupportMBAdmin的assign,将Test HKG 2选中。 使用test.hkg.2@liferay.com账户登录系统,可以看到Support下的Message Boards上出现了配置图标。 hkg.1和hkg.2有什么区别呢? hkg.1获得的是Individual的Resource。只有这个Portlet是可以允许他配置的。 hkg.2获得的是support Community下任一个Message Boards的配置权限。 最后要说明的是,个人页面上的Portlet的Permission配置是没有意义的。因为其他人不能查看你的页面,也就无法配置了。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-01-21
值得学习
|
|
返回顶楼 | |
发表时间:2007-01-27
写得不错,不过liferay的权限更加强大,还有对model的权限配置,精确到单条记录
|
|
返回顶楼 | |
发表时间:2007-01-27
利用liferay对权限开发也比较容易,写法也很固定,大家可以试试
|
|
返回顶楼 | |