」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 掌握 Django:從頭開始建立安全的使用者身份驗證 API

掌握 Django:從頭開始建立安全的使用者身份驗證 API

發佈於2024-08-31
瀏覽:889

``## 第四天
#100daysofMiva 编码挑战已经开始四天了。 ???

?深入了解 Django:从头开始构建安全的用户身份验证 API!

您准备好将您的 Django 技能提升到下一个水平吗? ?在本教程中,我将指导您使用 Django 创建强大的用户身份验证 API。无论您是经验丰富的开发人员还是新手,本分步指南都将引导您完成设置用户注册、登录和基于令牌的身份验证。

在本课程结束时,您将充分了解如何

  1. 设置 Django 项目并配置必要的包
  2. 为用户数据创建和自定义序列化器
  3. 构建视图来处理用户注册和身份验证
  4. 实施基于令牌的身份验证以实现安全 API 访问
  5. 加入我们,我们将空白画布转变为强大的身份验证系统,并在您的 Django 之旅中解锁新的可能性! ??

让我们开始编码吧! ?✨

Mastering Django: Building a Secure User Authentication API from Scratch

第 1 步:设置 Django 环境:

为此,您需要安装python:通过运行以下命令确保Python安装
macOS/Linux:
Python 通常是预先安装的。您可以通过运行来检查:
Mastering Django: Building a Secure User Authentication API from Scratch
或者
Mastering Django: Building a Secure User Authentication API from Scratch
如果需要,通过 Homebrew (macOS) 或包管理器 (Linux) 安装 Python:
Mastering Django: Building a Secure User Authentication API from Scratch

视窗:

  • 从 python.org 下载并安装 Python。
  • 确保选中该框以在安装过程中将 Python 添加到您的 PATH。

步骤 2. 设置虚拟环境:

macOS/Linux:

创建并激活虚拟环境:

Mastering Django: Building a Secure User Authentication API from Scratch

视窗:

创建并激活虚拟环境:

Mastering Django: Building a Secure User Authentication API from Scratch

步骤 3. 安装 Django 和软件包

现在没有软件包的框架是什么?...让我们安装我们需要的软件包。?
激活虚拟环境后,安装 Django 和其他软件包的命令在所有操作系统上都是相同的:

