Django實戰(zhàn)之用戶認(rèn)證(初始配置)
前兩篇講述了Django的理論,從這篇開始,我們真正進(jìn)入Django實戰(zhàn)部分,今天先從用戶認(rèn)證開始。
當(dāng)大家平時打開一個網(wǎng)站時,第一步一般做什么?我猜大部分是先登錄吧,所以我們就從用戶認(rèn)證開始。
打開用戶認(rèn)證
Django本身已經(jīng)提供了用戶認(rèn)證模塊,所以我們要做的事很簡單,就是在它的基礎(chǔ)上添加一些定制化的東西。默認(rèn)情況下,Django的用戶認(rèn)證模塊是打開的,可以通過以下步驟確認(rèn)用戶模塊是否打開(在settings.py文件里):
1、確保 MIDDLEWARE_CLASSES 中包含 'django.contrib.sessions.middleware.SessionMiddleware'。
2、確認(rèn) INSTALLED_APPS 中有 'django.contrib.sessions'
3、將 'django.contrib.auth' 放在你的 INSTALLED_APPS 設(shè)置中,然后運行 manage.py syncdb以創(chuàng)建對應(yīng)的數(shù)據(jù)庫表。
4、確認(rèn) SessionMiddleware 后面的 MIDDLEWARE_CLASSES 設(shè)置中包含 'django.contrib.auth.middleware.AuthenticationMiddleware'。
數(shù)據(jù)庫配置
用戶認(rèn)證系統(tǒng)必然離不開數(shù)據(jù)庫,因為用戶信息需要保存在數(shù)據(jù)庫里,Django自帶的用戶認(rèn)證系統(tǒng)也不例外。在使用它之前,必須配置數(shù)據(jù)庫,Django支持大部分的主流數(shù)據(jù)庫,這里我采用的是Oracle數(shù)據(jù)庫,首先需要安裝cx_Oracle模塊,Django必須通過它才能訪問Oracle數(shù)據(jù)庫。至于如何安裝cx_Oracle模塊,這里就不講了,具體查看官方文檔。
接著在Oracle中創(chuàng)建一個用戶,我們Django項目創(chuàng)建的所有表都建在該用戶下,因此需要相應(yīng)的權(quán)限:
SQL> create user dbrelease identified by *** default tablespace dbrelease; SQL> grant resource,create session,unlimited tablespace to dbrelease;
然后在settings.py中的Databases屬性里設(shè)置django連接oracle:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.oracle',
'NAME': 'lxdbtest',
'USER': 'dbrelease',
'PASSWORD': '***',
'HOST': '192.168.1.16',
'PORT': '1521',
}
}
注意:上面的NAME是指Oracle的instance_name
好了,下面驗證是否可以成功連接Oracle:
進(jìn)入Django項目的主目錄,運行python manage.py shell進(jìn)入交互命令行,然后輸入:
>>> from django.db import connection >>> cursor = connection.cursor()
如果沒有報錯,說明已經(jīng)配置成功。
最后執(zhí)行syncdb語句,從以下輸出中我們可以發(fā)現(xiàn),用戶認(rèn)證系統(tǒng)默認(rèn)在數(shù)據(jù)庫里創(chuàng)建了以下表:
# python manage.py syncdb Creating tables ... Creating table auth_permission Creating table auth_group_permissions Creating table auth_group Creating table auth_user_groups Creating table auth_user_user_permissions Creating table auth_user Creating table django_content_type Creating table django_session Creating table django_site
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python實現(xiàn)讀寫sqlite3數(shù)據(jù)庫并將統(tǒng)計數(shù)據(jù)寫入Excel的方法示例
這篇文章主要介紹了Python實現(xiàn)讀寫sqlite3數(shù)據(jù)庫并將統(tǒng)計數(shù)據(jù)寫入Excel的方法,涉及Python針對sqlite3數(shù)據(jù)庫的讀取及Excel文件相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
Pandas.concat連接DataFrame,Series的示例代碼
本文主要介紹了Pandas.concat連接DataFrame,Series的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
基于python+opencv調(diào)用電腦攝像頭實現(xiàn)實時人臉眼睛以及微笑識別
這篇文章主要為大家詳細(xì)介紹了基于python+opencv調(diào)用電腦攝像頭實現(xiàn)實時人臉眼睛以及微笑識別,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
淺析pandas 數(shù)據(jù)結(jié)構(gòu)中的DataFrame
DataFrame 類型類似于數(shù)據(jù)庫表結(jié)構(gòu)的數(shù)據(jù)結(jié)構(gòu),這篇文章主要介紹了pandas 數(shù)據(jù)結(jié)構(gòu)之DataFrame,需要的朋友可以參考下2019-10-10
通過 Django Pagination 實現(xiàn)簡單分頁功能
這篇文章主要介紹了通過 Django Pagination 實現(xiàn)簡單分頁功能,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11

