Django中 @login_required用法简介

我们在网站开发过程中,经常会遇到这样的需求:

  • 用户登陆系统才可以访问某些页面
  • 如果用户没有登陆而直接访问就会跳转到登陆界面,而不能访问其他页面。
  • 用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地址

要实现这样的需求其实很简单:

  1. 使用django自带的装饰器 @login_required。
  2. 在相应的view方法的前面添加@login_required
  3. 并在settings.py中配置LOGIN_URL参数
  4. 修改login.html中的表单action参数

view.py设置:

from djanco.contrib.auth.decorators import login_required
from django.shortcuts import render_to_response
from django.http import HttpResponse

@login_required
def myview(request):
    return render_to_response(‘index.html‘)

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

setting.py设置:

....
LOGIN_URL = ‘/accounts/login/‘  #这个路径需要根据你网站的实际登陆地址来设置
....

urls.py设置:

from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
    url(r‘^admin/‘, admin.site.urls),
    url(r‘^, views.index),
    url(r‘^accounts/login/, views.acc_login),
    url(r‘^logout/, views.acc_logout),
    url(r‘^host/, views.host, name=‘host‘),
    url(r‘^asset/, views.asset,name=‘asset‘),
    url(r‘^audit/, views.audit,name=‘audit‘),
]

如果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.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 -->

其他有用方法

除了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‘: ‘[email protected]‘,
}),
(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‘我们已将一封包含恢复密码步骤的邮件发到了您的邮箱,请查收‘),
}}),
时间: 2024-07-31 13:13:10

Django中 @login_required用法简介的相关文章

【Django】@login_required用法简介

在django项目中,经常会看到下面这样的代码: [python] view plain copy from django.contrib.auth.decorators import login_required @login_required def my_view(request): ... 里面有一个@login_required标签.其作用就是告诉程序,使用这个方法是要求用户登录的. 1.如果用户还没有登录,默认会跳转到'/accounts/login/'.这个值可以在settings

Django中的信号简介

Django中的信号 在现实中,我们会遇到各种各样的需求,比如对客户端请求进行过滤,将满足某些条件的客户端请求过滤掉,此时,我们可以利用Django的中间件来实现该需求,或者,我们希望每次model的save()方法被调用前后,都要写一条日志到日志文件中,此时,我们可以通过Django提供的内置信号post_save来实现,本文我们将要介绍Django的高级功能信号. 信号的概念 简单点说,Django框架内部包含了一个信号调度器,它的作用是可以将框架内部发生的任何操作都通知到功能独立的应用程序

列表[‘hello’ , ‘python’ ,’!’ ] 用多种方法拼接,并输出’hello python !’ 以及join()在python中的用法简介

列表['hello' , 'python' ,'!' ] 用多种方法拼接,并输出'hello python !' 使用字符串链接的四种方法都可以创建 字符串拼接一共有四种方法,也可以应用到列表的拼接中 a = ['hello','python','!'] 第一种是用类似字符串相加的方法 #a[0] + ' ' + a[1] + ' ' + a[2] 第二种是用%s 连接起来 #'%s %s %s'%(a[0],a[1],a[2]) 第三种是用 join 连接起来 '''这里先普及join()在p

@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参数来设定.(后面还会

django中tag的用法

新建一个tags.py from django import templateregister = template.Library() def short_msg(value): if len(value) > 50: return value[:50]+" ......" else: return value register.filter('short_msg', short_msg) 在html页面中 {% extends "base.html" %}

Android中Toast的用法简介

转自:http://www.cnblogs.com/GnagWang/archive/2010/11/26/1888762.html Toast是Android中用来显示显示信息的一种机制,和Dialog不一样的是,Toast是没有焦点的,而且Toast显示的时间有限,过一定的时间就会自动消失.下面用一个实例来看看如何使用Toast. 1.默认效果 代码 Toast.makeText(getApplicationContext(), "默认Toast样式",     Toast.LEN

Django中的信号及其用法

Django中提供了"信号调度",用于在框架执行操作时解耦. 一些动作发生的时候,系统会根据信号定义的函数执行相应的操作 Django中内置的signal Model_signals pre_init # Django中的model对象执行其构造方法前,自动触发 post_init # Django中的model对象执行其构造方法后,自动触发 pre_save # Django中的model对象保存前,自动触发 post_save # Django中的model对象保存后,自动触发 p

Django中ajax的基本用法

初识Ajax: ? Ajax并不是一门新的语言,它其实就是基于js写的一个功能模块而已 由于原生js书写ajax较为繁琐,django中我们一般直接使用jQuery封装好的ajax模块 案例: ? 页面上有是三个input框,一个按钮,用户在前两个框中输入数字,点击按钮保证页面不刷新的情况下将数据发到后端做计算,再将计算好的结果发送给前端展示到第三个input框中 ajax基本语法结构 $.ajax({ // 1. 到底朝哪个后端提交数据 url:'', // 控制数据的提交路径 (有三种方法,

Celery在Django中的使用介绍

Celery在Django中的使用介绍 Celery简介 celery是一个简单.灵活且可靠的,处理大量消息的分布式系统,并且提供维护这样一个系统的必须工具. 它是一个专注于实时处理的任务队列,同时也支持任务调度. 何为任务队列 任务队列:是一种在线程和机器间分发任务的机制. celery的三大组成部分 worker 任务执行单元-->Worker是Celery提供的任务执行的单元,worker并发的运行在分布式的系统节点中. broker(存tasks的仓库) 消息中间件--> Celery