亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Django web自定義通用權限控制實現方法

瀏覽:81日期:2024-09-18 08:06:24

需求:web系統有包含以下5個url,分別對于不同資源;

1、stu/add_stu/

2、stu/upload_homework/

3、stu/query_homework/

4、stu/add_record/

--------------------------------------------------------------------------------------------------------

學生可以訪問:2,3

老師可以訪問:1,4

可以通過基于角色對用戶權限進行控制:

一、數據模型

1、用戶表:用戶表和角色表為多對多關系,1個用戶可以有多個角色,1個角色可以被多個用戶劃分;

email = models.EmailField( verbose_name=’email address’, max_length=255, unique=True,) password = models.CharField(_(’password’),max_length=128, help_text=mark_safe(’’’<a href ='http://www.aoyou183.cn/bcjs/password/' >修改密碼</a>’’’))name = models.CharField(max_length=32,help_text=’用戶登陸后請修改為真實名字’)is_active = models.BooleanField(default=True)is_admin = models.BooleanField(default=False)role = models.ManyToManyField('Role')def __str__(self): return self.email

2、角色表:

class Role(models.Model): '''角色表''' name = models.CharField(unique=True,max_length=32) menus = models.ManyToManyField('Menu') def __str__(self): return self.name

3、菜單表:

class Menu(models.Model): '''動態菜單''' name = models.CharField(unique=True,max_length=32) url_type = models.SmallIntegerField(choices=((0,’relative_name’),(1,’absolute_url’))) url_name = models.CharField(unique=True,max_length=128) def __str__(self): return self.name

二、前端根據用戶權限生成菜單

<div class='container-fluid'> <div class='row'> {% block side-bar %} <div class='col-sm-3 col-md-2 sidebar'> <ul class='nav nav-sidebar'> {% block side-bar-menus %} {% for role in request.user.userprofile.roles.all %}<hr>{% for menu in role.menus.all %} <li> <a href='http://www.aoyou183.cn/bcjs/{% if menu.url_type == 0 %}{% url menu.url_name %}{% else %} {{ menu.url_name }}{% endif %}' rel='external nofollow' > {{ menu.name }} </a> </li>{% endfor %} {% endfor %} {% endblock %} </ul> </div> {% endblock %}

這樣就可以根據用戶生成菜單,但是如果用戶不是通過菜單方法,而是直接通過url訪問,后臺還是沒有對這些url進行控制

三、后臺根據用戶權限控制菜單訪問

裝飾器:

簡言之,python裝飾器就是用于拓展原來函數功能的一種函數,這個函數的特殊之處在于它的返回值也是一個函數,使用python裝飾器的好處就是在不用更改原函數的代碼前提下給函數增加新的功能。

class Mddile1(MiddlewareMixin): def process_request(self,request): #如果用戶訪問的url是登錄、注冊頁面,記錄到白名單,放行 for url in settings.PASS_URL_LIST: if re.match(url,request.path_info):return None Permission_url_list=request.session.get(settings.SESSION_PERMISSION_URL_KEY) #如果用戶訪問的url 不在當前用戶權限之內 返回login頁面 if not Permission_url_list: return redirect(settings.LOGIN_URL) current_url=request.path_info #由于數據庫的數據,可能是正則所有 一定要精確匹配 flag=False for url in Permission_url_list: url=’^%s$’%(url) if re.match(url,current_url):flag=Truebreak if not flag: if settings.DEBUG: #如果是程序調試應該 顯示用戶可以訪問的權限url_html=’<br/>’.join(Permission_url_list)return HttpResponse(’無權訪問您可以訪問%s’%url_html) else:return HttpResponse(’沒有權限’)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 免费一区二区视频 | 色xxxxx | 97碰碰碰免费公开在线视频 | 欧美综合图区亚欧综合图区 | 亚洲免费网站 | 伊人精品视频一区二区三区 | 国产精品亚洲欧美一区麻豆 | 一级免费看| 精品自拍视频在线观看 | 亚洲一级特黄特黄的大片 | 日本特黄特色大片免费视频 | www.激情555.com| 特黄特级a级黄毛片免费观看多人 | 亚洲一区二区三区在线免费观看 | 久久精品免费电影 | 一区二区免费视频观看 | 国产免费一区二区三区在线观看 | 免费观看又色又爽又大高清网站 | 中文字幕专区高清在线观看 | 女猛烈无遮挡性视频免费 | 99综合网 | 午夜精品影院 | 日韩免费高清一级毛片久久 | 亚洲欧美激情综合首页 | 免费高清a级毛片在线播放 免费高清小黄站在线观看 免费高清不卡毛片在线看 免费高清毛片 | 中文字字幕在线 | 狠狠五月天中文字幕 | 在线观看爱爱视频 | 久草美女 | 亚洲人成在线免费观看 | 五月婷婷六月丁香综合 | 特黄特级a级黄毛片免费观看多人 | 国产无遮挡又爽又色又刺激 | 97色伦图片97综合影院久久 | 黄色毛片在线看 | 达达兔午夜一级毛片 | 黄色三级国产 | 公么吃奶满足了我苏媚 | 国内精品久久久久久久999下 | 精品成人免费播放国产片 | 综合天天色|