Django - Cookie 处理


有时,您可能希望根据 Web 应用程序的要求为每个站点访问者存储一些数据。请始终记住,cookie 保存在客户端,并且根据您的客户端浏览器安全级别,设置 cookie 有时有效,有时可能无效。

为了说明 Django 中的 cookie 处理,让我们使用之前创建的登录系统创建一个系统。系统将使您保持登录状态 X 分钟,超过该时间,您将退出该应用程序。

为此,您需要设置两个 cookie:last_connection 和 username。

首先,让我们更改登录视图以存储我们的用户名和last_connection cookie -

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', {})

正如您在上面的 formView 中看到的,访问您设置的 cookie 是通过请求的 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 时,您将看到以下页面 -

Django Cookie 处理

提交时您将被重定向到以下屏幕 -

Cookie 处理重定向页面

现在,如果您尝试在 10 秒范围内再次访问 /myapp/connection,您将直接重定向到第二个屏幕。如果您再次超出此范围访问 /myapp/connection,您将收到登录表单(屏幕 1)。