ForumPermission这个东东看起来虽然不足道,类的设计也比较简单,可你不要小看它哦,因为它一直贯穿于整个系统的始终。几乎所有的操作都要与这个类打交道,这也是作者的过人之处,它非常灵活的把类的具体实现与它的权限管控分离了出来,也就是所谓的Proxy的模式。 在ForumPermission中,一共定义了8种不同的权限模式,它们分别是:READ = 0; SYSTEM_ADMIN = 1; FORUM_ADMIN = 2;USER_ADMIN = 3; GROUP_ADMIN = 4;MODERATOR = 5;CREATE_THREAD = 6;CREATE_MESSAGE = 7; ////////////////////////////////////////////////////////////////////////////////////////////////////////////// public static ForumPermissions full() { 定义一个具有全部权限的类型 return new ForumPermissions(true, true, true, true, true, true, true, true); }
public static ForumPermissions none() { 定义一个“空权” return new ForumPermissions(false, false, false, false, false, false, false, false); }
public static ForumPermissions readOnly() { 定义一个“只读权” return new ForumPermissions(true, false, false, false, false, false, false, false); }
public ForumPermissions(boolean READ, boolean SYSTEM_ADMIN, 构造函数 boolean FORUM_ADMIN, boolean USER_ADMIN, boolean GROUP_ADMIN, boolean MODERATOR, boolean CREATE_THREAD, boolean CREATE_MESSAGE) { values[0] = READ; values[1] = SYSTEM_ADMIN; values[2] = FORUM_ADMIN; values[3] = USER_ADMIN; values[4] = GROUP_ADMIN; values[5] = MODERATOR; values[6] = CREATE_THREAD; values[7] = CREATE_MESSAGE; }
public ForumPermissions(ForumPermissions perm1, 合并两个权限亦是构造函数 ForumPermissions perm2) { values[0] = perm1.get(0) || perm2.get(0); values[1] = perm1.get(1) || perm2.get(1); values[2] = perm1.get(2) || perm2.get(2); values[3] = perm1.get(3) || perm2.get(3); values[4] = perm1.get(4) || perm2.get(4); values[5] = perm1.get(5) || perm2.get(5); values[6] = perm1.get(6) || perm2.get(6); values[7] = perm1.get(7) || perm2.get(7); }
public ForumPermissions(boolean [] permissions) { 亦是构造函数,与那么多的参数不同的是,传递一个布尔数组,其实一样也 this.values = permissions; }
public boolean get(int type) { 看看是不是有那方面的权限,比如说READ=0,如果get(READ)=true,那么就是有READ的权限 if (type < 0 || type > 7) { return false; } return values[type]; }
public boolean isSystemOrForumAdmin() { 判断是不是论坛管理员或者系统管理员 return (values[FORUM_ADMIN] || values[SYSTEM_ADMIN]); } 
|