- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Django中login_required装饰器的深入介绍由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
前言 。
Django提供了多种装饰器, 其中login_required可能是经常会使用到的。 这里介绍下四种使用此装饰器的办法.
当然, 在使用前, 记得在工程目录的settings.py中设置好LOGIN_URL 。
使用方法 。
1. URLconf中装饰 。
1
2
3
4
5
6
7
8
9
|
from
django.contrib.auth.decorators
import
login_required, permission_required
from
django.views.generic
import
TemplateView
from
.views
import
VoteView
urlpatterns
=
[
url(r
'^about/'
, login_required(TemplateView.as_view(template_name
=
"secret.html"
))),
url(r
'^vote/'
, permission_required(
'polls.can_vote'
)(VoteView.as_view())),
]
|
2. 装饰基于函数的视图 。
1
2
3
4
5
6
7
8
|
from
django.contrib.auth.decorators
import
login_required
from
django.http
import
HttpResponse
@login_required
def
my_view(request):
if
request.method
=
=
'GET'
:
# <view logic>
return
HttpResponse(
'result'
)
|
3. 装饰类的视图 。
1
2
3
4
5
6
7
8
9
10
|
from
django.contrib.auth.decorators
import
login_required
from
django.utils.decorators
import
method_decorator
from
django.views.generic
import
TemplateView
class
ProtectedView(TemplateView):
template_name
=
'secret.html'
@method_decorator
(login_required)
def
dispatch(
self
,
*
args,
*
*
kwargs):
return
super
(ProtectedView,
self
).dispatch(
*
args,
*
*
kwargs)
|
4. 装饰通过Mixin类继承来实现 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
from
django.contrib.auth.decorators
import
login_required
from
django.http
import
HttpResponseRedirect
from
django.shortcuts
import
render
from
django.views.generic
import
View
from
.forms
import
MyForm
class
LoginRequiredMixin(
object
):
@classmethod
def
as_view(
cls
,
*
*
initkwargs):
view
=
super
(LoginRequiredMixin,
cls
).as_view(
*
*
initkwargs)
return
login_required(view)
class
MyFormView(LoginRequiredMixin, View):
form_class
=
MyForm
initial
=
{
'key'
:
'value'
}
template_name
=
'form_template.html'
def
get(
self
, request,
*
args,
*
*
kwargs):
form
=
self
.form_class(initial
=
self
.initial)
return
render(request,
self
.template_name, {
'form'
: form})
def
post(
self
, request,
*
args,
*
*
kwargs):
# code here
|
Django 用户登陆访问限制 @login_required 。
在网站开发过程中,经常会遇到这样的需求:用户登陆系统才可以访问某些页面,如果用户没有登陆而直接访问就会跳转到登陆界面.
要实现这样的需求其实很简单:
1、在相应的 view 方法的前面添加 django 自带的装饰器 @login_required 。
2、在 settings.py 中配置 LOGIN_URL 参数 。
3、修改 login.html 表单中的 action 参数 。
1
2
3
4
5
6
7
|
# views.py
from
djanco.contrib.auth.decorators
import
login_required
from
django.shortcuts
import
render_to_response
@login_required
def
index(request):
return
render_to_response(
'index.html'
)
|
1
2
3
4
|
# settings.py
....
LOGIN_URL
=
'/accounts/login/'
# 根据你网站的实际登陆地址来设置
....
|
如果要使用 django 默认登陆地址,则可以通过在 urls.py 中添加如此配置:
1
2
3
4
|
# urls.py
....
url(r
'^accounts/login/'
, views.login),
....
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
# login.html
<div
class
=
"container"
>
<form
class
=
"form-signin"
action
=
"/accounts/login/"
method
=
"post"
>
{
%
csrf_token
%
}
<!
-
-
csrf_token:生成令牌
-
-
>
<h2
class
=
"form-signin-heading"
align
=
"center"
>登录系统<
/
h2>
<label
for
=
"inputUsername"
class
=
"sr-only"
>username<
/
label>
<
input
type
=
"text"
name
=
"username"
id
=
"inputUsername"
class
=
"form-control"
placeholder
=
"username"
required autofocus>
<label
for
=
"inputPassword"
class
=
"sr-only"
>Password<
/
label>
<
input
type
=
"password"
name
=
"password"
id
=
"inputPassword"
class
=
"form-control"
placeholder
=
"Password"
required>
<div
class
=
"checkbox"
>
<label>
<
input
type
=
"checkbox"
value
=
"remember-me"
> 记住密码
<
/
label>
<
/
div>
<br
/
>
<button
class
=
"btn btn-lg btn-primary btn-block"
type
=
"submit"
>登录<
/
button>
<br
/
>
<span style
=
"color: red;"
>{{ login_err }}<
/
span>
<
/
form>
<
/
div>
<!
-
-
/
container
-
-
>
|
总结 。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我的支持。 。
原文链接:https://segmentfault.com/a/1190000012056602 。
最后此篇关于Django中login_required装饰器的深入介绍的文章就讲到这里了,如果你想了解更多关于Django中login_required装饰器的深入介绍的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有这些 ViewModel:RecordViewModel、ComponentViewModel,其中 RecordViewModel 本质上是几个 ComponentViewModel 的容器。
我正在尝试为我的 Controller 设置一个装饰器。我的目的是在我的应用程序中的所有 Controller 中引入一些常见的行为。 我已将其配置为在 Angular 1.2.x 中工作,但从 1.
我想用角上的时间戳装饰我生成的所有 JFreeCharts。 JFreeChart 框架中是否有一种方法可以在生成图表后在图像上绘制? 编辑:请注意,这些图表是在后台线程中生成并通过 servlet
在grails应用程序中,我想用自定义数据装饰每个日志。当前的需要只是在日志消息前添加当前用户名 我对如何解决此问题有一些想法: -Adding custom field to log4j patte
我有一个form-el,它只是一个容器,必须将所有子元素包装在具有特定类的div 中。我希望允许 from-el 来包装它们,而不是在每个表单元素中重复这个 div 。我可以循环所有元素并将它们包装在
我遵循以下约定来装饰 Python 类中的某些方法。我想知道是否有一些更好的方法可以做到同样的事情。我的方法看起来当然不太好;对原始成员函数的调用看起来一点也不直观。 from threading i
我的 DTO 看起来像这样 public class SomeDTO { public string last_name{ get; set; } public string ac
这可能是一个远景,但 .NET 的灵 active 一直让我惊叹不已,所以开始吧。 我正在开发一个 MVC 应用程序,它需要在一组程序集中搜索派生自公共(public)基类的类类型。 即我有几个程序集
在我正在进行的项目中,我正在按照项目负责人的要求实现开发人员通知系统。它的工作方式是,如果发生前端错误,开发团队会收到一封错误电子邮件。 但是,在我当前的实现中,我似乎有以下循环依赖: $rootSc
我需要一些关于如何取消装饰和装饰 JInternalFrame 的帮助。我的框架类是这样的: package com; import java.awt.BorderLayout; import jav
假设我们有可能需要长时间运行的任务: public class LongRunningTask { public ReturnType doSomething() { ...
我正在尝试创建一个装饰器方法,它将一些默认的生命周期方法添加到 react 组件中。我的目标是向组件中添加一些默认功能,例如,所有组件都应该能够在 componentWillMount 上执行特定操作
我正在尝试将 DBUS 的异步方法调用与 Twisted 的 Deferred 相结合,但我在调整常用的 DBUS 服务方法装饰器来执行此操作时遇到了麻烦。 要使用 DBUS 异步回调方法,您需要:
是否可以设置表格中一行的背景颜色?当条件适用时,我需要突出显示一行。效果为 ...我可以在其中指定“字体”属性。 (我需要突出显示整行)。 最佳答案 您必须子类化 qooxdoo 默认行渲染器才能做到
我正在开发一个具有不同视角的基于 Java Swing 的应用程序。对于“主菜单”视角,我不希望装饰窗口 (JFrame),而在其他视角中,我确实希望装饰窗口。换句话说,我需要动态更 retrofit
我想做一些类似下面代码所示的事情: class foo { private: std::fstream* m_stream; public: foo(std::fstream* str
我的数据源提供了一个 ObservableList ,但是对于我的 ListView,我需要一个 ObservableList . A Warning基本上只是字符串的装饰器,添加一个 boolean
我一直在纠结于装饰+接口(interface)。假设我有以下“行为”接口(interface): interface IFlyable { void Fly();} interface ISwimma
有没有人为 iOS 6 UICollectionView 实现过装饰 View ?不可能 查找有关在网络上实现装饰 View 的任何教程。基本上在我的应用程序中,我有多个部分,我只想在每个部分后面显示
我有一个简单的 Controller ,例如: function MyController($scope, $http) { ... $http.post(url).success(f
我是一名优秀的程序员,十分优秀!