发新话题
打印

ThinkPHP安全体系-委托认证和决策访问

ThinkPHP安全体系-委托认证和决策访问

企业级的应用是离不开安全保护的,ThinkPHP以基于Spring的Acegi安全系统作为参考原型,并做了简化,以适合目前的ThinkPHP结构,提供了一个多层的、可定制的安全体系来为应用开发提供安全控制。安全体系中主要有:
安全拦截器
认证管理器
决策访问管理器
运行身份管理器

安全拦截器
安全拦截器就好比一道道门,在系统的安全防护系统中可能存在很多不同的安全控制环节,一旦某个环节你未通过安全体系认证,那么安全拦截器就会实施拦截。

认证管理器
防护体系的第一道门就是认证管理器,认证管理器负责决定你是谁,一般它通过验证你的主体(通常是一个用户名)和你的凭证(通常是一个密码),或者更多的资料来做到。更简单的说,认证管理器验证你的身份是否在安全防护体系授权范围之内。

访问决策管理
虽然通过了认证管理器的身份验证,但是并不代表你可以在系统里面肆意妄为,因为你还需要通过访问决策管理这道门。访问决策管理器对用户进行授权,通过考虑你的身份认证信息和与受保护资源关联的安全属性决定是是否可以进入系统的某个模块,和进行某项操作。
例如,安全规则规定只有主管才允许访问某个模块,而你并没有被授予主管权限,那么安全拦截器会拦截你的访问操作。
决策访问管理器不能单独运行,必须首先依赖认证管理器进行身份确认,因此,在加载访问决策过滤器的时候已经包含了认证管理器和决策访问管理器。

为了满足应用的不同需要,ThinkPHP在进行访问决策管理的时候采用两种模式:登录模式和即时模式。
登录模式,系统在用户登录的时候读取改用户所具备的授权信息到Session,下次不再重新获取授权信息。也就是说即使管理员对该用户进行了权限修改,用户也必须在下次登录后才能生效。
即时模式就是为了解决上面的问题,在每次访问系统的模块或者操作时候,进行即使验证该用户是否具有该模块和操作的授权,从更高程度上保障了系统的安全。

运行身份管理器
运行身份管理器的用处在大多数应用系统中是有限的,例如某个操作和模块需要多个身份的安全需求,运行身份管理器可以用另一个身份替换你目前的身份,从而允许你访问应用系统内部更深处的受保护对象。这一层安全体系目前的RBAC插件中尚未实现。

早先RBAC组件是集成在ThinkPHP框架中的,从0.9版本引入了插件机制后,已经把RBAC组件转换成插件使用,以方便用户替换或者扩展,而且在调用接口上也更加方便。

要启用RBAC插件,请在项目配置文件_appConfig.php(请注意:项目配置文件名是以App命名的支持多种格式,运行时候系统会自动生成一个定义文件,最新的版本中自动生成的定义文件名是_appConfig.php ,请注意更新) 中设置
USER_AUTH_ON 为True
并设置认证类型USER_AUTH_TYPE
1 普通认证(认证一次)
2 高级认证(实时认证)
不设置默认为1

认证识别号USER_AUTH_KEY 是用于检查用户是否经过身份认证的标识,一旦用户经过系统认证,系统会把该用户编号保存在$_SESSION[USER_AUTH_KEY]中
为了满足应用系统的需要,RBAC插件中可以设置
REQUIRE_AUTH_MODULE 需要认证的模块
NOT_AUTH_MODULE 无需认证的模块
多个模块之间用逗号分割
如果某个模块需要认证,但是用户还没有经过身份认证,就会跳转到
USER_AUTH_GATEWAY 认证网关,例如 /Public/login
验证地址就是: 项目入口文件URL地址/Public/login
假设认证网关的验证操作地址是/Public/CheckLogin,可以在public模块的checkLogin操作中采用如下方式进行认证:
  • <?php
  • // 生成认证Map条件
  • // 这里使用用户名、密码和状态的方式进行认证
  • $map   =   new HashMap();
  • $map->put("name",$_POST['name']);
  • $map->put("password",$_POST['password']);
  • $map->put("status",1);
  • $authInfo = RBAC: : authenticate($map);
  • if(false === $authInfo) {
  •     $this->assign('error','登录失败,请检查用户名和密码是否有误!');
  • }else {
  •     // 设置认证识别号
  •     Session: :set(USER_AUTH_KEY,$authInfo->id);
  •     //获取并保存用户访问权限列表
  •     RBAC: :saveAccessList();
  •     // 登录成功,页面跳转
  •     $this->assign("message",'登录成功!');
  •     $this->assign("jumpUrl",'http://www.topthink.com.cn');
  • }
  • $this->forward();
  • ?>



RBAC的委托认证方法
authenticate($map,$dao='UserDao',$provider=USER_AUTH_PROVIDER)
方法是静态方法,支持三个参数,其中第一个认证条件$map是必须的,可以灵活地控制需要认证的字段
第二个参数是进行认证的Dao类,默认是UserDao类
第三个参数是委托方式 由 USER_AUTH_PROVIDER 设置委托认证管理器的委托方式,目前支持的是 DaoAuthentictionProvider 通过数据库进行认证。

在应用系统的开发过程中,只需要设置相关的配置项和添加上面的认证方法,其他的认证和决策访问就由RBAC插件的AccessDecision方法自动完成了。
系统会在执行某个模块的操作时候,首先判断该模块是否需要认证,如果需要认证并且已经登录,就会获取当前用户的权限列表判断是否具有当前模块的当前操作权限,并进行相应的提示。
接下来就是在框架总后台设置相关项目的模块和操作权限了。
首先,在总管理后台(ThinkPHP自带的Admin项目)的节点管理添加相关项目、模块和操作,作为权限管理的节点。
如果需要设置公共的操作,可以使用Public模块,所有属于Public模块的操作对所有模块都有效。
添加完成项目管理节点后,就在权限管理里面对某个用户组设置相关权限(包括项目权限、模块权限和操作权限)
以后需要授权就把用户添加到某个权限组就可以了,同一个用户可以属于多个权限组。
授权和认证功能涉及到四个数据表,DB_PREFIX为配置文件中设置的数据库前缀
DB_PREFIX_group 权限组表
DB_PREFIX_groupuser 组-用户关联表
DB_PREFIX_access 访问权限表
DB_PREFIX_node 权限节点表
神迹兄~~好久不见鸟~~~

TOP

发新话题