सिम्फनी - कुकीज़ और सत्र प्रबंधन
सिम्फनी HttpFoundation घटक एक वस्तु-उन्मुख तरीके से कुकी और सत्र प्रबंधन प्रदान करता है। Cookieक्लाइंट-साइड डेटा स्टोरेज प्रदान करता है और यह केवल थोड़ी मात्रा में डेटा का समर्थन करता है। आमतौर पर, यह प्रति डोमेन 2KB है और यह ब्राउज़र पर निर्भर करता है।Sessionसर्वर-साइड डेटा भंडारण प्रदान करता है और यह बड़ी मात्रा में डेटा का समर्थन करता है। आइए देखें कि सिम्फनी वेब एप्लिकेशन में कुकी और सत्र कैसे बनाएं।
कुकी
सिम्फनी एक कुकी आइटम बनाने के लिए कुकी वर्ग प्रदान करती है। आइए हम एक कुकी रंग बनाते हैं, जो मूल्य के साथ 24 घंटे में समाप्त हो जाता हैblue। कुकी वर्ग का निर्माता पैरामीटर निम्नानुसार है।
- नाम (प्रकार: स्ट्रिंग) - कुकी नाम
- मान (प्रकार: स्ट्रिंग) - कुकी मान
- समाप्ति (प्रकार: पूर्णांक / स्ट्रिंग / डेटाटाइम) - समाप्ति की जानकारी
- पथ (प्रकार: स्ट्रिंग) - सर्वर पथ जिसमें कुकी उपलब्ध है
- डोमेन (प्रकार: स्ट्रिंग) - वह डोमेन पता जिसमें कुकी उपलब्ध है
- सुरक्षित (प्रकार: बूलियन) - क्या कुकी को HTTPS कनेक्शन में प्रसारित करने की आवश्यकता है
- httpOnly (प्रकार: बूलियन) - क्या कुकी केवल HTTP प्रोटोकॉल में उपलब्ध है
use Symfony\Component\HttpFoundation\Cookie;
$cookie = new Cookie('color', 'green', strtotime('tomorrow'), '/',
'somedomain.com', true, true);
सिम्फनी निम्नलिखित स्ट्रिंग-आधारित कुकी निर्माण विकल्प भी प्रदान करती है।
$cookie = Cookie::fromString('color = green; expires = Web, 4-May-2017 18:00:00 +0100;
path=/; domain = somedomain.com; secure; httponly');
अब, बनाई गई कुकी को http प्रतिक्रिया ऑब्जेक्ट के हेडर के साथ संलग्न करने की आवश्यकता है जो निम्नानुसार है।
$response->headers->setCookie($cookie);
कुकी प्राप्त करने के लिए, हम निम्नानुसार अनुरोध ऑब्जेक्ट का उपयोग कर सकते हैं।
$cookie = $request->cookie->get('color');
यहाँ, request->cookie प्रकार का है PropertyBag और हम इसे PropertyBag विधियों का उपयोग करके हेरफेर कर सकते हैं।
अधिवेशन
सिम्फनी एक सत्र वर्ग प्रदान करता है जो SessionInterface इंटरफ़ेस को लागू करता है। महत्वपूर्ण सत्र एपीआई इस प्रकार है,
start - सत्र शुरू करता है।
Session $session = new Session();
$session->start();
invalidate - सभी सत्र डेटा को साफ़ करता है और सत्र आईडी को पुन: बनाता है।
set - कुंजी का उपयोग करके सत्र में डेटा संग्रहीत करता है।
$session->set('key', 'value');
हम सत्र मान में किसी भी डेटा का उपयोग कर सकते हैं, जटिल वस्तुओं के लिए सरल पूर्णांक में हो सकते हैं।
get - कुंजी का उपयोग करके सत्र से डेटा प्राप्त करता है।
$val = $session->get('key');
remove - सत्र से एक कुंजी निकालता है।
clear - एक सत्र डेटा निकालता है।
FlashBag
सत्र एक और उपयोगी सुविधा प्रदान करता है जिसे कहा जाता है FlashBag। यह केवल पृष्ठ पुनर्निर्देशन के दौरान डेटा रखने वाले सत्र के अंदर एक विशेष कंटेनर है। यह http रीडायरेक्ट में उपयोगी है। एक पृष्ठ पर पुनर्निर्देशित करने से पहले, डेटा को सामान्य सत्र कंटेनर के बजाय फ्लैशबाग में सहेजा जा सकता है और सहेजा गया डेटा अगले अनुरोध (पुनर्निर्देशित पृष्ठ) में उपलब्ध होगा। फिर, डेटा स्वचालित रूप से अमान्य हो जाएगा।
$session->getFlashBag()->add('key', 'value');
$session->getFlashBag()->get('key');