django中权限框架设计
2019-07-05 本文已影响15人
我爱学python
一:admin下的权限了解
(一)默认权限表是在自带auth模块,中permission表中
data:image/s3,"s3://crabby-images/ea7c7/ea7c7ee6a852cf33003ca7e10bbc3aa1302b5c7c" alt=""
可以使用has_perm方法获取用户是否有这个权限
(二)Django自定义权限
(1)添加表
data:image/s3,"s3://crabby-images/1a254/1a2540d016a352223ea28a61801cbdf1e762989c" alt=""
(2)settings文件中设置
AUTH_USER_MODEL ='repository.UserProfile' #上面的值表示Django应用的名称(必须位于INSTALLLED_APPS中)和你想使用的User模型的名称。
(3)在admin文件中设置展示内容
data:image/s3,"s3://crabby-images/a7555/a75550a020dc6d2f75d649c8b2965efb7d7deefb" alt=""
二:通用权限框架设计
(一)业务场景分析(如何去实现将不同权限分配给用户)
data:image/s3,"s3://crabby-images/86220/86220b3250cf3509f7501586236c0657a61e8e45" alt=""
(二)权限管理分析
data:image/s3,"s3://crabby-images/46c7f/46c7f9776f42c3bb184c844034caf5a4fca43e3e" alt=""
data:image/s3,"s3://crabby-images/a80b3/a80b31c7d9f9d77e8db4776bdf33e29f79c2c32d" alt=""
主要实现:将权限列表定义出来,与角色(用户组)相互关联就可以
权限列表实现:
data:image/s3,"s3://crabby-images/b16b6/b16b67cfc1a0a574d29b982820d4c326d584e52b" alt=""
data:image/s3,"s3://crabby-images/9571f/9571fc0df2d8aefde233f4b86fafb67ca8e92fbb" alt=""
(三)实现方法
(1)定义权限列表文件,将权限列表定义。设置为装饰器,根据每个用户访问的url去反解,获取到对应的权限列表名,从而去数据库中获取,使用has_prem获取是否拥有权限。从而在用户访问url时进行判断
permission_list.py(这部分最好是放入数据库中,可以改进)
data:image/s3,"s3://crabby-images/7c35e/7c35e9b56056427a08ce0a263bc87a523ebd9172" alt=""
data:image/s3,"s3://crabby-images/68568/685680daea24b64805002890d7b24d63d38a732d" alt=""
resolve方法可以翻转获取url的数据
data:image/s3,"s3://crabby-images/8ef23/8ef23fc2770c6e8d5350a698b404b05f7f89f25b" alt=""
data:image/s3,"s3://crabby-images/ec543/ec54391dbe5ae6c85cfc8368e9789e2a1bb32053" alt=""
(2)permission文件,用于生成装饰器,验证权限列表
data:image/s3,"s3://crabby-images/71de7/71de767ab0c127af3a5eded5b39b55fb9c0e5309" alt=""
总结:
data:image/s3,"s3://crabby-images/12816/1281668b4e54267c685ab082d341dd784523f067" alt=""
(3)钩子函数案例(使当前用户只能访问自己的客户)
data:image/s3,"s3://crabby-images/7fc5e/7fc5e797ec19764d0ea8ed332d58ed81743d539f" alt=""