PHP - सत्र

एक संपूर्ण वेबसाइट के विभिन्न पृष्ठों में डेटा को सुलभ बनाने का एक वैकल्पिक तरीका PHP सत्र का उपयोग करना है।

एक सत्र सर्वर पर एक अस्थायी निर्देशिका में एक फ़ाइल बनाता है जहाँ पंजीकृत सत्र चर और उनके मान संग्रहीत किए जाते हैं। यह डेटा उस यात्रा के दौरान साइट के सभी पृष्ठों पर उपलब्ध होगा।

अस्थायी फ़ाइल का स्थान एक सेटिंग द्वारा निर्धारित किया जाता है php.ini फ़ाइल कहा जाता है session.save_path। किसी भी सत्र चर का उपयोग करने से पहले सुनिश्चित करें कि आपने इस पथ को सेटअप किया है।

जब एक सत्र शुरू होता है तो निम्नलिखित बातें होती हैं -

  • PHP पहले उस विशेष सत्र के लिए एक विशिष्ट पहचानकर्ता बनाता है जो कि 32xx34c3jj973hjkop2fc937e3443 जैसे 32 हेक्साडेसिमल संख्याओं का एक यादृच्छिक स्ट्रिंग है।

  • एक कुकी बुलाया PHPSESSID अद्वितीय सत्र पहचान स्ट्रिंग संग्रहीत करने के लिए उपयोगकर्ता के कंप्यूटर पर स्वचालित रूप से भेजा जाता है।

  • निर्दिष्ट अस्थायी निर्देशिका में सर्वर पर एक फ़ाइल स्वचालित रूप से बनाई जाती है और sess_ अर्थात sess_3c7foj34c3jj973hjkop2fc937344443 द्वारा उपसर्ग के लिए पहचाने जाने वाले विशिष्ट पहचानकर्ता का नाम रखती है।

जब एक PHP स्क्रिप्ट एक सत्र चर से मान प्राप्त करना चाहता है, तो PHP स्वचालित रूप से PHPSESSID कुकी से अद्वितीय सत्र पहचानकर्ता स्ट्रिंग प्राप्त करता है और फिर फ़ाइल नाम के लिए इसकी अस्थायी निर्देशिका में दिखता है कि नाम और एक सत्यापन दोनों मूल्यों की तुलना करके किया जा सकता है।

जब उपयोगकर्ता ब्राउज़र खो देता है या साइट छोड़ने के बाद एक सत्र समाप्त होता है, तो सर्वर समय की पूर्व निर्धारित अवधि, आमतौर पर 30 मिनट की अवधि के बाद सत्र समाप्त कर देगा।

एक PHP सत्र शुरू करना

एक PHP सत्र आसानी से एक कॉल करने से शुरू होता है session_start()function.This फ़ंक्शन पहले जाँचता है कि क्या एक सत्र पहले ही शुरू हो गया है और यदि कोई भी शुरू नहीं हुआ है तो यह एक शुरू होता है। यह करने के लिए कॉल करने के लिए सिफारिश की हैsession_start() पृष्ठ की शुरुआत में।

सत्र चर को साहचर्य सरणी में संग्रहीत किया जाता है $_SESSION[]। ये चर एक सत्र के जीवनकाल के दौरान पहुँचा जा सकता है।

निम्नलिखित उदाहरण एक सत्र शुरू करता है फिर एक चर नाम पंजीकृत करता है counter जब भी सत्र के दौरान पृष्ठ का दौरा किया जाता है तो हर बार वेतन वृद्धि की जाती है।

उपयोग करना isset() यह जाँचने के लिए कि सत्र चर पहले से ही निर्धारित है या नहीं।

इस कोड को एक test.php फ़ाइल में रखें और परिणाम देखने के लिए इस फ़ाइल को कई बार लोड करें -

<?php
   session_start();
   
   if( isset( $_SESSION['counter'] ) ) {
      $_SESSION['counter'] += 1;
   }else {
      $_SESSION['counter'] = 1;
   }
	
   $msg = "You have visited this page ".  $_SESSION['counter'];
   $msg .= "in this session.";
?>

<html>
   
   <head>
      <title>Setting up a PHP session</title>
   </head>
   
   <body>
      <?php  echo ( $msg ); ?>
   </body>
   
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

You have visited this page 1in this session.

एक PHP सत्र को नष्ट करना

एक PHP सत्र द्वारा नष्ट किया जा सकता है session_destroy()समारोह। इस फ़ंक्शन को किसी भी तर्क की आवश्यकता नहीं है और एक एकल कॉल सभी सत्र चर को नष्ट कर सकता है। यदि आप एकल सत्र चर को नष्ट करना चाहते हैं तो आप उपयोग कर सकते हैंunset() एक सत्र चर शुरू करने के लिए कार्य करते हैं।

यहाँ एक एकल चर को परेशान करने का उदाहरण दिया गया है -

<?php
   unset($_SESSION['counter']);
?>

यहां वह कॉल है जो सभी सत्र चर को नष्ट कर देगी -

<?php
   session_destroy();
?>

ऑटो सत्र चालू करना

जब कोई उपयोगकर्ता आपकी साइट पर जा सकता है, तो सत्र शुरू करने के लिए आपको start_session () फ़ंक्शन को कॉल करने की आवश्यकता नहीं है session.auto_start 1 में चर php.ini फ़ाइल।

कुकीज़ के बिना सत्र

एक मामला हो सकता है जब कोई उपयोगकर्ता अपनी मशीन पर कुकीज़ को स्टोर करने की अनुमति नहीं देता है। इसलिए ब्राउजर में सेशन आईडी भेजने का एक और तरीका है।

वैकल्पिक रूप से, आप निरंतर SID का उपयोग कर सकते हैं जो कि सत्र शुरू होने पर परिभाषित किया गया है। यदि क्लाइंट ने एक उपयुक्त सत्र कुकी नहीं भेजी, तो उसके पास session_name = session_id का फॉर्म है। अन्यथा, यह एक खाली स्ट्रिंग में फैलता है। इस प्रकार, आप इसे बिना शर्त URL में एम्बेड कर सकते हैं।

निम्न उदाहरण दर्शाता है कि चर को कैसे पंजीकृत किया जाए, और SID का उपयोग करके किसी अन्य पृष्ठ पर सही तरीके से कैसे लिंक किया जाए।

<?php
   session_start();
   
   if (isset($_SESSION['counter'])) {
      $_SESSION['counter'] = 1;
   }else {
      $_SESSION['counter']++;
   }
   
   $msg = "You have visited this page ".  $_SESSION['counter'];
   $msg .= "in this session.";
   
   echo ( $msg );
?>

<p>
   To continue  click following link <br />
   
   <a  href = "nextpage.php?<?php echo htmlspecialchars(SID); ?>">
</p>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

You have visited this page 1in this session.
To continue click following link

htmlspecialchars() XSS संबंधित हमलों को रोकने के लिए SID को प्रिंट करते समय उपयोग किया जा सकता है।