auth 权限控制
一. 权限介绍
所谓权限控制,大部分是在管理后台上使用。比如超级管理员登录,会得到所有操作的
控制权;认证专员,只能给会员做认证操作;审核专员,只能操作内容的审核、删除、加精
等操作,以此类推。那么 ThinkPHP 提供了一个内置的 Auth.class.php 类来实现权限控
制,这个类提供了三个表:think_auth_rule(认证规则表)、think_auth_group(用户组
表)、think_auth_group_access(用户和组对应关系表)。当然还要结合自己创建的用户
表进行对应即可
二. 简单登录
第一步:在 Admin 模块下创建一个 IndexController.class.php (默认就有了),创
建 index 方法,输出一句话即可。
namespace Admin\Controller;
use Common\Controller\AuthController; class IndexController extends AuthController {
public function index(){
echo '后台首页!';
}
}
这是通过 URL 访问: http://localhost/demo39/Admin/Index/index ,即可访问。
第二步:在 Weibo 根目录下的 Common 公共模块下创建 Controller 文件夹,并在里面
创建一个 AuthController.class.php 类,这个类用于权限控制。
namespace Common\Controller;
use Think\Controller;
use Think\Auth; class AuthController extends Controller {
protected function _initialize() {
$auth = new Auth();
if(!$auth->check()) {
$this->error('没有权限');
}
}
}
这里使用的方法固定为: _initialize() 。由于 AuthController.class.php 继承了
Controller 类,所以,第一步的 Index 类改为继承它。 check() 函数是调用了
ThinkPHP/Library/Think/Auth.class.php 内部的 check() 函数。
namespace Admin\Controller;
use Common\Controller\AuthController;
class IndexController extends AuthController {
public function index() {
echo '后台首页!';
}
}
此时,我们再访问后台首页的时候,已经没有权限了。主要是 $auth->check() 验证无
法通过的原因。
第三步:创建一个 WeiBo/Admin/Controller/LoginController.class.php ,模版为 index.html 。
在 WeiBo/Admin/View/Login/index.html 中写入登录代码:
<p>三个用户:admin为超级管理员,所有权限;test测试用户,没有权限;guest游客,只有登录权限。</p>
<form method="post" action="{:U('index')}">
<p>用户名:<input type="text" name="user" /></p>
<p><input type="submit" value="登录" /></p>
</form>
在 WeiBo/Admin/Controller/LoginController.class.php 中写入代码:
<?php
namespace Admin\Controller;
use Think\Controller; class LoginCOntroller extends Controller{
public function index() {
if(IS_POST) {
$login = array();
switch(I('user',null,false)) {
case 'admin':
$login['uid']=1;
$login['user']='admin';
break;
case 'test':
$login['uid']=2;
$login['user']='test';
break;
case 'guest':
$login['uid']=3;
$login['user']='guest';
break;
default:
$this->error('登陆用户不存在');
}
if(count($login)) {
session('auth',$login);
$this->success('登陆成功',U('Index/index'));
}
}else {
$this->display();
}
}
public function logout() {
session('[destroy]');
$this->success('退出成功',U('Login/index'));
}
}
这里登录的 LoginController.class.php 类只要继承 Controller 即可,否则无法
运行。因为继承 AuthController 类的是需要权限控制的类。
这里加了个 logout() 函数,就是在后台主页要退出的函数:
在 WeiBo/Admin/Controller/IndexController.class.php 中完善登出的功能:
<?php namespace Admin\Controller;
use Common\Controller\AuthController; class IndexController extends AuthController {
public function index(){
echo '后台首页!';
echo '<a href="'.U('Login/logout').'">退出</a>';
}
}
第四步:完善 AuthController 类的权限验证过程。
<?php
namespace Common\Controller;
use Think\Controller;
use Think\Auth; class AuthController extends Controller {
protected function _initialize() {
$sess_auth=session('auth');
if(!$sess_auth) {
$this->error('非法访问,正在跳转登录页面',U('Login/index'));
}
if($sess_auth['uid']==1) {
return true;
}
$auth = new Auth();
if(!$auth->check( MODULE_NAME.'/'.CONTROLLER_NAME.'/'.ACTION_NAME,$sess_auth['uid'])) {
$this->error('没有权限',U('Login/logout'));
}
}
}
最后的check()判定函数中的 MODULE_NAME.'/'.CONTROLLER_NAME.'/'.ACTION_NAME 其实在本例子中是 Admin/Index/index ,但由于这个权限规则可能不是固定的,所以用
MODULE_NAME.'/'.CONTROLLER_NAME.'/'.ACTION_NAME 会通用一点。
check()这个函数是调用的 ThinkPHP/Library/Think/Auth.class.php 中的,括号里面的参数在check()函数前面的注释里有介绍
如果 $sess_auth['uid']==1 则判定为: true ,这时就不会执行下面的 !$auth->check() 函数了,这个check()函数是当不是
admin用户时,则判定为没有权限
最后再写一些数据库中的操作是怎样的,
在 ThinkPHP/Library/Think/Auth.class.php 中可以看到已经写好了sql语句,可以用来增加数据库,复制后在
数据库中粘贴就行,效果如下图:

