溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

發(fā)布時(shí)間:2020-10-19 11:47:05 來源:腳本之家 閱讀:176 作者:Blue·Sky 欄目:開發(fā)技術(shù)

1、安裝

pip install djangorestframework

django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

2、創(chuàng)建項(xiàng)目及應(yīng)用

創(chuàng)建項(xiàng)目

創(chuàng)建應(yīng)用

目錄結(jié)構(gòu)如圖

django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

3、設(shè)置settings.py

設(shè)置數(shù)據(jù)庫連接

# MySQL 增加mysql 連接
DATABASES = {
 'default':{
  'ENGINE':'django.db.backends.mysql',
  'HOST':'127.0.0.1',
  'PORT':'3306',
  'NAME':'dbname', # 數(shù)據(jù)庫名
  'USER':'username',
  'PASSWORD':'password',
  'OPTIONS':{
   'sql_mode': 'traditional'
  },
 }
}

添加應(yīng)用

# Application definition
INSTALLED_APPS = [
  ...
 'rest_framework',
 'api',
]

4、創(chuàng)建用戶信息models,在models.py

from django.db import models
# Create your models here.
class User(models.Model):
 username = models.CharField(max_length=32,unique=True)
 password = models.CharField(max_length=32)
 class Meta:
  db_table = 'user'
  verbose_name = verbose_name_plural = '用戶信息表'
class userToken(models.Model):
 username = models.OneToOneField(to='User',on_delete=models.DO_NOTHING)
 token = models.CharField(max_length=60)
 class Meta:
  db_table = 'user_token'
  verbose_name = verbose_name_plural = '用戶token表'

在項(xiàng)目下執(zhí)行命令生成數(shù)據(jù)表

python manage.py makemigrations 
python manage.py migrate 

5、在views.py 文件里,編寫登錄驗(yàn)證程序

from django.shortcuts import render
# Create your views here.
import time
from api import models
from django.http import JsonResponse
from rest_framework.views import APIView
class AuthView(APIView):
 def post(self,request,*args,**kwargs):
  ret = {'code':1000,'msg':None}
  try:
   # 參數(shù)是datadict 形式
   usr = request.data.get('username')
   pas = request.data.get('password')
   # usr = request._request.POST.get('username')
   # pas = request._request.POST.get('password')
   # usr = request.POST.get('username')
   # pas = request.POST.get('password')
   print(usr)
   # obj = models.User.objects.filter(username='yang', password='123456').first()
   obj = models.User.objects.filter(username=usr,password=pas).first()
   print(obj)
   print(type(obj))
   print(obj.username)
   print(obj.password)
   if not obj:
    ret['code'] = '1001'
    ret['msg'] = '用戶名或者密碼錯(cuò)誤'
    return JsonResponse(ret)
    # 里為了簡(jiǎn)單,應(yīng)該是進(jìn)行加密,再加上其他參數(shù)
   token = str(time.time()) + usr
   print(token)
   models.userToken.objects.update_or_create(username=obj, defaults={'token': token})
   ret['msg'] = '登錄成功'
   #ret['token'] = token
  except Exception as e:
   ret['code'] = 1002
   ret['msg'] = '請(qǐng)求異常'
  return JsonResponse(ret)

6、在urls.py設(shè)置訪問路徑

from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from api.views import AuthView
urlpatterns = [
 path('admin/', admin.site.urls),
 url(r'^api/v1/auth/$', AuthView.as_view()),
]

7、通過postman驗(yàn)證登錄接口

django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

如圖顯示登錄成功。

遇到的坑:

views獲取Post參數(shù)的方式:

# 如下有三種方式獲取參數(shù),有些文章介紹,必須使用第二種,
# 其實(shí)不然,具體使用哪種要看參數(shù)的傳入形式而定,建議使用第一種,
#因?yàn)榈谝环N支持key-value 和 json 格式 ,后面兩種僅支持 key-value.
usr = request.data.get('username')
pas = request.data.get('password')
# usr = request._request.POST.get('username')
# pas = request._request.POST.get('password')
# usr = request.POST.get('username')
# pas = request.POST.get('password')

postman 配置

1、如圖,如果沒有選擇設(shè)置content-type,則參數(shù)要選擇 form-data,上面獲取參數(shù)的方式 三種皆可。

django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

2、如果選擇了content-type為application/json,則body 要選擇raw ,如圖

django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解

而此時(shí)獲取參數(shù)的方式只能選擇第一種。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI