怎么在django中通過url實現權限控制?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
1.models.py 文件
class level(models.Model): l_name = models.CharField(max_length=50,verbose_name="等級名稱") l_permission = models.OneToOneField("permission") def __str__(self): return self.l_name class userinfo(models.Model): u_name = models.CharField(max_length=50,verbose_name="用戶名稱") u_user = models.OneToOneField(User) u_level = models.ForeignKey(level,related_name="lev") def __str__(self): return self.u_name class permission(models.Model): p_name = models.CharField(max_length=50,verbose_name="權限名稱") p_menu = models.ManyToManyField("menu") def __str__(self): return self.p_name class menu(models.Model): m_name = models.CharField(max_length=50,verbose_name="菜單名稱") m_url = models.CharField(max_length=50,verbose_name="菜單地址",blank=True,null=True) def __str__(self): return self.m_name class nickname(models.Model): n_nickname = models.CharField(max_length=50,verbose_name="昵稱",blank=True,null=True) n_user = models.ForeignKey(userinfo,blank=True,null=True,related_name="nick") def __str__(self): return self.n_nickname
2.settings.py 文件
URL_WHITE_LIST = ['index', 'login', 'logout']
設置路由白名單。
3.views.py 文件
def url_check(fun): def check(request,*args,**kwargs): if request.session.get("p_l",None): require_list = pickle.loads(request.session.get("p_l")) request_url = request.path.replace("/","") ua = request.META.get('HTTP_USER_AGENT',None) if request_url in require_list or request_url in IP_WHITE_LIST: return fun(request,*args,**kwargs) else: error_msg = "沒有權限!" menu_ = pickle.loads(request.session.get("p_l")) return render(request,"index.html",{"error_msg":error_msg,"menu":menu_}) else: return HttpResponseRedirect(reverse("login")) return check
定義一個路由檢測的閉包方法,根據用戶登錄時的session信息,獲取該用戶角色可以訪問的路由,如果當前訪問的地址不在白名單或是session記錄里,返回錯誤信息。
@url_check def menu(request,menuname): return HttpResponse("<h2>%s</h2>"%menuname)
看完上述內容,你們掌握怎么在django中通過url實現權限控制的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。