PHP - GET & POST के तरीके

ब्राउज़र क्लाइंट वेब सर्वर को जानकारी भेजने के दो तरीके हैं।

  • GET विधि
  • पोस्ट विधि

ब्राउज़र द्वारा सूचना भेजे जाने से पहले, यह URL एन्कोडिंग नामक एक योजना का उपयोग करके इसे एनकोड करता है। इस योजना में, नाम / मूल्य जोड़े समान संकेतों के साथ जुड़ते हैं और विभिन्न जोड़े एम्परसेंड द्वारा अलग किए जाते हैं।

name1=value1&name2=value2&name3=value3

रिक्तियाँ हटा दी जाती हैं और उन्हें + वर्ण के साथ बदल दिया जाता है और किसी भी अन्य ग़ैर-अल्फ़ान्यूमेरिक वर्ण को हेक्साडेसिमल मानों से बदल दिया जाता है। जानकारी एन्कोडेड होने के बाद इसे सर्वर पर भेजा जाता है।

GET विधि

GET विधि पेज अनुरोध के लिए संलग्न एन्कोडेड उपयोगकर्ता जानकारी भेजता है। पृष्ठ और एन्कोडेड जानकारी को अलग कर दिया जाता है? चरित्र।

http://www.test.com/index.htm?name1=value1&name2=value2
  • GET विधि ब्राउज़र के स्थान: बॉक्स में आपके सर्वर लॉग में दिखाई देने वाली एक लंबी स्ट्रिंग का उत्पादन करती है।

  • GET विधि केवल 1024 वर्णों तक भेजने के लिए प्रतिबंधित है।

  • यदि आपके पास पासवर्ड या अन्य संवेदनशील जानकारी सर्वर पर भेजी जाए तो कभी भी GET विधि का उपयोग न करें।

  • GET का उपयोग बाइनरी डेटा, जैसे चित्र या शब्द दस्तावेज़, सर्वर पर भेजने के लिए नहीं किया जा सकता है।

  • GET विधि द्वारा भेजे गए डेटा को QUERY_STRING पर्यावरण चर का उपयोग करके एक्सेस किया जा सकता है।

  • PHP प्रदान करता है $_GET GET पद्धति का उपयोग करके सभी भेजी गई जानकारी तक पहुंचने के लिए सहयोगी सरणी।

स्रोत कोड को test.php स्क्रिप्ट में डालकर निम्नलिखित उदाहरण देखें।

<?php
   if( $_GET["name"] || $_GET["age"] ) {
      echo "Welcome ". $_GET['name']. "<br />";
      echo "You are ". $_GET['age']. " years old.";
      
      exit();
   }
?>
<html>
   <body>
   
      <form action = "<?php $_PHP_SELF ?>" method = "GET">
         Name: <input type = "text" name = "name" />
         Age: <input type = "text" name = "age" />
         <input type = "submit" />
      </form>
      
   </body>
</html>

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

पोस्ट विधि

POST विधि HTTP हेडर के माध्यम से जानकारी स्थानांतरित करती है। GET पद्धति के मामले में वर्णित जानकारी को कूटबद्ध किया गया है और QUERY_STRING नामक शीर्षक में रखा गया है।

  • POST विधि को भेजे जाने वाले डेटा आकार पर कोई प्रतिबंध नहीं है।

  • ASSTII और बाइनरी डेटा भेजने के लिए POST विधि का उपयोग किया जा सकता है।

  • POST विधि द्वारा भेजा गया डेटा HTTP हेडर से होकर जाता है इसलिए सुरक्षा HTTP प्रोटोकॉल पर निर्भर करती है। सुरक्षित HTTP का उपयोग करके आप यह सुनिश्चित कर सकते हैं कि आपकी जानकारी सुरक्षित है।

  • PHP प्रदान करता है $_POST POST विधि का उपयोग करके सभी भेजी गई जानकारी तक पहुंचने के लिए सहयोगी सरणी।

स्रोत कोड को test.php स्क्रिप्ट में डालकर निम्नलिखित उदाहरण देखें।

<?php
   if( $_POST["name"] || $_POST["age"] ) {
      if (preg_match("/[^A-Za-z'-]/",$_POST['name'] )) {
         die ("invalid name and name should be alpha");
      }
      echo "Welcome ". $_POST['name']. "<br />";
      echo "You are ". $_POST['age']. " years old.";
      
      exit();
   }
?>
<html>
   <body>
   
      <form action = "<?php $_PHP_SELF ?>" method = "POST">
         Name: <input type = "text" name = "name" />
         Age: <input type = "text" name = "age" />
         <input type = "submit" />
      </form>
   
   </body>
</html>

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

$ _REQUEST चर

PHP $ _REQUEST चर में $ _GET, $ _POST और $ _COOKIE दोनों की सामग्री शामिल है। जब हम कुकीज़ के बारे में बताएंगे तो हम $ _COOKIE चर पर चर्चा करेंगे।

GET और POST दोनों तरीकों से भेजे गए फॉर्म डेटा से परिणाम प्राप्त करने के लिए PHP $ _REQUEST चर का उपयोग किया जा सकता है।

स्रोत कोड को test.php स्क्रिप्ट में डालकर निम्नलिखित उदाहरण देखें।

<?php
   if( $_REQUEST["name"] || $_REQUEST["age"] ) {
      echo "Welcome ". $_REQUEST['name']. "<br />";
      echo "You are ". $_REQUEST['age']. " years old.";
      exit();
   }
?>
<html>
   <body>
      
      <form action = "<?php $_PHP_SELF ?>" method = "POST">
         Name: <input type = "text" name = "name" />
         Age: <input type = "text" name = "age" />
         <input type = "submit" />
      </form>
      
   </body>
</html>

यहां $ _PHP_SELF चर में स्व स्क्रिप्ट का नाम है जिसमें इसे बुलाया जा रहा है।

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