С Ответ Марко устарел, вы должны использовать следующий синтаксис (согласно комментарию jasonlfunk):
$client = new \GuzzleHttp\Client();
$response = $client->request('POST', 'http://www.example.com/user/create', [
'form_params' => [
'email' => '[email protected]',
'name' => 'Test user',
'password' => 'testpassword',
]
]);
Запрос с файлами POST
$response = $client->request('POST', 'http://www.example.com/files/post', [
'multipart' => [
[
'name' => 'file_name',
'contents' => fopen('/path/to/file', 'r')
],
[
'name' => 'csv_header',
'contents' => 'First Name, Last Name, Username',
'filename' => 'csv_header.csv'
]
]
]);
REST глаголы использования с Params
данных
// PUT
$client->put('http://www.example.com/user/4', [
'body' => [
'email' => '[email protected]',
'name' => 'Test user',
'password' => 'testpassword',
],
'timeout' => 5
]);
// DELETE
$client->delete('http://www.example.com/user');
Асинхронный POST
полезна для длительных операций сервера.
$client = new \GuzzleHttp\Client();
$promise = $client->requestAsync('POST', 'http://www.example.com/user/create', [
'form_params' => [
'email' => '[email protected]',
'name' => 'Test user',
'password' => 'testpassword',
]
]);
$promise->then(
function (ResponseInterface $res) {
echo $res->getStatusCode() . "\n";
},
function (RequestException $e) {
echo $e->getMessage() . "\n";
echo $e->getRequest()->getMethod();
}
);
Documentation более подробно рассказывает о новых возможностях.
Этот метод в настоящее время осуждается в 6.0. Вместо «тела» используйте «form_params». – jasonlfunk
Передача запроса «тело» в качестве массива для отправки запроса POST устарела. Пожалуйста, используйте параметр запроса «form_params» для отправки запроса приложения/x-www-form-urlencoded или опции «multipart» для отправки запроса multipart/form-data. –
@JeremyQuinton, так что вы выбрали именно это ... ответьте – Madhur