在实际应用中,我们经常需要根据当前用户的操作权限来判断是否显示一新功能。如在论坛系统中,只有版主及管理才能删除贴子,因此在一般用户打开一个贴子的时候,就不需要出现“删除”这个连接。 权限系统标签接口的设计,在大多数应用中,以下接口中两个方法基本能满足大多数需求。 public interface AuthorizationUtil { /** * 根据名称判断用户角色,从而判断用户是否刻有该权限.roleName可以是单独的名称,大小写可以任意.可以包含空格等. * 若要使用多个角色,可以使用+、|、~、,等符号来表示组合关系 * 使用方法:#if($ROLE.is("ADMIN"))<a href="javascript:doDel()">删除</a>#end * 或:#if($ROLE.is("AMDIN,Manager"))<a href="">删除所有</a>#end * @param roleName * @return */ public boolean is(String roleName); /** * 判断一个用户是否对指定的对象有指定的操作权限 * @param operation 操作,"del","create","update","read"等 * 使用方法:#if($ROLE.is("del",$obj))<a href="">删除该记录</a>#end * @param obj 操作的对象 * @return 如果具有操作权限 */ public boolean is(String operation,Object obj); } 在昨晚修改EasyJWeb的时候,在框架处理器中增加了一个全局Util的Map。同时增加了一个跟EasyJF的权限控制系统结合的AuthorizationUtil实现。下面是主要代码: protected void createUtilContext(Context context) { Object authorizationUtil = FrameworkEngine.getContainer() .getBean(com.easyjf.util.AuthorizationUtil.class); if (authorizationUtil != null) { globalUtils.put("AUTH", authorizationUtil); globalUtils.put("ROLE", authorizationUtil); } } 这样,在基于Spring2+JPA+EasyJWeb的应用中,可以在模板页面中使用下面的Velocity角本来进行权限控制。如: #if($AUTH.is("ADMIN")) <a href='doDel();'>删除</a>#end 权限/角色的名称可以在系统运行的过程中自由设定。这样问题变得简单多了,不再需要访问底层的权限系统,也不在需要复杂的标签系统,就是调用这两个方法,而具这是在每一个展示的View中都开放的全局功能。 当然,也可以扩展一下模板标签系统,使用<Auth:role="ADMIN"><a href='doDel();'>删除</a></Auth>。当然我不喜欢后一种用法,因为总是会让页面人员把这个标签跟其它的标签搞混淆,而且也容易误删除,还是第一种方法看起直接,对于接受过我们半小时Velocity标签培训的页面制作及美工人员也应该会有同感。 当然,如何让权限控制变得更加灵活,View层的使用更加方便直接、简易,想听听大家的看法。
|