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)

相关推荐

  • 如何编写eosjs传输代码

    技术eosjs转账代码怎么写eosjs转账代码怎么写,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。下面介绍使用V20版本的eosjs实现代币转账的思路,并给

    攻略 2021年12月14日
  • Go语言中什么是互斥锁

    技术Go语言中什么是互斥锁这篇文章将为大家详细讲解有关Go语言中什么是互斥锁,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、互斥锁Mutex1.1 Mutex介绍Go

    攻略 2021年10月21日
  • 如何使用hystrix的配置

    技术如何使用hystrix的配置这篇文章主要介绍“如何使用hystrix的配置”,在日常操作中,相信很多人在如何使用hystrix的配置问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使

    攻略 2021年10月21日
  • linux部署php和apache如何联动呢(linux配置apache服务器全攻略)

    技术Linux下Apache服务如何部署和配置这篇文章主要为大家展示了“Linux下Apache服务如何部署和配置”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux下A

    攻略 2021年12月20日
  • mysqlcount和countid(mysql的count能count几个)

    技术MySQL中的count(*)和count(1)哪个更快这篇文章主要讲解了“MySQL中的count(*)和count(1)哪个更快”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来

    攻略 2021年12月21日
  • 数据库中表连接方式有哪些

    技术数据库中表连接方式有哪些这篇文章将为大家详细讲解有关数据库中表连接方式有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 1 nested loop

    攻略 2021年11月20日