【Django】@login_required用法简介

在django项目中,经常会看到下面这样的代码:

from django.contrib.auth.decorators import login_required @login_required def my_view(request): ...
里面有一个@login_required标签。其作用就是告诉程序,使用这个方法是要求用户登录的。

1.如果用户还没有登录,默认会跳转到‘/accounts/login/’。这个值可以在settings文件中通过LOGIN_URL参数来设定。(后面还会自动加上你请求的url作为登录后跳转的地址,如: /accounts/login/?next=/polls/3/ 登录完成之后,会去请求/poll/3

2.如果用户登录了,那么该方法就可以正常执行


如果LOGIN_URL使用默认值,那么在urls.py中还需要进行如下设置:(加入下面这句)

(r'^accounts/login/$', 'django.contrib.auth.views.login'),

这样的话,如果未登录,程序会默认跳转到“templates\registration\login.html”这个模板。


如果想换个路径,那就再加个template_name参数,如下:

(r'^accounts/login/$', 'django.contrib.auth.views.login', {'template_name': 'myapp/login.html'}),
这样程序就会跳转到templates\myapp\login.html”


除了login这个有用的方法之外,auth模块还提供很多有用的方法,比如:

logout(request[,next_page,template_name,redirect_field_name])

password_change(request[,template_name,post_change_redirect,password_change_form])

password_change_done(request[,template_name])

password_reset(request[,is_admin_site,template_name,email_template_name,password_reset_form,token_generator,post_reset_redirect,from_email])

password_reset_done(request[,template_name])


用法示例:

( r'^change_passwd/$' , 'django.contrib.auth.views.password_change' , {
'template_name' : 'change_passwd.html' ,
'post_change_redirect' : '/' ,
}),
( r'^reset_passwd/$' , 'django.contrib.auth.views.password_reset' , {
'template_name' : 'reset_passwd.html' ,
'email_template_name' : 'reset_passwd_email.html' ,
'post_reset_redirect' : '/reset_done/' ,
'from_email' : 'noreply@jihua.in' ,
}),
( r'^reset_confirm/(?P<uidb36>[0-9A-Za-z]{1,13})-(?P<token>[0-9A-Za-z]{1,13}-[0-9A-Za-z]{1,20})/$' , \
'django.contrib.auth.views.password_reset_confirm' , {
'template_name' : 'reset_confirm.html' ,
'post_reset_redirect' : '/signin/' ,
}
),
( r'^reset_done/$' , 'django.views.generic.simple.direct_to_template' , { 'template' : 'message.html' , 'extra_context' : {
'msg' : _( u'我们已将一封包含恢复密码步骤的邮件发到了您的邮箱,请查收' ),
}}),


参考:

Django认证模块(auth)https://docs.djangoproject.com/en/1.3/topics/auth/

Django设置参数(setting)https://docs.djangoproject.com/en/1.3/ref/settings/#std:setting-LOGIN_URL


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值