1. 程式人生 > >django之用戶認證組件

django之用戶認證組件

list 改密 spa stat login pwd 更新 信息 object

功能:用session記錄登陸驗證狀態

前提:用戶表:django自帶的auth_user

創建超級用戶:python manage.py createsuperuser

本質也是用的django-session,不過人家這個更嚴謹,更新賬戶的時候連著session_key一起換了。

基於用戶認證組件的登錄驗證信息儲存和註銷

views.py

from django.shortcuts import render, HttpResponse, redirect

# Create your views here.

from django.contrib import auth
from django.contrib.auth.models import
User def login(request): if request.method == POST: user = request.POST.get(user) pwd = request.POST.get(pwd) # if 驗證成功user對象,else返回none user = auth.authenticate(username=user, password=pwd) if user: auth.login(request, user) # request.user:當前登錄對象。如果沒有登錄,就是匿名登錄對象
return redirect(/index/) return render(request, login.html) def index(request): print(request user, request.user.username) # request user # 登錄成功: request user edward print(request.user.id) # None # 登錄成功:1 print(request.user.is_anonymous) # True # 登錄成功:False
# if request.user.is_anonymous: if not request.user.is_authenticated: return redirect(/login/) return render(request, index.html) def logout(request): auth.logout(request) return redirect(/login/)

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>index</title>
</head>
<body>

<!--  request.user是全局變量,可以直接在模板裏面用 -->

<h3>Hi, {{ request.user.id }}- {{ request.user.username }} </h3>
<a href="/logout">註銷</a>
    
</body>
</html>

註冊用戶組件

def reg(request):
    if request.method == POST:
        user = request.POST.get(user)
        pwd = request.POST.get(pwd)

        # User.objects.create(username=user,password=pwd)  # 不要用這種方法,這種方法是按照明文插入的
        user = User.objects.create_user(username=user, password=pwd)

        return redirect(/login/)
    return render(request, reg.html)

reg.html

<h3>註冊</h3>
<form action="" method="post">
    {% csrf_token %}
    <p>用戶名:<input type="text" name="user"></p>
    <p>密碼: <input type="text" name="pwd"></p>
    <input type="submit" value="提交">
</form>

API

from django.contrib import auth:

  1. if 驗證成功user對象,else返回None

    user = auth.authenticate(username=user,password=pwd)

  2. auth.login(request, user) # request.user:當前登錄對象。如果沒有登錄,就是匿名登錄對象。

  3. auth.logout(request)

from django.contrib.auth.models import User

  1. requeset.user.is_authenticated

  2. user = User.objects.create_user(username=‘‘, password=‘‘,email=‘‘)

補充

匿名用戶對象

 匿名用戶
    class models.AnonymousUser

    django.contrib.auth.models.AnonymousUser 類實現了django.contrib.auth.models.User 接口,但具有下面幾個不同點:

    id 永遠為None。
    username 永遠為空字符串。
    get_username() 永遠返回空字符串。
    is_staff 和 is_superuser 永遠為False。
    is_active 永遠為 False。
    groups 和 user_permissions 永遠為空。
    is_anonymous() 返回True 而不是False。
    is_authenticated() 返回False 而不是True。
    set_password()、check_password()、save() 和delete() 引發 NotImplementedError。
    New in Django 1.8:
    新增 AnonymousUser.get_username() 以更好地模擬 django.contrib.auth.models.User。

修改密碼

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

@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)

總結

if not : auth.login(request, user) request.user = AnonymousUser( )

else : request.user == 登錄對象

request.user是一個全局變量,在任何視圖和模板都可以直接使用。

於用戶認證組件的認證裝飾器

django為我們設計了一個用於檢查用戶是否已經通過了認證:login_requierd()

views.py

from django.contrib.auth.decorators import login_required

@login_required
def index(request):
    # print(‘request user‘, request.user.username)  # request user  # 登錄成功: request user edward
    # print(request.user.id)  # None    # 登錄成功:1
    # print(request.user.is_anonymous)  # True   #  登錄成功:False
    #
    # # if request.user.is_anonymous:
    # if not request.user.is_authenticated:
    #     return redirect(‘/login/‘)

    return render(request, index.html)

@login_required
def order(request):
    # if not request.user.is_authenticated:
    #     return redirect(‘/login/‘)

    return render(request, order.html)
def login(request):
    if request.method == POST:
        user = request.POST.get(user)
        pwd = request.POST.get(pwd)

        # if 驗證成功user對象,else返回none
        user = auth.authenticate(username=user, password=pwd)

        if user:
            auth.login(request, user)  # request.user:當前登錄對象。如果沒有登錄成功,就是匿名登錄對象

            # http://127.0.0.1:8000/login/?next=/index/
            next_url = request.GET.get(next, "/index/")
            # 動態獲取next後面的url(設置在settings.py裏面,也就是跳轉到哪裏的路徑),如果取不到就用/index/

            return redirect(next_url)

    return render(request, login.html)

settings.py

LOGIN_URL = /login/  # 跳轉路徑

django之用戶認證組件