Dal La risposta di Marco è deprecata, è necessario utilizzare la seguente sintassi (in base al commento di 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',
]
]);
richiesta con i file POST utilizzo
$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'
]
]
]);
verbi riposo con params
dati
// 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');
Async POST
utile per le operazioni del server lunghi.
$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 è più esplicita su nuove possibilità.
Questo metodo è ora deprecato in 6.0. Invece di "corpo" usa "form_params". – jasonlfunk
Il passaggio all'opzione di richiesta "corpo" come una matrice per inviare una richiesta POST è stata deprecata. Utilizzare l'opzione di richiesta "form_params" per inviare una richiesta application/x-www-form-urlencoded o un'opzione di richiesta "multipart" per inviare una richiesta multipart/form-data. –
@JeremyQuinton, quindi quello che hai selezionato è quello che vuoi ... per favore rispondi – Madhur