मैं फ्रेड टैन्रिकुत के कर्ल-आधारित उत्तर के बारे में कुछ विचार जोड़ना चाहूंगा। मुझे पता है कि उनमें से अधिकांश पहले से ही ऊपर दिए गए उत्तरों में लिखे गए हैं, लेकिन मुझे लगता है कि एक जवाब दिखाना एक अच्छा विचार है जिसमें सभी को एक साथ शामिल किया गया है।
यहाँ वह श्रेणी है जो मैंने HTTP-GET / POST / PUT / DELETE अनुरोध को कर्ल के आधार पर बनाने के लिए लिखी थी, केवल प्रतिक्रिया निकाय के बारे में:
class HTTPRequester {
/**
* @description Make HTTP-GET call
* @param $url
* @param array $params
* @return HTTP-Response body or an empty string if the request fails or is empty
*/
public static function HTTPGet($url, array $params) {
$query = http_build_query($params);
$ch = curl_init($url.'?'.$query);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, false);
$response = curl_exec($ch);
curl_close($ch);
return $response;
}
/**
* @description Make HTTP-POST call
* @param $url
* @param array $params
* @return HTTP-Response body or an empty string if the request fails or is empty
*/
public static function HTTPPost($url, array $params) {
$query = http_build_query($params);
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $query);
$response = curl_exec($ch);
curl_close($ch);
return $response;
}
/**
* @description Make HTTP-PUT call
* @param $url
* @param array $params
* @return HTTP-Response body or an empty string if the request fails or is empty
*/
public static function HTTPPut($url, array $params) {
$query = \http_build_query($params);
$ch = \curl_init();
\curl_setopt($ch, \CURLOPT_RETURNTRANSFER, true);
\curl_setopt($ch, \CURLOPT_HEADER, false);
\curl_setopt($ch, \CURLOPT_URL, $url);
\curl_setopt($ch, \CURLOPT_CUSTOMREQUEST, 'PUT');
\curl_setopt($ch, \CURLOPT_POSTFIELDS, $query);
$response = \curl_exec($ch);
\curl_close($ch);
return $response;
}
/**
* @category Make HTTP-DELETE call
* @param $url
* @param array $params
* @return HTTP-Response body or an empty string if the request fails or is empty
*/
public static function HTTPDelete($url, array $params) {
$query = \http_build_query($params);
$ch = \curl_init();
\curl_setopt($ch, \CURLOPT_RETURNTRANSFER, true);
\curl_setopt($ch, \CURLOPT_HEADER, false);
\curl_setopt($ch, \CURLOPT_URL, $url);
\curl_setopt($ch, \CURLOPT_CUSTOMREQUEST, 'DELETE');
\curl_setopt($ch, \CURLOPT_POSTFIELDS, $query);
$response = \curl_exec($ch);
\curl_close($ch);
return $response;
}
}
सुधार
- अनुरोध-सरणी से क्वेरी-स्ट्रिंग प्राप्त करने के लिए http_build_query का उपयोग करना। (आप स्वयं भी सरणी का उपयोग कर सकते हैं, इसलिए देखें: http://php.net/manual/en/function.curl-setopt.php )
- इसे प्रतिध्वनित करने के बजाए प्रतिक्रिया लौटाते हुए। Btw आप लाइन curl_setopt ($ ch, CURLOPT_RETURNTRANSFER, सच) को हटाकर वापसी से बच सकते हैं ; । उसके बाद वापसी मूल्य एक बूलियन है (सही = अनुरोध सफल था अन्यथा एक त्रुटि हुई) और प्रतिक्रिया प्रतिध्वनित होती है। देखें: http://php.net/en/manual/function.curl-exec.php
- कर्ल_क्लोज़ का उपयोग करके कर्ल-हैंडलर का क्लिनिंग सत्र समापन और विलोपन । देखें: http://php.net/manual/en/function.curl-close.php
- किसी भी नंबर का उपयोग करने के बजाय कर्ल_सेटॉप फ़ंक्शन के लिए बूलियन मानों का उपयोग करना । (मुझे पता है कि किसी भी संख्या को शून्य नहीं के बराबर भी माना जाता है, लेकिन सच का उपयोग अधिक पठनीय कोड उत्पन्न करता है, लेकिन यह सिर्फ मेरी राय है)
- HTTP-PUT / DELETE कॉल करने की क्षमता (उपयोगी सेवा परीक्षण के लिए उपयोगी)
उपयोग का उदाहरण
प्राप्त
$response = HTTPRequester::HTTPGet("http://localhost/service/foobar.php", array("getParam" => "foobar"));
पद
$response = HTTPRequester::HTTPPost("http://localhost/service/foobar.php", array("postParam" => "foobar"));
डाल
$response = HTTPRequester::HTTPPut("http://localhost/service/foobar.php", array("putParam" => "foobar"));
हटाएँ
$response = HTTPRequester::HTTPDelete("http://localhost/service/foobar.php", array("deleteParam" => "foobar"));
परिक्षण
आप इस सरल वर्ग का उपयोग करके कुछ शांत सेवा परीक्षण भी कर सकते हैं।
class HTTPRequesterCase extends TestCase {
/**
* @description test static method HTTPGet
*/
public function testHTTPGet() {
$requestArr = array("getLicenses" => 1);
$url = "http://localhost/project/req/licenseService.php";
$this->assertEquals(HTTPRequester::HTTPGet($url, $requestArr), '[{"error":false,"val":["NONE","AGPL","GPLv3"]}]');
}
/**
* @description test static method HTTPPost
*/
public function testHTTPPost() {
$requestArr = array("addPerson" => array("foo", "bar"));
$url = "http://localhost/project/req/personService.php";
$this->assertEquals(HTTPRequester::HTTPPost($url, $requestArr), '[{"error":false}]');
}
/**
* @description test static method HTTPPut
*/
public function testHTTPPut() {
$requestArr = array("updatePerson" => array("foo", "bar"));
$url = "http://localhost/project/req/personService.php";
$this->assertEquals(HTTPRequester::HTTPPut($url, $requestArr), '[{"error":false}]');
}
/**
* @description test static method HTTPDelete
*/
public function testHTTPDelete() {
$requestArr = array("deletePerson" => array("foo", "bar"));
$url = "http://localhost/project/req/personService.php";
$this->assertEquals(HTTPRequester::HTTPDelete($url, $requestArr), '[{"error":false}]');
}
}