Mastering Django: Building a Secure User Authentication API from Scratch
解释:
`

  1. djangorestframework:这是一个强大而灵活的工具包,用于使用 Django 构建 Web API。
  2. djangorestframework-simplejwt:此包提供 JSON Web Token (JWT) 身份验证,通常用于安全 API 身份验证。

步骤 4. 创建并配置 Django 项目

macOS/Linux/Windows:

创建 Django 项目和应用程序:

Mastering Django: Building a Secure User Authentication API from Scratch
让我们简化必要的事情:

  1. startproject1:此命令创建一个新的 Django 项目。项目是 Django 实例的设置集合,包括数据库配置、特定于 Django 的选项和特定于应用程序的设置。
  2. startapp:这会在项目中创建一个新应用程序。应用程序是项目的组件,用于处理特定功能(例如用户管理)。

步骤 5. 更新项目设置

所有操作系统:

修改settings.py以包含您的应用程序和已安装的软件包。
文件:auth_project/settings.py

Mastering Django: Building a Secure User Authentication API from Scratch

解释一下?:

INSTALLED_APPS:您可以在此处注册应用程序和第三方软件包。在这里,您添加rest_framework用于API功能,rest_framework_simplejwt用于JWT身份验证,以及用户(您创建的应用程序)用于管理用户相关任务。

一次不知道所有步骤也没关系...只需要练习,你就会做对的

我希望你能关注……这并不难,但很复杂?
(不知道这样行不行?)...

继续...?
从这里抬起你的眼睛看家伙吗?

步骤 6. 创建序列化器

文件:users/serializers.py

Mastering Django: Building a Secure User Authentication API from Scratch

解释:

  1. **序列化器**:在 Django REST Framework 中,序列化器用于将复杂数据类型(如 Django 模型)转换为 JSON,反之亦然。
  2. **RegisterSerializer**:此自定义序列化程序处理用户注册。它包括用户名、密码、电子邮件等字段。
  3. **validate_password**:确保密码符合某些安全标准。
  4. **验证方法**:自定义验证,检查两个密码字段是否匹配。
  5. **create**方法:该方法负责创建并保存新用户。

第7步:创建视图

文件:users/views.py

Mastering Django: Building a Secure User Authentication API from Scratch
解释:

  1. **视图**:在 Django 中,视图处理处理用户请求的逻辑。
  2. **RegisterView**:此视图处理用户注册。
  3. **CreateAPIView**:用于处理新记录创建的内置视图。这里,它用于创建一个新用户。
  4. **permission_classes**:AllowAny 意味着任何人(甚至未经身份验证的用户)都可以访问此端点,这是注册所必需的。

第 8 步:设置 URL

文件:users/urls.py
此代码写在应用程序的 URL

Mastering Django: Building a Secure User Authentication API from Scratch

解释:

URL 模式:定义映射到视图的路径。
**register/**:此 URL 将处理用户注册。

然后转到您的项目文件:**auth_project/urls.py**
然后输入这个...?

Mastering Django: Building a Secure User Authentication API from Scratch

解释:

  1. **include('users.urls')**:这包括用户应用程序的 URL。
  2. 智威汤逊浏览量: TokenObtainPairView:此视图返回一对访问令牌和刷新令牌。 TokenRefreshView:此视图允许客户端使用刷新令牌刷新访问令牌。
  3. **TokenObtainPairView**:此视图返回一对访问和刷新令牌。
  4. **TokenRefreshView**:此视图允许客户端使用刷新令牌刷新访问令牌。

到了下一个这里就可以好好休息了吗?...以后就没有压力了呵呵..

第 9 步:运行迁移

命令:

Mastering Django: Building a Secure User Authentication API from Scratch

这样做的功能/目的是,它根据您在项目中定义的模型和字段对数据库架构进行更改。我们上面精心策划的那些?

换句话说,它使项目保持最新状态

第10步:运行服务器并测试

命令:

Mastering Django: Building a Secure User Authentication API from Scratch

此命令启动 Django 开发服务器,使您的项目可以在本地访问。 (您本地的端口)

现在让我们看看到目前为止我们做了什么...

使用 Postman 或 cURL 进行测试(您可以从 IDE 下载此扩展)

使用 Postman

  1. 打开 Postman(或任何您喜欢的 API 测试工具)。

  2. 设置新请求

  • 1.网址:http://127.0.0.1:8000/api/auth/register/
  • 2.方法:POST
  1. 在“正文”选项卡中,选择原始格式和 JSON 格式。

  2. 输入以下 JSON 数据:
    身体:

Mastering Django: Building a Secure User Authentication API from Scratch

  1. 点击发送。

对于这一部分,Django-Rest Framework 有一个友好的用户界面,因此比其他框架更容易在这里导航

如果成功,您应该会收到 HTTP 状态代码 201 Created 的响应以及包含用户数据的 JSON 响应。

测试令牌身份验证端点

要确保 JWT 身份验证正常工作,请测试令牌端点。

使用邮差:

  1. 设置新请求: 方法:邮寄 网址:http://127.0.0.1:8000/api/token/
  2. 在“正文”选项卡中,选择原始格式和 JSON 格式。
  3. 输入以下 JSON 数据

Mastering Django: Building a Secure User Authentication API from Scratch

4、点击发送。
您应该收到带有访问和刷新令牌的 JSON 响应:

Mastering Django: Building a Secure User Authentication API from Scratch

**

故障排除技巧

**
服务器未启动:确保您位于正确的目录中并已激活虚拟环境。
端点错误:仔细检查您的 URL 路径并确保您的 Django 应用程序已使用 URL 正确设置。
无效响应:验证您的 API 端点和序列化程序是否已正确配置。
通过执行这些步骤,您应该能够成功运行 Django 开发服务器、测试注册端点并验证基于令牌的身份验证。

版本聲明 本文轉載於:https://dev.to/mayowakalejaiye/mastering-django-building-a-secure-user-authentication-api-from-scratch-4ma3?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-12-29
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-12-29
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-12-29
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-12-29
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段:action=''而非:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST陣列:表單提交後使用 var_dump 檢查 $_POST 陣列的內容...
    程式設計 發佈於2024-12-29
  • 插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入記錄時如何解決「一般錯誤:2006 MySQL 伺服器已消失」介紹:將資料插入MySQL 資料庫有時會導致錯誤「一般錯誤:2006 MySQL 伺服器已消失」。當與伺服器的連線遺失時會出現此錯誤,通常是由於 MySQL 配置中的兩個變數之一所致。 解決方案:解決此錯誤的關鍵是調整wait_tim...
    程式設計 發佈於2024-12-29
  • HTML 格式標籤
    HTML 格式標籤
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    程式設計 發佈於2024-12-29
  • 如何在 React 中有條件地應用類別屬性?
    如何在 React 中有條件地應用類別屬性?
    在React 中有條件地應用類別屬性在React 中,根據從父組件傳遞的props 來顯示或隱藏元素是很常見的。為此,您可以有條件地應用 CSS 類別。然而,當使用語法 {this.props.condition ? 'show' : 'hidden'} 直接在字串中...
    程式設計 發佈於2024-12-28
  • 如何在Java中執行系統命令並與其他應用程式互動?
    如何在Java中執行系統命令並與其他應用程式互動?
    Java 中運行進程在 Java 中,啟動進程的能力是執行系統命令和與其他應用程式互動的關鍵功能。為了啟動一個流程,Java提供了一個相當於.Net System.Diagnostics.Process.Start方法。 解決方案:取得本地路徑對於執行至關重要Java 中的程序。幸運的是,Java ...
    程式設計 發佈於2024-12-28
  • 如何在 C++ 中建立多行字串文字?
    如何在 C++ 中建立多行字串文字?
    C 中的多行字串文字 在 C 中,定義多行字串文字並不像 Perl 等其他語言那麼簡單。但是,您可以使用一些技術來實現此目的:連接字串文字一種方法是利用 C 中相鄰字串文字由編譯器連接的事實。將字串分成多行,您可以建立單一多行字串:const char *text = "This te...
    程式設計 發佈於2024-12-28
  • 如何準確地透視具有不同記錄的資料以避免遺失資訊?
    如何準確地透視具有不同記錄的資料以避免遺失資訊?
    有效地透視不同記錄透視查詢在將資料轉換為表格格式、實現輕鬆資料分析方面發揮著至關重要的作用。但是,在處理不同記錄時,資料透視查詢的預設行為可能會出現問題。 問題:忽略不同值考慮下表:------------------------------------------------------ | Id...
    程式設計 發佈於2024-12-27
  • 為什麼 C 和 C++ 忽略函式簽章中的陣列長度?
    為什麼 C 和 C++ 忽略函式簽章中的陣列長度?
    將陣列傳遞給C 和C 中的函數問題:為什麼C和C 編譯器允許在函數簽章中宣告數組長度,例如int dis(char a[1])(當它們不允許時)強制執行? 答案:C 和C 中用於將數組傳遞給函數的語法是歷史上的奇怪現象,它允許將指針傳遞給第一個元素詳細說明:在C 和C 中,數組不是透過函數的引用傳遞...
    程式設計 發佈於2024-12-26
  • 如何刪除 MySQL 中的重音符號以改進自動完成搜尋?
    如何刪除 MySQL 中的重音符號以改進自動完成搜尋?
    在MySQL 中刪除重音符號以實現高效的自動完成搜尋管理大型地名資料庫時,確保準確和高效至關重要資料檢索。使用自動完成功能時,地名中的重音可能會帶來挑戰。為了解決這個問題,一個自然的問題出現了:如何在 MySQL 中刪除重音符號以改善自動完成功能? 解決方案在於為資料庫列使用適當的排序規則設定。透過...
    程式設計 發佈於2024-12-26
  • 如何在MySQL中實作複合外鍵?
    如何在MySQL中實作複合外鍵?
    在 SQL 中實作複合外鍵一個常見的資料庫設計涉及使用複合鍵在表之間建立關係。複合鍵是多個列的組合,唯一標識表中的記錄。在這個場景中,你有兩個表,tutorial和group,你需要將tutorial中的複合唯一鍵連結到group中的欄位。 根據MySQL文檔,MySQL支援外鍵對應到複合鍵。但是,...
    程式設計 發佈於2024-12-26
  • 為什麼我的 JComponent 隱藏在 Java 的背景圖片後面?
    為什麼我的 JComponent 隱藏在 Java 的背景圖片後面?
    調試背景圖像隱藏的JComponent在Java 應用程式中使用JComponent(例如JLabels)時,必須確保正確的行為和可見度。如果遇到組件隱藏在背景圖像後面的問題,請考慮以下方法:1。正確設定組件透明度:確保背景面板是透明的,以允許底層組件透過。使用setOpaque(false)方法來...
    程式設計 發佈於2024-12-26

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3