Django的用户认证组件

技术Django的用户认证组件 Django的用户认证组件Django的用户认证组件
用户认证 
auth模块from django.contrib import authdjango.contrib.

Django的用户认证组件

Django的用户认证组件

用户认证 

auth模块

来自django.contrib import auth

django.contrib.auth中提供了很多方法,这里我们主要介绍其中的三种:

1.1 、authenticate()

提供用户身份验证,即验证用户名和密码是否正确,一般需要用户名和密码两个关键字参数。

如果身份验证信息有效,将返回一个用户对象。Authenticate()在User对象上设置一个属性,以标识哪个身份验证后端对用户进行了身份验证,并且在以后的登录过程中需要该信息。当我们试图登录一个未经身份验证就直接从数据库中取出的用户对象()时,我们将报告一个错误!

用户=验证(用户名='某人',密码='somepassword ')

1.2 、login(HttpRequest, user)  

该函数接受一个HttpRequest对象和一个经过身份验证的用户对象。

该函数使用django的会话框架将会话id等信息附加到经过身份验证的用户。

从django.contrib.auth导入authenticate,登录

def my_view(请求):

用户名=请求。开机自检['用户名']

密码=请求。开机自检['密码']

用户=验证(用户名=用户名,密码=密码)

如果用户不是非:

登录(请求、用户)

#重定向至成功页面。

.

else:

#返回“无效登录”错误消息。

.

1.3 、logout(request) 注销用户  

来自django.contrib.auth导入注销

def注销_查看(请求):

注销(请求)

#重定向至成功页面。

该函数接受一个没有返回值的HttpRequest对象。调用此函数时,当前请求的所有会话信息都将被清除。即使用户没有登录,使用此功能也不会报告错误。

User对象

用户属性:用户名、密码(必需)密码通过哈希算法保存到数据库。

2.1 、user对象的 is_authenticated()

如果它是一个真实的用户对象,返回值总是真。用于检查用户是否通过身份验证。通过身份验证并不意味着用户拥有任何权限,甚至不会检查用户是否处于活动状态。这只是意味着用户已经成功通过了身份验证。这个方法很重要。在后台,使用request.user.is_authenticated()判断用户是否已经登录。如果为真,可以向前台显示request.user.name。

要求:

1用户登录后只能访问部分页面,

如果用户没有登录就访问这个页面,直接跳转到登录页面。

3.用户在跳转的登录界面完成登录后,自动访问跳转到之前访问过的地址。

方法1:

def my_view(请求):

如果没有请求,user.is_authenticated():

返回重定向(' %snext=%s' %(设置。LOGIN_URL,request.path))

方法2:

django已经为我们设计好了一个用于此种情况的装饰器:login_requierd()

来自django.contrib.auth.deco

rators import login_required

@login_required
def my_view(request):
...

若用户没有登录,则会跳转到django默认的 登录URL '/accounts/login/ ' (这个值可以在settings文件中通过LOGIN_URL进行修改)。并传递 当前访问url的绝对路径 (登陆成功后,会重定向到该路径)。

2.2 、创建用户

使用 create_user 辅助函数创建用户:

from django.contrib.auth.models import User
user = User.objects.create_user(username='',password='',email='')

2.3 、check_password(passwd)

用户需要修改密码的时候 首先要让他输入原来的密码 ,如果给定的字符串通过了密码检查,返回 True

2.4 、修改密码

使用 set_password() 来修改密码

user = User.objects.get(username='')
user.set_password(password='')
user.save

2.5 、简单示例

注册:

def sign_up(request):
 
    state = None
    if request.method == 'POST':
 
        password = request.POST.get('password', '')
        repeat_password = request.POST.get('repeat_password', '')
        email=request.POST.get('email', '')
        username = request.POST.get('username', '')
        if User.objects.filter(username=username):
                state = 'user_exist'
        else:
                new_user = User.objects.create_user(username=username, password=password,email=email)
                new_user.save()
 
                return redirect('/book/')
    content = {
        'state': state,
        'user': None,
    }
    return render(request, 'sign_up.html', content)  

修改密码:

@login_required
def set_password(request):
    user = request.user
    state = None
    if request.method == 'POST':
        old_password = request.POST.get('old_password', '')
        new_password = request.POST.get('new_password', '')
        repeat_password = request.POST.get('repeat_password', '')
        if user.check_password(old_password):
            if not new_password:
                state = 'empty'
            elif new_password != repeat_password:
                state = 'repeat_error'
            else:
                user.set_password(new_password)
                user.save()
                return redirect("/log_in/")
        else:
            state = 'password_error'
    content = {
        'user': user,
        'state': state,
    }
    return render(request, 'set_password.html', content)

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/143794.html

(0)

相关推荐

  • 宋仁宗为什么无子,宋仁宗为什么一生没有儿子

    技术宋仁宗为什么无子,宋仁宗为什么一生没有儿子据史料记载,宋仁宗本来生育了有三个儿子,十五个女儿宋仁宗为什么无子。但是这十八个孩子只有四个女儿长大成人,其他都在出生后不久就死了,包括三个皇子。宋仁宗赵祯(1010年5月1

    生活 2021年10月19日
  • solr全文检索(solr搜索)

    技术solr4.7如何建立索引本篇内容主要讲解“solr4.7如何建立索引”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“solr4.7如何建立索引”吧!solr的建立索引的方

    攻略 2021年12月22日
  • Flink 的运行架构详细剖析

    技术Flink 的运行架构详细剖析 Flink 的运行架构详细剖析1. Flink 程序结构
    Flink 程序的基本构建块是流和转换(请注意,Flink 的 DataSet API 中使用的 DataS

    礼包 2021年11月4日
  • MySQL数据库的建模工具都有哪些

    技术MySQL数据库的建模工具都有哪些这篇文章将为大家详细讲解有关MySQL数据库的建模工具都有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。数据库建模和设计是软件开

    攻略 2021年11月4日
  • 如何使用SPNEGO配置身份验证

    技术如何使用SPNEGO配置身份验证这篇文章给大家介绍如何使用SPNEGO配置身份验证,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Cloudera Manager 6.3和更高版本支持使用SPNE

    攻略 2021年11月10日
  • Oracle中闪回区存储空间报ORA-19815问题怎么办

    技术Oracle中闪回区存储空间报ORA-19815问题怎么办这篇文章给大家分享的是有关Oracle中闪回区存储空间报ORA-19815问题怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

    攻略 2021年11月11日