django 通过url实现简单的权限控制的例子
2019-08-16 19:12
761 查看
根据用户权限设定用户可以访问哪些页面,用django实现一个简单的demo。
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("<h1>%s</h1>"%menuname)
在之后的方法上添加该闭包,即可实现简易的路由控制。
以上这篇django 通过url实现简单的权限控制的例子就是小编分享给大家的全部内容了,希望能给大家一个参考
您可能感兴趣的文章:
相关文章推荐
- CI框架中通过hook的方式实现简单的权限控制
- **CodeIgniter通过hook的方式实现简单的权限控制
- CodeIgniter通过hook的方式实现简单的权限控制
- CodeIgniter通过hook的方式实现简单的权限控制
- CodeIgniter通过hook的方式实现简单的权限控制
- CI框架中通过hook的方式实现简单的权限控制
- CodeIgniter通过hook的方式实现简单的权限控制
- 自己动手实现简单权限控制
- 在ASP.NET MVC中实现基于URL的权限控制
- javaWeb用户权限控制简单实现
- javaWeb用户权限控制简单实现
- 通过控制台实现 socket 的简单的例子
- SVM实现多分类的程序基础工作(二)——通过一个简单libsvm例子迈入libsvm学习的大门
- 自己动手实现简单权限控制
- Struts2自定义标签——通过自定义标签实现权限控制
- 通过SpringMVC+Annotation实现方法、按钮级别的细粒度权限控制
- 通过linux的tc工具简单实现上传和下载的流量控制
- javaWeb用户权限控制简单实现
- Struts 拦截器权限控制【通过拦截器实现登录后跳转到登录前页面】
- django权限控制功能实现