think_auth_rule
name是授权给用户访问的页面
视频中的权限是 Admin/Index/index
title写的是后台首页
此时id默认是1,这里id是需要认证的规则
think_auth_group
title上写的是默认管理组
status默认是1
给rules设置为1,但是以后还是会设置第2,第3,第4,第5个权限,所以可以设置为1,2,3,4,5...,这时默认管理组就有这些权限,
这些权限就是 think_auth_rule 中的id,因为这些id对应了后面的name,name就是可以访问的权限 这些权限就会分配给 think_auth_group_access ,
think_auth_group_access 中的uid就是程序登录是的 WeiBo/Admin/Controller/LoginController.class.php 中的 $login['uid'] 中的值,这里的 group_id 就是 think_auth_group 中的id.
think_auth_rule 中的表的结构如图:

think_auth_group 中的效果如下图:

think_auth_group_access 的效果如下图:

auth 权限控制的更多相关文章
- MongoDB 安全和访问权限控制
MongoDB的访问控制能够有效保证数据库的安全,访问控制是指绑定Application监听的IP地址,设置监听端口,使用账户和密码登录 一,访问控制的参数 1,绑定IP地址 mongod 参数:-- ...
- redis密码设置、访问权限控制等安全设置
redis作为一个高速数据库,在互联网上,必须有对应的安全机制来进行保护,方法有2,如下. 1.比较安全的办法是采用绑定IP的方式来进行控制. 请在redis.conf文件找到如下配置 # If y ...
- 为CDH 5.7集群添加Kerberos身份验证及Sentry权限控制
转载请注明出处:http://www.cnblogs.com/xiaodf/ 4. 为CDH 5集群添加Kerberos身份验证 4.1 安装sentry1.点击“操作”,“添加服务”:2.选择sen ...
- [转]CodeIgniter与Zend Acl结合实现轻量级权限控制
Tag :CodeIgniter Zend Acl 权限控制 1. Zend_Acl简介 Zend_Acl 为权限管理提供轻量并灵活的访问控制列表 (ACL,access control list) ...
- Spring Security(16)——基于表达式的权限控制
目录 1.1 通过表达式控制URL权限 1.2 通过表达式控制方法权限 1.2.1 使用@PreAuthorize和@PostAuthorize进行访问控制 1.2.2 ...
- thinkphp整合系列之rbac的升级版auth权限管理系统demo
权限管理基本是作为网站的标配了: 除非是像博客这类个人使用的:否则权限管理的重要性不言而喻: 今个就来写写auth权限管理: thinkphp已经内置了auth权限类位于:/ThinkPHP/Libr ...
- ASP.NET Zero--15.一个例子(8)商品分类管理-权限控制
1.添加权限常量 打开文件AppPermissions.cs [..\MyCompanyName.AbpZeroTemplate.Core\Authorization\AppPermissions.c ...
- aProxy: 带认证授权和权限控制的反向代理
前段时间很多数据库因为没有做好权限控制暴露在外网被删然后遭勒索的事件,而类似的有些内网的web服务也会被开放到公网并且没有做任何权限控制的,这样也会有一定的风险.所以就决定写篇文章简单介绍一个小工具. ...
- django(权限、认证)系统——第三方组件实现Object级别权限控制
在我的系列blog<Django中内置的权限控制>中明确提及到,Django默认并没有提供对Object级别的权限控制,而只是在架构上留了口子.在这篇blog中,我们探讨一个简单流行的Dj ...
随机推荐
- web版源码管理软件SCM-Manager使用简要说明
登录 默认管理员用户:scmadmin / scmadmin 用户 用户,可以反向添加针对所有仓库的权限 用户组 用户组,可以反向添加针对所有仓库的权限 用户组管理 用户组,可委托给具体用户进行管理( ...
- 我所理解的Mongodb 的优势
更高的写负载 默认情况下,对比事务安全,MongoDB更关注高的插入速度.如果你需要加载大量低价值的业务数据,比如日志收集,那么MongoDB将很适合你的用例,但是必须避免在要求高事务安全的情景下使用 ...
- BRICH
一.简介 Brich是典型的基于层次的聚类算法.最大的特点就是适合数据量特别大的数据集,处理速度很快,因为该算法扫描一遍数据集. 该算法是利用了一个树状结构来快速聚类,该结构类似平衡B+树.每一个叶子 ...
- Ubuntu 安装arm-linux-gcc编译器
/********************************************************************************** * Ubuntu 安装arm-l ...
- php写入数据到mysql数据库中出现乱码解决方法
乱码情况: 在选择数据库前加入一句代码即可 mysql_query("set names utf8"); 最后效果
- python之 python 起源、语言特点
一. 1.1 什么是 PythonPython 是一门优雅而健壮的编程语言,它继承了传统编译语言的强大性和通用性,同时也借鉴了简单脚本和解释语言的易用性.它可以帮你完成工作,而且一段时间以后,你还能 ...
- angular track by $index
这个东西配合删除数组时会出现永远删除uoloadPicArr这个数组的最后一个一项 其用法是主要用在当ng-repeat循环时如果其内部的dom元素有id属性存在 可以避免页面出现相同的id 只是一 ...
- Visualforce Page超链接
Salesforce开发者文档:https://developer.salesforce.com/docs/atlas.en-us.pages.meta/pages/pages_quick_start ...
- MySQL 用户权限详细汇总(转)
1,MySQL权限体系 MySQL 的权限体系大致分为5个层级: 全局层级: 全局权限适用于一个给定服务器中的所有数据库.这些权限存储在mysql.user表中.GRANT ALL ON .和REVO ...
- 解决IDEA输入法不跟随
1.关掉idea后在idea的安装路径下把jre64文件夹删掉,或者重命名也行,如把jre64改成jre642: 2.升级jdk版本至jdk 8u45以上 3.把Java安装路径下的jre文件拷贝到I ...