欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

Auth认证类通用认证代码

程序员文章站 2022-06-15 22:22:53
...
使用Auth.class.php对系统进行认证,其中频繁用到认证,在前面的基础上做了改进。
登陆成功后,将当前用户的id存入:session('uid',$curUserId);
在Config.php中配置:'NOT_AUTH_MODULE' =>'Public,Index,Test', // 默认无需认证模块
'NOT_AUTH_ACTION' =>'', // 默认无需认证操作
'SUPERADMIN_UID'=>array(1,2),
function authcheck($url,$relation='or'){

$linkArr=explode('/',$url);
if(!(count($linkArr)==2||count($linkArr)==3))return;

if(count($linkArr)==2){
$CUR_MODULE_NAME=$linkArr[0];
$CUR_ACTION_NAME=$linkArr[1];
}else{
$CUR_MODULE_NAME=$linkArr[1];
$CUR_ACTION_NAME=$linkArr[2];
}
$notAuth=in_array($CUR_MODULE_NAME, explode(",", C("NOT_AUTH_MODULE"))) || in_array($CUR_ACTION_NAME, explode(",", C("NOT_AUTH_ACTION")));

$AUTH_CONFIG=C('AUTH_CONFIG');
if(!$AUTH_CONFIG['AUTH_ON']||$notAuth)return true;
else{
if(!session("?uid"))return false;

if(in_array(session('uid'),C('SUPERADMIN_UID')))return true;
else{
import('ORG.Util.Auth');
$auth=new Auth();
if($auth->check($CUR_MODULE_NAME.'/'.$CUR_ACTION_NAME,session('uid'),$relation))return true;
else return false;
}
}
}
所有的Action均需要继承CommonAction.class.php,在Common的 _initialize()方法中使用:if(!authcheck(MODULE_NAME.'/'.ACTION_NAME))$this->error('你没有权限',U('Index/index'));在后台中对think_auth_rule数据表中在name字段存入操作的url,如:User/index,User/addRecord......

有不明白的地方有问必答,欢迎大家探讨。

AD:真正免费,域名+虚机+企业邮箱=0元