Django - सत्र
जैसा कि पहले चर्चा की गई है, हम वेब ऐप के लिए बहुत सारे उपयोगी डेटा स्टोर करने के लिए क्लाइंट साइड कुकीज़ का उपयोग कर सकते हैं। हमने पहले देखा है कि हम अपने वेब ऐप के लिए उपयोगी विभिन्न डेटा स्टोर करने के लिए क्लाइंट साइड कुकीज़ का उपयोग कर सकते हैं। यह आपके द्वारा सहेजे जाने वाले डेटा के महत्व के आधार पर बहुत सारे सुरक्षा छेदों की ओर जाता है।
सुरक्षा कारणों से, Django में कुकीज़ से निपटने के लिए एक सत्र की रूपरेखा है। सत्रों का उपयोग कुकीज़ को प्राप्त करने और भेजने के लिए किया जाता है, डेटा सर्वर साइड (जैसे डेटाबेस) में सहेजा जाता है, और क्लाइंट साइड कुकी की पहचान के लिए एक सत्र आईडी है। उन मामलों से बचने के लिए सत्र उपयोगी होते हैं जहां उपयोगकर्ता ब्राउज़र कुकीज़ को 'स्वीकार नहीं' करने के लिए सेट है।
सत्रों की स्थापना
Django में, सक्षम करने का सत्र आपकी परियोजना में किया जाता है settings.py, कुछ लाइनों को जोड़कर MIDDLEWARE_CLASSES और यह INSTALLED_APPSविकल्प। यह प्रोजेक्ट बनाते समय किया जाना चाहिए, लेकिन यह जानना हमेशा अच्छा होता है, इसलिएMIDDLEWARE_CLASSES होना चाहिए -
'django.contrib.sessions.middleware.SessionMiddleware'
तथा INSTALLED_APPS होना चाहिए -
'django.contrib.sessions'
डिफ़ॉल्ट रूप से, Django सत्र की जानकारी डेटाबेस (django_session तालिका या संग्रह) में सहेजता है, लेकिन आप अन्य तरीकों का उपयोग करके जानकारी संग्रहीत करने के लिए इंजन को कॉन्फ़िगर कर सकते हैं जैसे: में file या में cache।
जब सत्र सक्षम होता है, तो प्रत्येक अनुरोध (Django में किसी भी दृश्य का पहला तर्क) में एक सत्र (तानाशाही) विशेषता होती है।
आइए सत्रों को बनाने और सहेजने के तरीके को देखने के लिए एक सरल नमूना बनाएं। हमने पहले एक सरल लॉगिन सिस्टम बनाया है (देखें Django फॉर्म प्रोसेसिंग चैप्टर और Django कुकीज़ हैंडलिंग अध्याय)। हमें एक कुकी में उपयोगकर्ता नाम बचाने के लिए, अगर साइन आउट नहीं किया जाता है, तो हमारे लॉगिन पृष्ठ तक पहुंचने पर आपको लॉगिन फ़ॉर्म दिखाई नहीं देगा। असल में, कुकीज़ सर्वर साइड को बचाकर, हम अपने लॉगिन सिस्टम को Django कुकीज में अधिक सुरक्षित तरीके से उपयोग करते हैं।
इसके लिए, पहले हमारे यूज़रनेम कुकी सर्वर साइड को बचाने के लिए अपना लॉगिन दृश्य बदलें -
def login(request):
username = 'not logged in'
if request.method == 'POST':
MyLoginForm = LoginForm(request.POST)
if MyLoginForm.is_valid():
username = MyLoginForm.cleaned_data['username']
request.session['username'] = username
else:
MyLoginForm = LoginForm()
return render(request, 'loggedin.html', {"username" : username}
फिर हमें लॉगिन फॉर्म के लिए फॉर्म व्यू व्यू बनाते हैं, जहां हम कुकी सेट होने पर फॉर्म प्रदर्शित नहीं करेंगे -
def formView(request):
if request.session.has_key('username'):
username = request.session['username']
return render(request, 'loggedin.html', {"username" : username})
else:
return render(request, 'login.html', {})
अब हम url को बदलने के लिए url.py फ़ाइल बदलते हैं ताकि यह हमारे नए दृश्य के साथ जोड़े -
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 / कनेक्शन, आप निम्न पृष्ठ देखने के लिए मिल जाएगा -
और आप निम्न पृष्ठ पर पुनः निर्देशित हो जाएंगे -
अब यदि आप फिर से / myapp / कनेक्शन का उपयोग करने का प्रयास करते हैं, तो आप सीधे दूसरी स्क्रीन पर पुनः निर्देशित हो जाएंगे।
आइए एक सरल लॉगआउट दृश्य बनाएं जो हमारे कुकी को मिटा देता है।
def logout(request):
try:
del request.session['username']
except:
pass
return HttpResponse("<strong>You are logged out.</strong>")
और इसे myapp / url.py में लॉगआउट URL के साथ पेयर करें
url(r'^logout/', 'logout', name = 'logout'),
अब, यदि आप / myapp / लॉगआउट का उपयोग करते हैं, तो आपको निम्न पृष्ठ मिलेगा -
यदि आप फिर से / myapp / कनेक्शन का उपयोग करते हैं, तो आपको लॉगिन फ़ॉर्म (स्क्रीन 1) मिलेगा।
कुछ और संभावित क्रिया सत्रों का उपयोग करना
हमने देखा है कि किसी सत्र को कैसे स्टोर और एक्सेस किया जाए, लेकिन यह जानना अच्छा है कि अनुरोध की सत्र विशेषता के कुछ अन्य उपयोगी कार्य हैं जैसे -
set_expiry (value) - सत्र के लिए समाप्ति समय निर्धारित करता है।
get_expiry_age() - यह सत्र समाप्त होने तक सेकंड की संख्या लौटाता है।
get_expiry_date() - यह सत्र समाप्त होने की तारीख लौटाता है।
clear_expired() - सेशन स्टोर से एक्सपायर्ड सेशन हटाता है।
get_expire_at_browser_close() - उपयोगकर्ता के वेब ब्राउज़र के बंद होने पर उपयोगकर्ता के सत्र कुकीज़ की अवधि समाप्त हो गई है या नहीं, इस पर निर्भर करते हुए, या तो सही या गलत रिटर्न देता है।