前兩篇講述了Django的理論,從這篇開始,我們真正進入Django實戰部分,今天先從用戶認證開始。
當大家平時打開一個網站時,第一步一般做什么?我猜大部分是先登錄吧,所以我們就從用戶認證開始。
打開用戶認證
Django本身已經提供了用戶認證模塊,所以我們要做的事很簡單,就是在它的基礎上添加一些定制化的東西。默認情況下,Django的用戶認證模塊是打開的,可以通過以下步驟確認用戶模塊是否打開(在settings.py文件里):
1、確保 MIDDLEWARE_CLASSES 中包含 'django.contrib.sessions.middleware.SessionMiddleware'。
2、確認 INSTALLED_APPS 中有 'django.contrib.sessions'
3、將 'django.contrib.auth' 放在你的 INSTALLED_APPS 設置中,然后運行 manage.py syncdb以創建對應的數據庫表。
4、確認 SessionMiddleware 后面的 MIDDLEWARE_CLASSES 設置中包含 'django.contrib.auth.middleware.AuthenticationMiddleware'。
數據庫配置
用戶認證系統必然離不開數據庫,因為用戶信息需要保存在數據庫里,Django自帶的用戶認證系統也不例外。在使用它之前,必須配置數據庫,Django支持大部分的主流數據庫,這里我采用的是Oracle數據庫,首先需要安裝cx_Oracle模塊,Django必須通過它才能訪問Oracle數據庫。至于如何安裝cx_Oracle模塊,這里就不講了,具體查看官方文檔。
接著在Oracle中創建一個用戶,我們Django項目創建的所有表都建在該用戶下,因此需要相應的權限:
1
2
3
|
SQL> create user dbrelease identified by *** default tablespace dbrelease; SQL> grant resource, create session,unlimited tablespace to dbrelease; |
然后在settings.py中的Databases屬性里設置django連接oracle:
1
2
3
4
5
6
7
8
9
10
|
DATABASES = { 'default' : { 'ENGINE' : 'django.db.backends.oracle' , 'NAME' : 'lxdbtest' , 'USER' : 'dbrelease' , 'PASSWORD' : '***' , 'HOST' : '192.168.1.16' , 'PORT' : '1521' , } } |
注意:上面的NAME是指Oracle的instance_name
好了,下面驗證是否可以成功連接Oracle:
進入Django項目的主目錄,運行python manage.py shell進入交互命令行,然后輸入:
1
2
|
>>> from django.db import connection >>> cursor = connection.cursor() |
如果沒有報錯,說明已經配置成功。
最后執行syncdb語句,從以下輸出中我們可以發現,用戶認證系統默認在數據庫里創建了以下表:
1
2
3
4
5
6
7
8
9
10
11
|
# 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 |
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/dbanote/article/details/11351735