目标
- 确认启用session
- 确认数据库连接配置正确
- 在视图中使用session
- 实例
确认启用session
Django的session是通过一个中间件SessionMiddleware实现的,如果是启用的,那么setting.py中有两处关键配置
1)MIDDLEWARE处应存在django.contrib.sessions.middleware.SessionMiddleware
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'**django.contrib.sessions.middleware.SessionMiddleware**',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
2)INSTALLED_APPS中存在django.contrib.sessions
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'formapp',
]
此配置是指将session存到数据库中
确认数据库连接配置正确
1)setting.py
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'mysql',
'USER': 'root',
'PASSWORD': 'mysql',
'HOST': '127.0.0.1',
'PORT': '3306',
}
}
2)init.py
import pymysql
pymysql.install_as_MySQLdb()
3)数据库中应该有表django_session
表结构如下(键,值,过期时间):
目前表中无数据
在视图中使用session
session存在于HttpRequest中,它是一个类字典对象
你可以在你的视图中任何地方读取并写入 request.session。
操作方法
-
添加
request.session['key'] = 'value'
-
读取
request.session['key']
-
删除
del request.session['key']
-
设置有效期
request.session.set_expiry(300) #5分钟内有效
如果value是datetime或timedelta对象,则会话将在该特定日期/时间过期。
如果value是0,用户的会话cookie将在用户的Web浏览器关闭时过期。
如果value为None,会话将恢复为使用全局会话到期策略。
-
返回会话离过期的秒数
request.session.get_expiry_age()
-
返回过期的日期。
request.session.get_expiry_date()
练习使用session
完成一个登录功能,要求:
正确启用session功能
在登录页面login.html中,用户可以输入用户名和密码信息并以以post方式提交表单实现登录,登录成功后要跳转到新的显示页面success2.html,并给出成功提示。
在登录成功后将用户账号信息和登录状态存储到session中。并在success2.html中显示用户名
-
login.html
<form action="/forms/login/" method="post"> {% csrf_token %} <table>{{ form }}</table> <input type="submit" value="Submit" /> </form>
-
views.py
def login(request): if request.method == 'POST': form = RegisterForm(request.POST) request.session['username']=request.POST['username'] username=request.session['username'] if form.is_valid(): return render(request, 'success2.html',{'username': username}) else: form = RegisterForm() return render(request, 'login.html', {'form': form})
-
success2.html
用户名:{{ username }}<br>