ThinkPHP框架3.1.3 BUG(麻烦修复)

浏览:1068 发布日期:2013/07/22 分类:站务建议 关键字: ThinkPHP框架3.1.3 BUG
小弟是框架的初学者,在看后盾网黄老师的PHP实战教程的时候,发现了一个3.1.3最新框架中的一个缺陷。
'SESSION_TYPE' => 'Db',
'SESSION_PREFIX' => 'sess_my' //SESSION表前缀
当我们自定义了 session 的表前缀后,
完整包里面RABC类的这个方法:
static function saveAccessList($authId=null) {
if(null===$authId) $authId = $_SESSION[C('USER_AUTH_KEY')];
// 如果使用普通权限模式,保存当前用户的访问权限列表
// 对管理员开发所有权限
if(C('USER_AUTH_TYPE') !=2 && !$_SESSION[C('ADMIN_AUTH_KEY')] )
$_SESSION['_ACCESS_LIST'] = RBAC::getAccessList($authId);
return ;
}

其中 判断超级管理员 的session读取用了PHP原本的方法,这样不行,如果我们自定义了 session数据前缀,那么就会多出一层,数组是嵌套的
Array
(
[sess_my] => Array
(
//用户数据
)

[_ACCESS_LIST] => Array
(
//权限数据
)
)
这样用 $_SESSION[C('USER_AUTH_KEY')] 就无法读取得到
需要修改成 session(C('USER_AUTH_KEY'))
下面读取超级管理员身份的原理一样,不然就无法通过了!
最后导致的结果就是:无法正确读取当前登录用户的权限,并且写入到session中

刚才我又看了一下,还有 AccessDecision 这个静态方法中,判断管理的那段代码:if(empty($_SESSION[C('ADMIN_AUTH_KEY')]))
判断 这个session是空,就不是管理员,也需要修改成if(!session(C('ADMIN_AUTH_KEY')))

$accessList = RBAC::getAccessList($_SESSION[C('USER_AUTH_KEY')]);
这句代码 应该修改成:
$accessList = RBAC::getAccessList(session(C('USER_AUTH_KEY')));

小弟菜鸟,才接触,如有错误,请指正!
最佳答案
评论( 相关
后面还有条评论,点击查看>>