入口文件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运行流程yii2运行流程

 

 

 

yii2运行流程

 

 

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

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

 

yii2运行流程

 

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

 yii2运行流程

 

 

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

yii2运行流程

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

yii2运行流程

 

相关文章:

  • 2021-06-09
  • 2021-08-10
  • 2021-11-02
  • 2021-10-11
  • 2021-05-25
  • 2021-07-29
  • 2021-10-04
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-07-25
  • 2021-03-31
  • 2021-09-01
相关资源
相似解决方案