有时您可能希望根据Web应用程序的要求在每个站点访问者的基础上存储一些数据.请记住,Cookie会保存在客户端,并且根据您的客户端浏览器安全级别,设置Cookie有时会工作,有时可能不会.
说明处理cookie Django,让我们使用之前创建的登录系统创建一个系统.系统会让您保持登录X分钟的时间,超过该时间,您将退出应用程序.
为此,您需要设置两个cookie,last_connection和用户名.
首先,让我们更改我们的登录视图以存储我们的用户名和last_connection cookies :
from django.template import RequestContext def login(request): username = "not logged in" if request.method == "POST": #Get the posted form MyLoginForm = LoginForm(request.POST) if MyLoginForm.is_valid(): username = MyLoginForm.cleaned_data['username'] else: MyLoginForm = LoginForm() response = render_to_response(request, 'loggedin.html', {"username" : username}, context_instance = RequestContext(request)) response.set_cookie('last_connection', datetime.datetime.now()) response.set_cookie('username', datetime.datetime.now()) return response
如上图所示设置cookie是通过响应而非请求调用的 set_cookie 方法完成的,并且还要注意所有cookie值都以字符串形式返回.
现在让我们创建用于登录表单的formView,如果设置了cookie并且不超过10秒和以下,我们将不显示表单;
def formView(request): if 'username' in request.COOKIES and 'last_connection' in request.COOKIES: username = request.COOKIES['username'] last_connection = request.COOKIES['last_connection'] last_connection_time = datetime.datetime.strptime(last_connection[:-7], "%Y-%m-%d %H:%M:%S") if (datetime.datetime.now() - last_connection_time).seconds < 10: return render(request, 'loggedin.html', {"username" : username}) else: return render(request, 'login.html', {}) else: return render(request, 'login.html', {})
正如您所见访问您设置的cookie上面的formView是通过请求的COOKIES属性(dict)完成的.
现在让我们更改url.py文件以更改URL,使其与我们的新视图 :
from django.conf.urls import patterns, url from django.views.generic import TemplateView urlpatterns = patterns('myapp.views', url(r'^connection/','formView', name = 'loginform'), url(r'^login/', 'login', name = 'login'))
访问/myapp/connection时,您将看到以下页面 :
您将在提交和减号时被重定向到以下屏幕;
现在,如果您尝试在10秒范围内再次访问/myapp/connection,您将直接重定向到第二个屏幕.如果您再次访问此范围内的/myapp/connection,您将获得登录表单(屏幕1).