django rest_framework 前端網頁實現Token認證

rest_framework提供了幾種認證方式:Session、Token等。Session是最簡單的,幾乎不用寫任何代碼就可以是實現,Token方式其實也不復雜,網上的教程一大把,但是最后都是用Postman這類工具來實現API調用的,通過這類工具來增加HTTP頭信息以回傳Token。那么真正的前端網頁應該怎么辦呢?網上基本上就是基于Aixos來實現的,但是我就不想用Vue,純Javascript是不能改寫HTTP頭的。怎么辦?

首先,看一下TokenAuthentication的源碼:

auth = request.META.get('HTTP_AUTHORIZATION', b'')

它是從HTTP頭中讀取Authorization,其中是的內容Token(固定字) Token(值)。

那既然JavaScript不能改寫頭,但是能用cookie啊,所以我就通過自定義TokenAuthentication類,讀取Cookie來實現。

1. 用戶登錄之后先創建Token,并返回給前端。

2. 前端把Token保存到Cookie。

$.ajax({url: "login",type:'POST',data: {'username':username,'password':password},dataType: "json",success: function (data) {   //請求成功后執行的操作if (data.status == "SUCCESS") {//localStorage.setItem('token',data.token);$.cookie('token', data.token);window.location.href = '/';}else{alert('Invalid username or password.');}}
});

這樣每次發起HTTP請求時都會把Token帶上

3. 在logout的時候把Token刪除。防止失效Token仍然可以使用。

def logout_view(request):request.user.auth_token.delete()logout(request)return redirect('login')

4. 寫一個自定義的TokenAuthentication類:

from rest_framework.authentication import BaseAuthentication
from rest_framework.exceptions import AuthenticationFailed
from rest_framework.authtoken.models import Tokenclass CustomTokenAuthentication(BaseAuthentication):keyword = 'token'def authenticate(self, request):cookie_token = request.COOKIES.get(self.keyword)if cookie_token is None:raise AuthenticationFailed('No Token Found in Cookies!')try:user_token = Token.objects.get(key=cookie_token)if user_token is None:raise AuthenticationFailed('No Token Found for Current User!')return (user_token.user, user_token)except Token.DoesNotExist:raise AuthenticationFailed('Token in cookie is invalidate!')

當Token未提供或者無效時,直接拋出AuthenticationFailed異常

5. 講自定義的類放入項目的settings,否則不生效:

REST_FRAMEWORK = {'DEFAULT_AUTHENTICATION_CLASSES': ('bid_request_system_app.commons.authentications.CustomTokenAuthentication','rest_framework.authentication.SessionAuthentication',),
}

6. 在相對應的view方法前面加上相應的注解:

@api_view(['GET', 'POST'])
@csrf_exempt
@login_required()
@authentication_classes([CustomTokenAuthentication])
@permission_classes([IsAuthenticated, IsAdminUser])
def department_management_view(request):

這樣的話就OK了。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/85665.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/85665.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/85665.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

面試題-函數類型的重載是啥意思

在 TypeScript 中,函數重載(Function Overload) 是指為同一個函數提供多個不同的調用簽名(參數類型和返回值類型的組合),但函數體只有一個實現。這樣可以讓函數在不同的輸入下表現出不同的行為,…

磐基PaaS平臺MongoDB組件SSPL許可證風險與合規性分析(上)

#作者:任少近 文章目錄 1.背景與問題1.1.背景1.2.問題 3.SSPL條款解讀分析3.1.條款0:定義條款3.2.條款一:源代碼條款3.3.條款二:基本授權條款3.4.條款三:反規避保護條款3.5.條款四:逐字傳播條款3.6.條款五…

「Linux文件及目錄管理」輸入輸出重定向與管道

知識點解析 輸入/輸出重定向 標準輸入(stdin):默認從鍵盤讀取,文件描述符為0。標準輸出(stdout):默認輸出到終端,文件描述符為1。標準錯誤(stderr):默認輸出到終端,文件描述符為2。重定向符號: >:覆蓋輸出到文件(如command > file)。>>:追加輸出…

【Node】最佳Node.js后端開發模板推薦

Node.js 后端開發模板推薦 以下是幾個優秀的Node.js后端模板,它們都適合二次開發,各自有不同的特點和適用場景: 1. Express基礎模板 Express Generator (官方工具) 官方提供的快速搭建工具基礎MVC結構簡單易上手 npm install express-ge…

HALCON相機標定

相機標定簡介: 首先,相機會產生畸變,即實際圖像和拍攝圖像不一致,可以是凸性也可以是凹性形變,相機標定的過程就是將畸變圖像還原為原始圖像,并將圖像中的像素坐標轉換為世界坐標。 形如:相機內…

Solidity 入門教程(二):值類型全解 —— 布爾、整數、地址與字節數組

在上一章中,我們寫下了第一個 Solidity 合約并在 Remix 中成功運行。本章我們將深入了解 Solidity 中的幾種常用值類型(Value Types),并通過示例代碼在 Remix 進行驗證。 一、Solidity 中的三種數據類型 在 Solidity 中&#xf…

16.大數據監控

0.說明 監控主要構成。 軟件版本。 1.exporter監控配置 1.1 node_exporter 啟動命令 nohup ./node_exporter &服務 創建文件 /etc/systemd/system/node_exporter.service: [Unit] DescriptionPrometheus Node Exporter Wantsnetwork-online.target Aft…

Tomcat項目本地部署(Servlet為例)

在Windows上部署 在idea中打開項目 首先我們需要準備一個Servlet項目,我之前的Servlet項目是用eclipse寫的,這種情況下如果用idea直接打開的話會出現左側目錄無法顯示的情況,這個時候我們就需要用別的方法打開 打開項目管理 如下圖&#…

安裝MySQL 5.7導入數據,修改密碼,創建賬號并授權

1. 準備工作 sudo yum update -y sudo yum install -y wget libaio numactl 2. 下載 MySQL 5.7 二進制包 wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz 3. 創建 MySQL 用戶和組 sudo groupadd mysql sudo useradd -r -g m…

基礎RAG實現,最佳入門選擇(八)

RAG重排序 RAG重排序技術以提高RAG系統中的檢索質量。重新排序充當初始檢索后的第二個過濾步驟,以確保最相關的內容用于響應生成。 重排序的關鍵概念 1.初始檢索:使用基本相似度搜索的第一遍(準確度較低但速度更快) 2.文檔評分…

Spring Boot 常用注解整理

Spring & Spring Boot 常用注解整理 現代的 Spring 與 Spring Boot 應用大量使用注解來簡化配置、管理組件和實現各種框架功能。本文系統整理了常用的 Spring/Spring Boot 注解,按照功能分類進行介紹。每個注解都會涵蓋其含義、提供來源、應用場景以及代碼示例…

深入理解 Cross-Entropy 損失函數:從原理到實踐

在深度學習中,損失函數是衡量模型性能的關鍵指標之一。對于多分類問題,Cross-Entropy 損失函數 是最常用的選擇之一。它不僅能夠有效衡量模型輸出與真實標簽之間的差異,還能通過梯度下降法指導模型的優化。本文將深入探討 Cross-Entropy 損失…

Vim-vimrc保存文件自動移除行末尾空格

Vim-vimrc保存文件自動移除行末尾空格 這段代碼通過設置 autocmd 和自定義函數,確保每次保存文件時都自動刪除文件中的行尾空格,同時不會影響光標和視圖的位置。它適用于所有文件類型,并且刪除操作不會引入錯誤,即使沒有行尾空格的…

Occt幾何內核快速入門

本文簡單介紹 Open Cascade Technology(OCCT),提供了下載地址和文檔地址。通過OCCT的測試工具Draw,展示了OCCT的一些功能特性。介紹了OCCT集成開發的演示代碼,提供了源代碼下載地址和編譯過程文件。 一、簡介 Open C…

【Docker 08】Compose - 容器編排

🌈 一、Docker Compose 介紹 ? 1. Docker Compose 是什么 Docker Compose 是由 Docker 官方提供的一個用于定義和運行多容器應用的工具,它讓用戶可以通過一個 YAML 文件(通常是 docker-compose.yml)來配置應用所需要的服務&…

CentOS Stream 9平臺部署安裝MySQL8.4.1

1、在線下載安裝包 [rootlocalhost ~]# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.4.1-1.el9.x86_64.rpm-bundle.tar 2、新建解壓文件夾 [rootlocalhost ~]#mkdir /root/sql 3、離線解壓安裝包安裝配置MySQL8 上傳安裝包到home下 [rootlocalhost ~]#c…

phpstorm無縫切換vscode

要將 PhpStorm 的開發體驗無縫遷移到 VS Code,需重點配置插件、快捷鍵和操作習慣。以下是詳細方案: 一、必備插件清單 安裝以下插件(VS Code 搜索安裝): PHP Intelephense:核心插件(代碼補全、…

雨聲_錦程_時年

1 炎涼 飄零于三界。 子銘師傅看了幾卷筆記,以為我文筆很好,于是我留在石銘公社。 我每日在公社會議廳,高地吹風,悠然筆記。 我喜歡四處旅行。 穿著鞘翅飛翔,風劃過耳邊。 我渴求所飲的每一滴水,追憶木履留…

微信小程序使用rsa 加解密

jsencrypt.min.js !function(t,e){"object"typeof exports&&"undefined"!typeof module?e(exports):"function"typeof define&&define.amd?define(["exports"],e):e(t.JSEncrypt{})}(this,function(t){"use s…

2025北郵軟件工程復習

文章目錄 廢話知識點總結Part1 軟件工程概述Part2 軟件需求分析需求介紹需求描述方法 Part3 軟件設計方法軟件設計的概念與原則軟件設計的方法 Part4 程序實現方法Part5 軟件測試方法白盒測試黑盒測試 練習題北郵2021~2022期末考北郵2018期末考 考后總結 廢話 update on 4.24&…