前兩篇講述了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項目創建的所有表都建在該用戶下,因此需要相應的權限:
SQL> create user dbrelease identified by *** default tablespace dbrelease; SQL> grant resource,create session,unlimited tablespace to dbrelease;
然后在settings.py中的Databases屬性里設置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:
進入Django項目的主目錄,運行python manage.py shell進入交互命令行,然后輸入:
>>> from django.db import connection>>> cursor = connection.cursor()
如果沒有報錯,說明已經配置成功。
最后執行syncdb語句,從以下輸出中我們可以發現,用戶認證系統默認在數據庫里創建了以下表:
# python manage.py syncdbCreating tables ...Creating table auth_permissionCreating table auth_group_permissionsCreating table auth_groupCreating table auth_user_groupsCreating table auth_user_user_permissionsCreating table auth_userCreating table django_content_typeCreating table django_sessionCreating table django_site
新聞熱點
疑難解答