django中的auth模塊與admin後臺管理

来源:https://www.cnblogs.com/suncolor/archive/2022/09/18/16598738.html
-Advertisement-
Play Games

1. auth模塊 在創建完django項目之後,執行資料庫遷移之後,資料庫里會增加很多新表,其中有一張名為auth_user的表,當訪問django自帶的路由admin的時候,需要輸入用戶名和密碼,其參照的就是auth_user表 使用python3 manage.py crataesupperu ...


1. auth模塊

在創建完django項目之後,執行資料庫遷移之後,資料庫里會增加很多新表,其中有一張名為auth_user的表,當訪問django自帶的路由admin的時候,需要輸入用戶名和密碼,其參照的就是auth_user表

使用python3 manage.py crataesupperuser 可以創建超級管理員用戶,同時在auth_user表裡面產生一條超級用戶數據

1.1 auth模塊的常用方法

from django.contrib import auth
# 1.比對用戶名和密碼是否正確
	user_obj = auth.authenticate(request,username=username,password=password)
	# 括弧內必須同時傳入用戶名和密碼
	print(user_obj)  # 返回的是用戶對象  jason   數據不符合則返回None
	print(user_obj.username)  # jason
	print(user_obj.password)  # 結果為密文
	
# 2.保存用戶狀態
	auth.login(request,user_obj)  # 類似於request.session[key] = user_obj
	# 主要執行了該方法 你就可以在任何地方通過request.user獲取到當前登陸的用戶對象
	
# 3.判斷當前用戶是否登陸
	request.user.is_authenticated()
	登錄了返回true,否則返回false
	
# 4.獲取當前登陸用戶對象
	user_obj=request.user
	
# 5.校驗用戶是否登陸的裝飾器
	from django.contrib.auth.decorators import login_required
	# 局部配置
	@login_required(login_url='/login/')
	在需要裝飾的函數上添加上述裝飾器,括弧里表示未登錄則跳轉到指定url
	# 在setting.py里進行全局配置
	LOGIN_URL = '/login/'
		1.如果局部和全局都有 該聽誰的?
		局部 > 全局
		2.局部和全局哪個好呢?
		全局的好處在於無需重覆寫代碼 但是跳轉的頁面卻很單一
		局部的好處在於不同的視圖函數在用戶沒有登陸的情況下可以跳轉到不同的頁面
		
# 6.比對原密碼
	is_right=request.user.check_password(old_password)
	返回的是true或者false

# 7.修改密碼
	request.user.set_password(new_password)  # 僅僅是在修改對象的屬性
	request.user.save()  # 這一步才是真正的操作資料庫

# 8.註銷
	auth.logout(request)

# 9.註冊
	# 操作auth_user表寫入數據
	from django.contrib.auth.models import User #導入模塊
	User.objects.create(username=username,password=password)  # 寫入數據  不能用create 密碼沒有加密處理
	# 創建普通用戶
	User.objects.create_user(username=username,password=password)
	# 創建超級用戶(瞭解):使用代碼創建超級用戶 郵箱是必填的 而用命令創建則可以不填
	User.objects.create_superuser(username=username,email='[email protected]',password=password)

1.2 如何擴展auth_user表

from django.db import models
from django.contrib.auth.models import User,AbstractUser

# 第一種方法:一對一關係(利用外鍵)  不推薦
# class UserDetail(models.Model):
#     phone = models.BigIntegerField()
#     user = models.OneToOneField(to='User')

# 第二種:面向對象的繼承
class UserInfo(AbstractUser):
    """
    如果繼承了AbstractUser
    那麼在執行資料庫遷移命令的時候auth_user表就不會再創建出來了
    而UserInfo表中會出現auth_user所有的欄位外加自己擴展的欄位
    這麼做的好處在於你能夠直接點擊你自己的表更加快速的完成操作及擴展

    前提:
        1.在繼承之前沒有執行過資料庫遷移命令
            auth_user沒有被創建,如果當前庫已經創建了那麼你就重新換一個資料庫
        2.繼承的類裡面不要覆蓋AbstractUser裡面的欄位名
            表裡面有的欄位都不要動,只擴展額外欄位即可
        3.需要在配置文件中告訴django你要用UserInfo替代auth_user(******)
            AUTH_USER_MODEL = 'app01.UserInfo'
                                '應用名.表名'
    """
    phone = models.BigIntegerField() # 需要添加的新欄位

