Django实战之用户认证(初始配置)
前两篇讲述了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.pysyncdb以创建对应的数据库表。
4、确认SessionMiddleware后面的MIDDLEWARE_CLASSES设置中包含'django.contrib.auth.middleware.AuthenticationMiddleware'。
数据库配置
用户认证系统必然离不开数据库,因为用户信息需要保存在数据库里,Django自带的用户认证系统也不例外。在使用它之前,必须配置数据库,Django支持大部分的主流数据库,这里我采用的是Oracle数据库,首先需要安装cx_Oracle模块,Django必须通过它才能访问Oracle数据库。至于如何安装cx_Oracle模块,这里就不讲了,具体查看官方文档。
接着在Oracle中创建一个用户,我们Django项目创建的所有表都建在该用户下,因此需要相应的权限:
SQL>createuserdbreleaseidentifiedby***defaulttablespacedbrelease; SQL>grantresource,createsession,unlimitedtablespacetodbrelease;
然后在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项目的主目录,运行pythonmanage.pyshell进入交互命令行,然后输入:
>>>fromdjango.dbimportconnection >>>cursor=connection.cursor()
如果没有报错,说明已经配置成功。
最后执行syncdb语句,从以下输出中我们可以发现,用户认证系统默认在数据库里创建了以下表:
#pythonmanage.pysyncdb Creatingtables... Creatingtableauth_permission Creatingtableauth_group_permissions Creatingtableauth_group Creatingtableauth_user_groups Creatingtableauth_user_user_permissions Creatingtableauth_user Creatingtabledjango_content_type Creatingtabledjango_session Creatingtabledjango_site
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。