FuelPHP - अनुरोध और प्रतिक्रिया

HTTP अनुरोध और HTTP प्रतिक्रिया किसी भी वेब अनुप्रयोग में एक महत्वपूर्ण भूमिका निभाते हैं। हमें इसे ठीक से संसाधित करने के लिए http अनुरोध का पूरा विवरण प्राप्त करने की आवश्यकता है। एक बार संसाधित होने के बाद, हमें http प्रतिक्रिया के माध्यम से क्लाइंट को संसाधित डेटा भेजने की आवश्यकता है।

FuelPHP उत्कृष्ट प्रदान करता है Request तथा Responseक्रमशः HTTP अनुरोध और HTTP प्रतिक्रिया पढ़ने और लिखने के लिए कक्षा। आइए हम दोनों के बारे में जानेंRequest तथा Response इस अध्याय में कक्षा।

निवेदन

एक विशिष्ट वेब एप्लिकेशन में, एप्लिकेशन को वर्तमान अनुरोध के विवरण को पार्स करने की आवश्यकता होती है। अनुरोध वर्ग आवेदन द्वारा संसाधित किए जाने वाले वर्तमान अनुरोध को पार्स करने के लिए सरल तरीके प्रदान करता है। अनुरोध भी http क्लाइंट के रूप में कार्य करके एक नया अनुरोध बनाने का विकल्प प्रदान करता है।

एक नया अनुरोध बनाने से एप्लिकेशन को एप्लिकेशन के अन्य भाग या पूरी तरह से किसी अन्य एप्लिकेशन का अनुरोध करने और परिणाम दिखाने में सक्षम बनाता है। आइए हम इस अध्याय में आने वाले अनुरोध को पार्स करना सीखें और एचएमवीसी अनुरोध अध्याय में एक नया अनुरोध बनाना सीखें।

एक अनुरोध पार्स करना

Http अनुरोध के विवरण प्राप्त करने के लिए अनुरोध वर्ग तीन तरीके प्रदान करता है। वे इस प्रकार हैं,

active - यह एक स्थिर विधि है, जो वर्तमान सक्रिय http अनुरोध को वापस करता है।

$currentRequest = Request::active();

परम - यह निर्दिष्ट पैरामीटर का मान लौटाता है। इसमें दो तर्क दिए गए हैं। पहला तर्क पैरामीटर नाम है और दूसरा तर्क मान को वापस करने के लिए है, यदि पैरामीटर वर्तमान http अनुरोध में उपलब्ध नहीं है।

$param = Request::active()->param('employee_name', 'none');

params - यह एक पैरामीटर के रूप में एक सरणी के रूप में सभी मापदंडों को छोड़कर सिवाय इसके जैसे ही है।

$params = Request::active()->params();

उदाहरण

हमें एक सरल फ़ॉर्म बनाने और अनुरोध वर्ग का उपयोग करके फ़ॉर्म को संसाधित करना है।

Step 1- कर्मचारी कंट्रोलर में एक नया एक्शन, एक्शन_रेक्स्ट बनाएं ।

public function action_request() {
}

Step 2 - वर्तमान अनुरोध के सभी मापदंडों को प्राप्त करने के लिए अनुरोध विधियों को कॉल करें।

public function action_request() {
   $params = Request::active()->params();
}

Step 3 - प्राप्त पैरामीटर सरणी को डंप करें।

public function action_request() {
   $params = Request::active()->params();
   echo dump($params);
}

Step 4- रूट कॉन्फ़िगरेशन फ़ाइल, ईंधन / एप्लिकेशन / कॉन्फ़िगरेशन / मार्गों में पैरामीटर शामिल करने के लिए रूटिंग बदलें

'employee/request(/:name)?' => array('employee/request', 'name' => 'name'),

अब, नई कार्रवाई का अनुरोध करते हुए, http: // localhost: 8080 / कर्मचारी / अनुरोध / जॉन , यह निम्नलिखित प्रतिक्रिया दिखाएगा।

प्रतिक्रिया

प्रतिक्रिया वर्ग एक HTTP प्रतिक्रिया बनाने के लिए विकल्प प्रदान करता है। डिफ़ॉल्ट रूप से, हमें अधिकांश स्थितियों में सीधे प्रतिक्रिया वर्ग का उपयोग करने की आवश्यकता नहीं है। इसके बजाय, हम http प्रतिक्रिया बनाने के लिए View (जो हम अगले अध्याय में सीखेंगे) का उपयोग करते हैं। देखें डेवलपर से http प्रतिक्रिया छुपाता है और अंतर्निहित प्रतिक्रिया वर्ग का उपयोग करके क्लाइंट को प्रतिक्रिया भेजता है । एक उन्नत स्थिति में, हम सीधे रिस्पांस क्लास का उपयोग करते हैं और एक पूर्ण http प्रतिक्रिया बनाते हैं।

