it-swarm.com.ru

Скручиваемость и PHP - Как я могу пройти через JSON через 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 для создания curl. Как видите, я передаю данные в виде строки json. Я прочитал и думаю, что, возможно, смогу выполнить POST и включить поля POST, но я не смог выяснить, как передать данные http тела с помощью GET. Все, что я вижу, говорит о том, что вы должны прикрепить его к URL, но это не выглядит так в форме командной строки. В любом случае, я бы хотел, чтобы кто-то мог написать правильный способ выполнения этих четырех операций в PHP здесь на одной странице. Я хотел бы увидеть самый простой способ сделать это с помощью curl и php. Я думаю, что мне нужно пропустить все через тело http, потому что мой php api ловит все с помощью php: // input

47
Gilberg

ПОЛОЖИЛ

$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);

ПОЛУЧИТЬ Смотрите @Dan H ответ

УДАЛЯТЬ

$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);
136
voodoo417

Вы можете использовать эту небольшую библиотеку: 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'] строка с заголовками ответа

Надеюсь, поможет

10
ledfusion

Для себя я просто кодирую его в 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);

Правка: Добавление фрагмента назначения ... (РЕДАКТИРОВАНИЕ 2 добавлено выше при запросе OP)

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

Я работал с Elastic SQL plugin . Запрос выполняется методом 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'

Я выставил пользовательский порт на общедоступном сервере, делая обратный прокси-сервер с установленным Basic 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
0
Luiz Vaz