yii2运行流程

入口文件index.js开始 

通过Application创建app, 并且读入config, 装载扩展和组件

通过request解析被请求的路由
app根据路由创建controller
controller创建action
如果过滤器通过, 则会执行action
action会渲染视图view
view中的内容一般来自于model
渲染的结果通过response返回给客户端
这篇文章写得很清楚了,原文链接:https://blog.csdn.net/alex_my/article/details/54142711

 

以下分析是为了了解yii2 yii\rbac\DbManager的rbac权限怎么统一管理的,比如怎么让所有控制器访问之前都会统一检查权限,而不是使用Yii::$app->user->can()一个一个验证;

统一验证我们可以在yii\filters\AccessControl的beforeAction方法里做统一验证,或者重写一个AccessControl,类似使用yii2-admin自带的rbac管理,注意重写的AccessControl要配置as access指定class,不然会使用默认的yii\filters\AccessControl

 

 

 

 

 

yii2权限rbac通过AccessControl.php下面的方法beforeAction过滤是否有权限访问

流程大概为在yii\base\Controller::runAction中会执行 this->beforeAction —> this->ensureBehaviors()到$behaviors

 

 

$behaviors实际上是AccessControl的对象,attach是其基类ActionFilter中的函数将会执行ActionFilter::beforeFilter,beforeFilter又执行了beforeAction,AccessControl又重载了beforeAction,如下图

 

 

 

最后就是执行AccessControl类下面做验证权限,

 注意使用别的比如yii2-admin插件的rbac一定要配置as access,指定类AccessControl,不然会默认使用yii\filters\AccessControl的验证方法

 

posted @ 2020-05-21 20:18  JahanGu  阅读(528)  评论(0编辑  收藏  举报