博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django实战(23):权限控制
阅读量:4879 次
发布时间:2019-06-11

本文共 906 字,大约阅读时间需要 3 分钟。

我们功能,但是它还没有起作用。因为匿名用户还是可以通过直接输入url:http://localhost:8000/depotapp/product/list/ 访问到产品管理界面。这就好像你在门上加了把锁,却没有把窗户关上一样。所以我们还需要进行访问控制。

我们这里实现最简单的控制,非登录用户禁止访问产品管理界面。在Django里面,只需要在相应的视图函数前面增加@login_required修饰符即可:

 

from django.contrib.auth.decorators import login_required ... ... @login_required def list_product(request): list_items = Product.objects.all() ... ...

 

login_required实现了如下功能:

如果用户没有登录, 重定向到/accounts/login/,并且把当前绝对URL作为next参数用get方法传递过去;

如果用户已经登录, 正常地执行视图函数。

 

这样我们例子中需要的功能就实现了。但是这充其量是“登录限制”,而更常见的需求是“访问控制”,即区分已经登录的用户,对不同的视图有不同的访问权限。因为我们的例子中没有涉及到,所以只把相关的做法简单例举在下面。

1.访问控制功能通过Django的 request.user.has_perm() 来实现,该函数返回True或False,表示该用户是否有权限。而权限是auth 应用中定义的Permission类型;User与Permission是many-to-many的关系。

2. Django还提供了一个@permission_required修饰符,来限定view函数只有在User具有相应权限的情况下才能被访问。

3. Django对于每个模型类,自动增加add、change、delete三种权限,以便于权限控制。当然你也可以设定自己的权限。

转载于:https://www.cnblogs.com/holbrook/archive/2012/02/10/2357344.html

你可能感兴趣的文章
简单的社交网络
查看>>
jeecg 实现lhgDialog窗口传值
查看>>
JSON初试
查看>>
欧拉计划 题目24 (全排列)
查看>>
Mysql基础2
查看>>
Math.floor,Math.ceil,Math.rint,Math.round用法
查看>>
HDU ACM 1495 非常可乐(广搜BFS)
查看>>
Java程序设计概述
查看>>
我的第一个Java程序
查看>>
eclipse Mac 快捷键
查看>>
浏览器下载代码
查看>>
第三天(1)自定义拦截器
查看>>
XML语言:可扩展的标记语言;
查看>>
Leetcode OJ : Implement strStr() [ Boyer–Moore string search algorithm ] python solution
查看>>
计算机网络概况(一)
查看>>
es6 箭头函数【箭头表达式】
查看>>
将数据保存在系统钥匙串里,即使应用被删除,数据还会被保存
查看>>
获取差集合的一种实现思路
查看>>
实验七
查看>>
Unity 摄像头竖屏预览显示的问题
查看>>