Django--csrf跨站請求僞造、Auth認證模塊

form表單中使用跨站請求僞造

  { % csrf_token % }
  會動態生成一個input框,內部的value是隨機刷新的

 

 

如果不想校驗csrf

  from django.views.decorators.csrf import csrf_exempt, csrf_protect

  然後在不想裝飾的函數的上面加上@csrf_exempt

  

如果只想校驗單獨一個的話就在那個函數的上面加上@csrf_protect

 

 

 

在CBV中添加csrf就是通過導入第三方模塊

  from django.utils.decorators import method_decorator

  然後在方法上面利用method_decorator進行裝飾,第一個參數傳的是csrf_protect,第二個參數name要制定方法

 

csrf_protect在裝飾的時候跟正常的CBV的裝飾器一樣,也是三種方式都可以的

csrf_exempt只能有下面兩種方式

@method_decorator(csrf_exempt, name='dispatch')
class Index(View):
    @method_decorator(csrf_exempt)
    def dispatch(self, request, *args, **kwargs):
        super().dispatch(request, *args, **kwargs)

 

 

Auth模塊: 

  命令行創建超級用戶

    createsuperuser

  Auth模塊是Django自帶的用戶認證模塊

    我們在開發一個網站的時候,無可避免的需要設計實現網站的用戶系統。此時我們需要實現包括用戶註冊、用戶登錄、用戶認證、註銷、修改密碼等功能

    Django內置了強大的用戶認證系統--auth, 它默認使用auth_user表來存儲用戶數據

 

  auth模塊常用的方法:

    authenticate()

      提供了用戶認證功能,即驗證用戶名以及密碼是否正確,一般需要username、password兩個關鍵字參數 

      如果認證成功,便會返回一個User對象

      authenticate()會在該User對象上設置一個屬性來標識後端已經認證了該用戶,並且該信息在後續的登陸過程中是需要的

  

    login(HttpRequest,user)

      該函數接受一個HttpRequest對象,以及一個認證過的User對象

      該函數實現一個用戶登錄的功能,它本質上會在後端爲該用戶生成相關的session數據

 

    logout(request)

      該函數沒有返回值

      當調用該函數時,當前請求session會被全部清除。該用戶即使沒有登錄,使用該函數也不會報錯

 

    is_authenticated()

      用來判斷當前請求是否通過了認證

  

    login_required()  

      auth給我們提供的一個裝飾器工具,用來快捷給某個視圖函數添加登錄校驗

from django.contrib.auth.decorators import login_required
      
@login_required
def my_view(request):
  ...

 

      若用戶沒有登錄,就會跳轉到Django默認的登錄URL '/accounts/login/ ' 並傳遞當前訪問url的絕對路徑(若登陸成功後,會重定向到該路徑)。

      如果需要自定義登錄到URL,則需要在settings.py文件中通過LOGIN_URL進行修改

LOGIN_URL = '/login/'  # 這裏配置成你項目登錄頁面的路由

    create_user()

      auth提供的一個創建新用戶的方法,需要提供必要的參數(username, password)等

from django.contrib.auth.models import User
user = User.objects.create_user(username='用戶名',password='密碼',email='郵箱',...)

    

    create_superuser()

      auth提供的一個創建新用戶的方法,需要提供必要的參數(username, password)等

from django.contrib.auth.models import User
user = User.objects.create_superuser(username='用戶名',password='密碼',email='郵箱',...)

 

      

    check_password(password)

      auth提供的一個檢查密碼是否正確的方法,需要提供當前請求用戶的密碼,密碼正確就返回True,否則就返回False

ok = user.check_password('密碼')

 

  

    set_password(password)

      auth提供的一個修改密碼的方法,接受要設置的新密碼 作爲參數

      注意:設置完一定要調用用戶對象的save方法       

user.set_password(password='')
user.save()

 

  

@login_required
def set_password(request):
    user = request.user
    err_msg = ''
    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:
                err_msg = '新密碼不能爲空'
            elif new_password != repeat_password:
                err_msg = '兩次密碼不一致'
            else:
                user.set_password(new_password)
                user.save()
                return redirect("/login/")
        else:
            err_msg = '原密碼輸入錯誤'
    content = {
        'err_msg': err_msg,
    }
    return render(request, 'set_password.html', content)

 

 

 

    User對象的屬性

      username、password

      is_staff:用戶是否擁有網站的管理權限

      is_active:是否允許用戶登錄,設置爲False,可以在不刪除用戶的前提下禁止用戶登錄

 

  擴展默認的auth_user表

    auth_user表的字段就那麼幾個,我在項目中沒辦法直接拿來使用,比如我想要存儲一個用戶的手機號的字段,首先想到的肯定是一對一進行表與表之間的關聯

    我們可以通過繼承內置的AbstractUser類,來自定義一個Model類,這樣既可以根據項目需求靈活的設計用戶表,又能使用Django強大的認證系統了

from django.contrib.auth.models import AbstractUser
class UserInfo(AbstractUser):
    """
    用戶信息表
    """
    nid = models.AutoField(primary_key=True)
    phone = models.CharField(max_length=11, null=True, unique=True)
    
    def __str__(self):
        return self.username

    按上面的方式擴展了內置的auth_user表之後,一定要在settings.py中告訴Django,我現在使用我新定義的UserInfo表來做用戶的認證,

# 引用Django自帶的User表,繼承使用時需要設置
AUTH_USER_MODEL = "app名.UserInfo"

    一旦我們指定了新的認證系統所使用的的表,我們就需要重新在數據庫中創建該表,而不能繼續使用原來默認的auth_user表了

 

 

 

 

 

 

 

 

 

    

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章