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 चर में स्व स्क्रिप्ट का नाम है जिसमें इसे बुलाया जा रहा है।
यह निम्नलिखित परिणाम का उत्पादन करेगा -