你如果自己寫表替代了auth_user,那麼auth模塊的功能還是照常使用,參考的表頁由原來的auth_user變成了UserInfo!

2.admin後臺管理

django的admin管理後臺提供了比較完善的管理資料庫的介面

2.1 admin後臺管理的準備工作

1.創建超級用戶:python manage.py createsuperuser
2.進入127.0.0.1/admin --使用超級用戶賬號登錄進行用戶的增加或者組的增加
3.在app中的admin.py中導入註冊自己要管理的模型類如:from . models import Book
4.admin.site.register(Book) # 註冊語法,註冊之後admin後臺就可以對該表進行管理!!

2.2 為admin後臺設置樣式和增加數據

1.修改admin後臺的表名

在該表對應的models類裡面添加一個Meta類:
    class Meta:
        verbose_name_plural = '用戶表' #指定該表在admin後臺的名字為:用戶表

image
image

2.在admin中為具體表增加數據

image

3.null=True,blank=True的區別

phone = models.BigIntegerField(verbose_name='手機號',null=True,blank=True)
    """
    null=True:是告訴資料庫該欄位可以為空,admin後臺預設還是不允許為空
    blank=True:告訴admin後臺該欄位可以為空
    """

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這個系列的目的是通過使用 JS 實現“乞丐版”的 React,讓讀者瞭解 React 的基本工作原理,體會 React 帶來的構建應用的優勢 1 HTML 構建靜態頁面 使用 HTML 和 CSS,我們很容易可以構建出上圖中的頁面 <!DOCTYPE html> <html lang="en"> < ...
  • 原型(prototype)是函數特有的屬性。只要創建了一個函數,這個函數就會自動創建一個prototype屬性(顯式原型),並指向該函數的原型對象。原型對象上都有一個constructor屬性,指向prototype屬性所在的函數(即函數本身)。而對於每一個構造函數創建出的實例對象,內部都會有一個[... ...
  • 移動端中的元素內容超出時,對容器設置overflow-x: auto就可以通過手勢水平移動。但是 PC 端只能通過滑鼠滾輪上下滑動,而不能水平移動。 只需要給元素添加一個監聽滑鼠滾輪事件,上下滑動時修改其 scrollLeft 屬性值就可以實現。直接貼上代碼: <div class="horizon ...
  • 我的設計模式之旅,本節學習原型模式。從複製原有對象出現的兩大問題思考原型模式存在的必要性。探討原型模式的實現方法。 ...
  • 在寫開源項目的時候,想到了要支持多種redis部署方式,於是對於這塊的生產環境的架構選型展開調研。 推薦使用更新的引擎版本以支持更多的特性, Redis 6.0新特性說明 模塊系統新增多個API。 支持SSL/TLS加密。 支持新的Redis協議:RESP3。 服務端支持多模式的客... ...
  • 我的設計模式之旅。本節詳細說明單例模式的實現方式、優缺點,簡要描述多線程情況下利用雙重鎖定保護單例對象和C#靜態初始化的方式。並用 Golang 實現單例模式,三個工作者需要各自找到電梯搭乘,只有一個電梯!補充C#單線程單例模式的實現。 ...
  • 目錄 一.OpenGL 圖像反色 1.原始圖片 2.效果演示 二.OpenGL 圖像反色源碼下載 三.猜你喜歡 零基礎 OpenGL ES 學習路線推薦 : OpenGL ES 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL ES 學習路線推薦 : OpenGL ES 學習目錄 >> ...
  • 我的博客 俗話說,工欲善其事必先利其器,所以在使用日期前要先對日期進行處理,所以時間戳和字元串的來回來去轉換這個事肯定是要搞的 這次的函數有一個?有兩個?有三個?有四個!上代碼! 哈哈,像不像直播帶貨 本次用到3個內置包 import reimport timeimport calendar 第一個 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...