Django-쿠키 처리

웹 응용 프로그램의 요구 사항에 따라 사이트 방문자별로 일부 데이터를 저장하려는 경우가 있습니다. 쿠키는 클라이언트 측에 저장되며 클라이언트 브라우저 보안 수준에 따라 쿠키 설정이 때때로 작동 할 수 있고 때로는 작동하지 않을 수 있음을 항상 명심하십시오.

Django에서 쿠키 처리를 설명하기 위해 이전에 만든 로그인 시스템을 사용하여 시스템을 만들어 보겠습니다. 시스템은 X 분 동안 로그인 상태를 유지하며 그 시간이 지나면 앱에서 나갑니다.

이를 위해서는 last_connection과 username이라는 두 개의 쿠키를 설정해야합니다.

먼저 사용자 이름과 last_connection 쿠키를 저장하도록 로그인 뷰를 변경해 보겠습니다.

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

위의보기에서 볼 수 있듯이 쿠키 설정은 set_cookie 메서드가 요청이 아닌 응답에서 호출되며 모든 쿠키 값이 문자열로 반환됩니다.

이제 로그인 양식에 대한 formView를 생성 해 보겠습니다. 쿠키가 설정되어 있고 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에서 볼 수 있듯이 설정 한 쿠키에 액세스하는 것은 요청의 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)이 표시됩니다.