Curl и PHP - как я могу передать json через curl по PUT, POST, GET

Я работал над созданием REST API для ада, и я тестировал его, когда я иду, используя curl из командной строки, что очень легко для CRUD

Я могу успешно сделать этот вызов из командной строки

curl -u username:pass -X GET http://api.mysite.com/pet/1
curl -d '{"dog":"tall"}' -u username:pass -X GET http://api.mysite.com/pet
curl -d '{"dog":"short"}' -u username:pass -X POST http://api.mysite.com/pet
curl -d '{"dog":"tall"}' -u username:pass -X PUT http://api.mysite.com/pet/1

вышеуказанные вызовы легко сделать из командной строки и отлично работать с моим api, но теперь я хочу использовать PHP для создания завитка. Как вы можете видеть, я передаю данные как строку json. Я много читал и думаю, что смогу. вероятно, сделайте сообщение и включите поля POST, но я не смог узнать, как передать данные тела http с GET. Все, что я вижу, говорит, что вы должны прикрепить его к url-адресу, но это не выглядит так в форме командной строки. В любом случае, я бы хотел, чтобы кто-то мог написать правильный способ выполнения этих четырех операций в PHP здесь на одной странице. Хотелось бы увидеть самый простой способ сделать это с помощью curl и PHP. Я думаю, что мне нужно передать все через тело http, потому что мой php api ловить все с помощью php: / / input

5 ответов


поставить

$data = array('username'=>'dog','password'=>'tall');
$data_json = json_encode($data);

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json','Content-Length: ' . strlen($data_json)));
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PUT');
curl_setopt($ch, CURLOPT_POSTFIELDS,$data_json);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response  = curl_exec($ch);
curl_close($ch);

в должности

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json'));
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS,$data_json);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response  = curl_exec($ch);
curl_close($ch);

GET См. @Dan H answer

удалить

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "DELETE");
curl_setopt($ch, CURLOPT_POSTFIELDS,$data_json);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response  = curl_exec($ch);
curl_close($ch);

вы можете использовать эту небольшую библиотеку:https://github.com/jmoraleda/php-rest-curl

звонить так же просто, как:

// GET
$result = RestCurl::get($URL, array('id' => 12345678));

// POST
$result = RestCurl::post($URL, array('name' => 'John'));

// PUT
$result = RestCurl::put($URL, array('$set' => array('lastName' => "Smith")));

// DELETE
$result = RestCurl::delete($URL); 

и для переменной $result:

  • $result ['status'] - это код ответа HTTP
  • $result['data'] массив с ответом JSON проанализирован
  • $result ['header'] строка с заголовками ответов

надеюсь, что это помогает


для себя я просто кодирую его в url и использую $_GET на целевой странице. Вот строка в качестве примера.

$ch = curl_init();
$this->json->p->method = "whatever";
curl_setopt($ch, CURLOPT_URL, "http://" . $_SERVER['SERVER_NAME'] . $this->json->path . '?json=' . urlencode(json_encode($this->json->p)));
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$output = curl_exec($ch);
curl_close($ch);

EDIT: добавление фрагмента назначения... (EDIT 2 добавил больше выше по запросу OPs)

<?php
if(!isset($_GET['json']))
    die("FAILURE");
$json = json_decode($_GET['json']);
$method = $json->method;
...
?>

задайте еще одно свойство curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, false);


Я работал с эластичный SQL плагин. Запрос выполняется с помощью метода GET с помощью cURL, как показано ниже:

curl -XGET http://localhost:9200/_sql/_explain -H 'Content-Type: application/json' \
-d 'SELECT city.keyword as city FROM routes group by city.keyword order by city'

Я предоставил пользовательский порт на общедоступном сервере, делая обратный прокси с базовым набором Auth.

этот код отлично работает плюс базовый заголовок Auth:

$host = 'http://myhost.com:9200';
$uri = "/_sql/_explain";
$auth = "john:doe";
$data = "SELECT city.keyword as city FROM routes group by city.keyword order by city";

function restCurl($host, $uri, $data = null, $auth = null, $method = 'DELETE'){
    $ch = curl_init();

    curl_setopt($ch, CURLOPT_URL, $host.$uri);
    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);
    curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json'));
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

    if ($method == 'POST')
        curl_setopt($ch, CURLOPT_POST, 1);
    if ($auth)
        curl_setopt($ch, CURLOPT_USERPWD, $auth);
    if (strlen($data) > 0)
        curl_setopt($ch, CURLOPT_POSTFIELDS,$data);

    $resp  = curl_exec($ch);
    if(!$resp){
        $resp = (json_encode(array(array("error" => curl_error($ch), "code" => curl_errno($ch)))));
    }   
    curl_close($ch);
    return $resp;
}

$resp = restCurl($host, $uri); //DELETE
$resp = restCurl($host, $uri, $data, $auth, 'GET'); //GET
$resp = restCurl($host, $uri, $data, $auth, 'POST'); //POST
$resp = restCurl($host, $uri, $data, $auth, 'PUT'); //PUT