欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

django的auth認證,authenticate和裝飾器功能詳解

 更新時間:2019年07月25日 09:33:04   作者:谷子的  
這篇文章主要介紹了django的auth認證,authenticate和裝飾器功能詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

在django中創(chuàng)建表,會自動創(chuàng)建一些django自帶的表,先了解用戶認證,

認證登錄 先要引用 ,

from django.contrib import auth

有很多方法,

網站先有登錄和認證,

authenticate(),提供用戶認證,驗證用戶名和密碼是否正確,一般需要username ,password兩個關鍵字參數(shù),

認證信息有效,返回有一個User對象。authrenticate()會在User對象上設置一個屬性標識,認證了該用戶,

創(chuàng)建一個Book表,然后生成數(shù)據(jù)庫

from django.db import models

# Create your models here.


class Book(models.Model):

  title = models.CharField(max_length=32)
  price = models.DecimalField(max_digits=5,decimal_places=2)

在pycharm里命令臺terminal 里創(chuàng)建一個超級用戶 root, 密碼 root123456

C:\Users\lenovo\PycharmProjects\auth_gu>python manage.py createsuperuser
Username (leave blank to use 'lenovo'): root
Email address:
Password:
Password (again):
This password is too short. It must contain at least 8 characters.
Password:
Password (again):
Superuser created successfully.

然后在auth_user 表中就有了剛才創(chuàng)建的信息

可以看到django是做了一層加密,

創(chuàng)建login頁面,

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

</head>
<body>

<form action="/login/" method="post">

