我在学ThinkPHP里的RBAC的时候, [_ACCESS_LIST] 总是空的,高手给看一下
Array([verify]=>a87ff679a2f3e71d9181a67b7542122c[uid]=>7[username]=>lisi[logintim]=>2...
Array
(
[verify] => a87ff679a2f3e71d9181a67b7542122c
[uid] => 7
[username] => lisi
[logintim] => 2014-04-07 20:03
[loginip] => 127.0.0.1
[_ACCESS_LIST] => Array
(
)
)
我的配置项
'RBAC_SUPERADMIN' => 'admin',
'ADMIN_AUTH_KEY' => 'superadmin',
'USER_AUTH_ON' => true,
'USER_AUTH_TYPE' => 1,
'USER_AUTH_KEY' => 'uid',
'NOT_AUTH_ACTION' => '',
'NOT_AUTH_MODULE' => '',
'RBAC_ROLE_TABLE' => 'hd_role',
'RBAC_USER_TABLE' => 'hd_role_user',
'RBAC_ACCESS_TABLE' => 'hd_access',
'RBAC_NODE_TABLE' => 'hd_node',
_____________________________________________________________________
我的Login控制器
session(C('USER_AUTH_KEY'),$user['id']);
session('username',$user['username']);
session('logintim',date("Y-m-d H:i",$user['logintime']));
session('loginip',$user['loginip']);
if($user['username'] == C('RBAC_SUPERADMIN')){
session(C('ADMIN_AUTH_KEY'),true);
}
//将RBAC写入session
import('ORG.Util.RBAC');
RBAC::saveAccessList();
p($_SESSION);
die; 展开
(
[verify] => a87ff679a2f3e71d9181a67b7542122c
[uid] => 7
[username] => lisi
[logintim] => 2014-04-07 20:03
[loginip] => 127.0.0.1
[_ACCESS_LIST] => Array
(
)
)
我的配置项
'RBAC_SUPERADMIN' => 'admin',
'ADMIN_AUTH_KEY' => 'superadmin',
'USER_AUTH_ON' => true,
'USER_AUTH_TYPE' => 1,
'USER_AUTH_KEY' => 'uid',
'NOT_AUTH_ACTION' => '',
'NOT_AUTH_MODULE' => '',
'RBAC_ROLE_TABLE' => 'hd_role',
'RBAC_USER_TABLE' => 'hd_role_user',
'RBAC_ACCESS_TABLE' => 'hd_access',
'RBAC_NODE_TABLE' => 'hd_node',
_____________________________________________________________________
我的Login控制器
session(C('USER_AUTH_KEY'),$user['id']);
session('username',$user['username']);
session('logintim',date("Y-m-d H:i",$user['logintime']));
session('loginip',$user['loginip']);
if($user['username'] == C('RBAC_SUPERADMIN')){
session(C('ADMIN_AUTH_KEY'),true);
}
//将RBAC写入session
import('ORG.Util.RBAC');
RBAC::saveAccessList();
p($_SESSION);
die; 展开
展开全部
学习ThinkPHP的RBAC的时候, [_ACCESS_LIST] 总是空的解决方法
注意:
admin权限应该是所有权限,admin,lisi,wangwu等用户在顶级,后台应用上,一定要钩选中,次级,帖子管理等控制器级别,也要选中,最下级别的帖子列表选中,这样一来,[_Access_List]=>Array{}数组就可以显示出来权限了,关键在于静态函数static function saveAccessList($authId=null)对getAccessList的封装,而getAccessList又对thinkphp框架中core下db.class.php的调用,其中level级别,通过$authId获取各个RBAC各个相关数据库表的操作,如果不钩选顶级应用,即使,次级控制器,最下级别的帖子列表钩选上,level也会没有,使得,[_Access_List]=>Array{}数组打印为空!
注意:
admin权限应该是所有权限,admin,lisi,wangwu等用户在顶级,后台应用上,一定要钩选中,次级,帖子管理等控制器级别,也要选中,最下级别的帖子列表选中,这样一来,[_Access_List]=>Array{}数组就可以显示出来权限了,关键在于静态函数static function saveAccessList($authId=null)对getAccessList的封装,而getAccessList又对thinkphp框架中core下db.class.php的调用,其中level级别,通过$authId获取各个RBAC各个相关数据库表的操作,如果不钩选顶级应用,即使,次级控制器,最下级别的帖子列表钩选上,level也会没有,使得,[_Access_List]=>Array{}数组打印为空!
展开全部
我也碰到过,看了RBAC类下的源码,我发现node,role表里的status=0时就是这样,最后把这两个表里的status改为1就好了,分配权限时要注意:如果选择了level3里的操作方法,就必须选择对应的控制器level2和level2对应的应用level1;还有就是role表里的pid不能一样,否则在登录下一个时,上一个的权限也会加到这个用户头上,我遇到的问题就是这些,希望可以帮到你;这里是我做的RBAC(thinkPHP3.2.3)完整demo,包含功能:权限管理、用户的增删改查、节点的增删改查、角色的增删改查,有需要的可以看看:网页链接
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你那个hd_access表中level肯定没有为1的,只有2,3。问题就出在这,所以它才没有找到值
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你解决了没有?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
只需要把最上面的节点选中就行了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询