settings.py 文件设置

中间件的引进一般放在settings.py 文件中的 MIDDLEWARE 中, 权限中间件也是从这儿引进放进去。

django-vue-admin 权限中间件

自定义middleware文件解析

在上面截图中可以看到权限中间件是放在了vadmin.op_drf.middleware.PermissionModeMiddleware 里边 去到对应的 middleware 文件中,看中间件写的一些内容。

django-vue-admin 权限中间件
里边PermissionModelMiddleware类中继承了 MiddlewareMixin,然后自定义实现了中间件中常用的办法 process_request, process_view, process_response, 还有自己写了一个 has_interface_permission 办法去对权限进行判别.

process_request: 恳求进来前的处理
process_view: 恳求进入到视图处理前的处理
process_response: 恳求处理完后的记载

这儿主要是在process_view进行逻辑处理,可以对这进行分析解析。

  • process_view 解析

    1. 演示模式判别处理 环境变量DEMO_ENV 为真,恳求的办法不是get或者options, 而且恳求的地址不在白名单内的,一概回绝。

      django-vue-admin 权限中间件

    2. 假如没有开接口权限校验的,直接回来,无需校验

    django-vue-admin 权限中间件

    1. 假如开了接口权限校验,需求进行权限校验

      1. 获取恳求用户的基本信息
      2. 用户存在且用户不是AnonymousUser类型的用户,则持续进行校验。
        1. 恳求的是GET办法,一概不设置接口权限
        2. 解析恳求URL
        3. 经过has_interface_permission办法获取接口认证权限auth_code

      django-vue-admin 权限中间件

    2. 解析 has_interface_permission

      接口权限验证,优先级:
      (1)接口是否接入权限办理, 是:持续; 否:经过
      (2)认证的user是否superuser, 是:经过; 否:持续
      (3)user的人物有该接口权限, 是:经过, 否:不经过

      1. 先获取一切录入系统的接口

      django-vue-admin 权限中间件
      Menu.get_interface_dict() 相关代码

      django-vue-admin 权限中间件

      1. 判别此用户是否是superuser
      2. 获取此用户所恳求的接口
      3. 获取此用户关联人物一切有权限的接口

      django-vue-admin 权限中间件