{#  #}   {% csrf_token %}
  <p>姓名:<input type="text" name="user"></p>
  <p>密碼:<input type="password" name="pwd"></p>
  <input type="submit" value="提交">

</form>

</body>

</html>

當我提交的時候,會出現(xiàn)forbidden的情況,get請求不會出現(xiàn)這種情況,

因為在setting文件的中間件,不允許出現(xiàn)跨站請求,

別的網站第一次訪問我就發(fā)送post 請求,我的網站就拒絕,怎么拒絕,要區(qū)分第一次和第二次,y用cookie, 在cookie里加上csrf-token,下次請求時,cookie就有csrf-token ,就知道,已經登錄過了,不會再被forbidden掉了,

在form表單中添加 {% csrf_token %},

在前端頁面,檢查元素,就可以看到有了crsf-token ,是隱藏的狀態(tài),

------

在ajax請求的時候,也要加上csrf-token,

$.ajax({

  data:{csrfmiddlewaretoken:'{{csrf-token}}' },

}), 

-----

在views文件,使用authenticate()方法,從前端獲取用戶登錄的信息進行驗證,

def login(request):

  if request.method == "POST":

    user = request.POST.get("user")
    pwd = request.POST.get("pwd")
    #使用authenticate()方法
    auth.authenticate(username=user,password=pwd)
    print("user",user)
    print("pwd",pwd)

    return HttpResponse("ok")


  return render(request,"login.html")

在前端頁面,輸入剛才注冊的超級用戶,和密碼,登錄成功,后臺進行打印出用戶名和密碼,

user root
pwd root123456
[05/Dec/2017 10:04:41] "POST /login/ HTTP/1.1" 200 2

但現(xiàn)在存在一個問題,沒有cookie和session,如果換個瀏覽器,登錄index頁面,還是能直接直接登錄,

所以現(xiàn)在就可以直接用,login(request,User),就相當于設置了cookie和session, 在跳轉到index頁面親,跳轉

修改login函數(shù),因為與django里login()重名了,

def index(request):


  return render(request,'index.html')

#用django的認證方法,
def log_in(request):

  if request.method == "POST":

    user = request.POST.get("user")
    pwd = request.POST.get("pwd")
    #使用authenticate()方法
    auth.authenticate(username=user,password=pwd)
    print("user",user)
    print("pwd",pwd)

    if user is not None:#如果有這個用戶,跳轉到index頁面

      auth.login(request,user)    -------------------

      return redirect("/index/")

  return render(request,"log_in.html")

關于裝飾器login_required 和is_authenticated ()的功能一樣,就是不用判斷了

from django.shortcuts import render,HttpResponse,redirect

from django.contrib.auth.decorators import login_required
#與is_authenticate的工程一樣,

# Create your views here.

from django.contrib import auth
#auth 的3個方法,
#authenticate()
#login(HttpResquest,user)
#logout(request)



# @login_required,與is_authenticate 的功能一樣,就不用判斷,

#舉例說明
@login_required
def index2(request):
  # 可以加一個裝飾器,與is_authenticated()的功能一樣,@login_required
  # 先導入 from django.contrib.auth.decorators import login_required
  return render(request,"index.html")

#如果用戶沒有登錄,者跳轉到django默認的登錄URL"accounts/login/" ,可以以
#通過settings文件通過LOGIN_URL進行修改,并傳遞當前訪問的url的絕對路徑

def index(request):
  #打印一個user對象,利用user對象的is_tuthenticated方法做判斷,是否驗證過,返回布爾值,,做判斷
  #用戶登錄后才能訪問某些頁面,
  #沒有登錄就訪問,就直接跳到登錄頁面,
  #用戶跳轉到登錄頁面完成登錄,自動訪問跳轉到之前訪問的地址,
  print("=====>",request.user.is_authenticated())
  #=====> root
  # ,如果換個瀏覽器,就是AnonymousUser匿名,

  if request.user.is_authenticated():#已登錄

    return render(request,"index.html")
  else:
    return redirect("/log_in/")

  #登錄之前先驗證,

  return render(request,'index.html')



#用django的認證方法,
def log_in(request):

  if request.method == "POST":

    user = request.POST.get("user")
    pwd = request.POST.get("pwd")
    #使用authenticate()方法,得到一個User對象,做user驗證,
    user = auth.authenticate(username=user,password=pwd)
    print("user",user)
    print("pwd",pwd)

    if user is not None:#如果有這個用戶,跳轉到index頁面

      auth.login(request,user)#auth下的login() 方法,就相當于session+cookie,在跳轉到index頁面還要實現(xiàn)做判斷,

      return redirect("/index/")

  return render(request,"log_in.html")

-------------------------------

現(xiàn)在寫一個注冊功能,url路由

from django.conf.urls import url
from django.contrib import admin

from app01 import views

urlpatterns = [
  url(r'^admin/', admin.site.urls),
  url(r'^log_in/', views.log_in),
  url(r'^index/', views.index),
  url(r'^reg/', views.reg),
  url(r'^log_out/', views.log_out),
]

再寫一個reg頁面

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

</head>
<body>

<h1>注冊頁面</h1>

<h4>{{ error_message }}</h4>

<form action="/reg/" method="post">
  
  {% csrf_token %}
  <p>姓名:<input type="text" name="user"></p>
  <p>密碼:<input type="password" name="pwd"></p>
  <p>確認密碼:<input type="password" name="repeat_pwd"></p>
  <input type="submit">
</form>



</body>

</html>

在views 視圖函數(shù)中,

#注冊頁面
def reg(request):

  error_message = ""#放在全局
  if request.method=="POST":
    #獲取用戶輸入的數(shù)據(jù),存到數(shù)據(jù)庫前,要先判斷
    user = request.POST.get("user")
    pwd = request.POST.get("pwd")
    repeat_pwd = request.POST.get("repeat_pwd")


    #密碼不能為空,
    if not pwd or not repeat_pwd :
      error_message="密碼不能為空"

    elif not user :
      error_message="用戶名不能為空"

    elif repeat_pwd != pwd:
      error_message = "密碼不一致"
    elif User.objects.filter(username = user):

      error_message = "用戶已存在"

    else:
      #把用戶輸入的用戶名和密碼存到數(shù)據(jù)庫,但django做了一次加密,
  #所以就不能直接用,create的方法,要用User表的方法,create_user()
      User.objects.create_user(username = user,password = pwd)

      #注冊成功后,跳到登錄頁面
      return redirect("/log_in/")


  return render(request,"reg.html",{"error_message":error_message})

auth下的注銷功能,直接挑用logout()方法,

#注銷功能,清除掉cookie和session,
def log_out(request):
  #登錄的時候,用到了login()函數(shù),

  auth.logout(request)#清除了cookie和session,清除了當前的用戶,

  return redirect("/log_in/")

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • pycharm 關掉syntax檢查操作

    pycharm 關掉syntax檢查操作

    這篇文章主要介紹了pycharm 關掉syntax檢查操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • Python閉包與裝飾器原理及實例解析

    Python閉包與裝飾器原理及實例解析

    這篇文章主要介紹了Python閉包與裝飾器原理及實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • 在Python中將函數(shù)作為另一個函數(shù)的參數(shù)傳入并調用的方法

    在Python中將函數(shù)作為另一個函數(shù)的參數(shù)傳入并調用的方法

    今天小編就為大家分享一篇在Python中將函數(shù)作為另一個函數(shù)的參數(shù)傳入并調用的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Python用Jira庫來操作Jira

    Python用Jira庫來操作Jira

    這篇文章主要介紹了Python如何用Jira庫來操作Jira,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-12-12
  • python實現(xiàn)人性化顯示金額數(shù)字實例詳解

    python實現(xiàn)人性化顯示金額數(shù)字實例詳解

    在本篇內容里小編給大家整理了關于python實現(xiàn)人性化顯示金額數(shù)字實例內容,需要的朋友們可以參考下。
    2020-09-09
  • python中的變量命名規(guī)則詳情

    python中的變量命名規(guī)則詳情

    這篇文章主要介紹了python中的變量命名規(guī)則詳情,變量名可以包括字母、數(shù)字、下劃線,但是數(shù)字不能做為開頭,變量用的好或不好,和代碼質量有著非常重要的聯(lián)系,合理的使用變量,可以讓你的代碼可讀性更高并且更加簡潔,下面相關內容吧需要的小伙伴可以參考一下
    2022-03-03
  • 詳解Python中的字符串格式化

    詳解Python中的字符串格式化

    這篇文章主要為大家介紹了Python中的字符串格式化,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • python實現(xiàn)心型照片墻效果

    python實現(xiàn)心型照片墻效果

    這篇文章主要為大家詳細介紹了python實現(xiàn)心型照片墻效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Python批量將csv文件轉化成xml文件的實例

    Python批量將csv文件轉化成xml文件的實例

    將 csv 格式轉換成xml格式有許多方法,可以用數(shù)據(jù)庫的方式,也有許多軟件可以將 csv 轉換成xml。但是比較麻煩,本文利用 Python 一鍵批量將 csv 文件轉化成 xml 文件。
    2021-05-05
  • 詳解pandas.DataFrame.plot() 畫圖函數(shù)

    詳解pandas.DataFrame.plot() 畫圖函數(shù)

    這篇文章主要介紹了詳解pandas.DataFrame.plot()畫圖函數(shù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06

最新評論