網站首頁 編程語言 正文
1. auth模塊
auth模塊是對登錄認證方法的一種封裝,本身就是一個對象,可以獲取用戶的詳細信息,有了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='123@qq.com',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后臺的名字為:用戶表
2.在admin中為具體表增加數據
3.null=True,blank=True的區別
phone = models.BigIntegerField(verbose_name='手機號',null=True,blank=True)
"""
null=True:是告訴數據庫該字段可以為空,admin后臺默認還是不允許為空
blank=True:告訴admin后臺該字段可以為空
"""
原文鏈接:https://www.cnblogs.com/suncolor/archive/2022/09/18/16598738.html
相關推薦
- 2022-06-02 Python學習之迭代器詳解_python
- 2022-11-25 CentOS?7.9?升級內核?kernel-ml-5.6.14版本的方法_云其它
- 2022-07-03 如何讓Python在HTML中運行_python
- 2022-04-20 Python設計模式結構型享元模式_python
- 2022-11-15 Python一直報錯SyntaxError:invalid?syntax的解決辦法_python
- 2022-10-10 scrapy框架ItemPipeline的使用_python
- 2024-07-15 使用itext導出pdf出現的中文無法顯示的問題
- 2022-04-06 go語言限制協程并發數的方案詳情_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支