zoukankan      html  css  js  c++  java
  • 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 bacDbManager的rbac权限怎么统一管理的,比如怎么让所有控制器访问之前都会统一检查权限,而不是使用Yii::$app->user->can()一个一个验证;

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

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

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

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

     

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

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

  • 相关阅读:
    git切换仓库 小记
    修改prometheus默认端口,修改grafana默认端口
    Redisson报错
    Windows IDEA Community 报错
    Debouncer防抖代码
    IDEA通用配置
    Jackson通用工具类
    SpringBoot接入两套kafka集群
    博客园什么时候有的高低贵贱制度???
    致已经逝去的2020和已经到来的2021
  • 原文地址:https://www.cnblogs.com/JahanGu/p/12933381.html
Copyright © 2011-2022 走看看