एक प्रतिक्रिया बनाना

प्रतिक्रिया में हेडर और शरीर शामिल हैं। मुख्य हैडर http स्थिति कोड है। प्रतिक्रिया का वर्णन करने के लिए HTTP प्रोटोकॉल में Http स्थिति कोड मानक कोड हैं। उदाहरण के लिए, एक स्थिति कोड, 200 का अर्थ है अनुरोध सफलता है।

प्रतिक्रिया वर्ग http प्रतिक्रिया बनाने के लिए तीन तर्क प्रदान करता है,

  • $body - http प्रतिक्रिया का निकाय
  • $status_code - http प्रतिक्रिया की स्थिति कोड
  • $headers - सरणी के रूप में वैकल्पिक हेडर
$body = "Hi, FuelPHP";
$headers = array (
   'Content-Type' => 'text/html',
);
$response = new Response($body, 200, $headers);

हमें एक नया कार्रवाई बनाएँ, action_response कर्मचारी नियंत्रक के रूप में इस प्रकार है।

public function action_response() {
   $body = "Hi, FuelPHP";
   $headers = array (
      'Content-Type' => 'text/html',
   );
   $response = new Response($body, 200, $headers);
   return $response;
}

परिणाम

तरीकों

प्रतिक्रिया प्रतिक्रियाओं को हेरफेर करने के लिए रिस्पॉन्स क्लास बहुत सारे तरीके प्रदान करता है। वे इस प्रकार हैं,

forge - यह रिस्पॉन्स क्लास कंस्ट्रक्टर जैसा ही है जैसा कि ऊपर देखा गया है।

return Response::forge("Hi, FuelPHP", 404);

redirect- यह प्रतिक्रिया भेजने के बजाय URL पर पुनर्निर्देशित करने का विकल्प प्रदान करता है। इसमें निम्नलिखित तर्क दिए गए हैं,

a.url- गंतव्य url b। विधि - पुनर्निर्देशन के तरीके। स्थान (डिफ़ॉल्ट) और ताज़ा करें c.redirect_code - http स्थिति कोड। डिफ़ॉल्ट मान 302 है।

// use a URL
Response::redirect('http://some-domain/index', 'refresh');
// or use a relative URI
Response::redirect('employee/list');

redirect_back- यह पिछले पृष्ठ पर रीडायरेक्ट करने के अलावा रीडायरेक्ट पद्धति के समान है। यदि कोई बैक पेज उपलब्ध नहीं है, तो हम पुनर्निर्देशन पृष्ठ निर्दिष्ट कर सकते हैं।

// If there is no back page, go to the employee list page
Response::redirect_back('/employee/list', 'refresh');

set_status - यह http स्टेटस कोड सेट करने का विकल्प प्रदान करता है।

$response = new Response();
$response->set_status(404);

set_header - यह http हेडर सेट करने के लिए एक विकल्प प्रदान करता है।

$response = new Response();
$response->set_header('Content-Type', 'application/pdf');
// replace previous value using third arguments
$response->set_header('Content-Type', 'application/pdf', 'text/plain');

set_headers- यह set_header के समान है सिवाय इसके कि यह सरणी का उपयोग करके कई हेडर सेट करने का विकल्प प्रदान करता है।

$response = new Response();
$response->set_headers(array
   'Content-Type' => 'application/pdf',
   'Pragma' => 'no-cache',
));

get_header - यह पिछले सेट हेडर विवरण प्राप्त करने में सक्षम बनाता है।

$response = new Response();
$response->set_header('Pragma', 'no-cache');
// returns 'no-cache'
$header = $response->get_header('Pragma');
// returns array('Pragma' => 'no-cache')
$header = $response->get_header();

body - यह http प्रतिक्रिया का मुख्य भाग सेट करने के लिए एक विकल्प प्रदान करता है।

$response = new Response();
$response->body('Hi, FuelPHP');
// returns 'Hi, FuelPHP'
$body = $response->body();

send_headers- यह अनुरोधित क्लाइंट को हेडर भेजता है। फ्यूलफेप क्लाइंट को प्रतिक्रिया भेजने के लिए इस विधि का उपयोग करता है। आम तौर पर, हमें इस पद्धति का उपयोग करने की आवश्यकता नहीं है।

$response->send_headers();

Send - हेडर को छोड़कर send_headers के रूप में भी http प्रतिक्रिया में प्रतिबंधित किया जा सकता है।

// send the headers as well
$response->send(true);
// only send the body
$response->send(false);
$response->send();