Converteer curl-opdrachten naar PHP-code - Genereer direct bruikbare PHP cURL-code voor API-verzoeken
"https://api.example.com/data", CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => "", CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 30, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => "POST", CURLOPT_POSTFIELDS => json_encode(["name" => "test"]), CURLOPT_HTTPHEADER => [ "Content-Type: application/json" ], ]); $response = curl_exec($curl); $err = curl_error($curl); curl_close($curl); if ($err) { echo "cURL Error #:" . $err; } else { echo $response; }
Hier zijn enkele veelvoorkomende curl-opdrachten die u naar PHP-code kunt converteren:
curl https://api.example.com/users
curl -X POST -H "Content-Type: application/json" -d '{"name":"John","email":"[email protected]"}' https://api.example.com/users
curl -X PUT -H "Authorization: Bearer token123" -d '{"status":"active"}' https://api.example.com/users/1
curl -X DELETE https://api.example.com/users/1
curl -H "X-API-Key: abc123" -H "Accept: application/json" https://api.example.com/data
PHP's cURL-extensie biedt een krachtige manier om HTTP-verzoeken te doen. Hier zijn enkele veelvoorkomende PHP cURL-patronen:
"https://api.example.com/upload", CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => "", CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 30, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => "POST", CURLOPT_POSTFIELDS => [ 'file' => $cfile ], CURLOPT_HTTPHEADER => [ "Authorization: Bearer YOUR_TOKEN_HERE" ], ]); $response = curl_exec($curl); $err = curl_error($curl); curl_close($curl); if ($err) { echo "cURL Error #:" . $err; } else { echo $response; }
"https://api.example.com/data", CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => "", CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 5, // 5 seconds timeout CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => "GET", ]); $response = curl_exec($curl); $err = curl_error($curl); $httpCode = curl_getinfo($curl, CURLINFO_HTTP_CODE); curl_close($curl); if ($err) { echo "cURL Error: " . $err; } else { if ($httpCode >= 400) { echo "HTTP Error: " . $httpCode . "\n"; echo "Response: " . $response; } else { $data = json_decode($response, true); if (json_last_error() === JSON_ERROR_NONE) { // Process JSON data print_r($data); } else { echo "JSON parsing error: " . json_last_error_msg(); echo "Raw response: " . $response; } } }
Kopieer uw curl-opdracht → Plak in het invoerveld → Krijg geconverteerde PHP cURL-code
true, CURLOPT_ENCODING => "", CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 30, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_HTTPHEADER => [ "Authorization: Bearer YOUR_TOKEN_HERE", "Content-Type: application/json", "Accept: application/json" ], ]; // First request curl_setopt_array($curl, $options + [ CURLOPT_URL => "https://api.example.com/users", CURLOPT_CUSTOMREQUEST => "GET", ]); $response1 = curl_exec($curl); $err1 = curl_error($curl); // Second request with the same session curl_setopt_array($curl, $options + [ CURLOPT_URL => "https://api.example.com/products", CURLOPT_CUSTOMREQUEST => "GET", ]); $response2 = curl_exec($curl); $err2 = curl_error($curl); curl_close($curl); // Process responses $users = json_decode($response1, true); $products = json_decode($response2, true);
Onze tool verwerkt deze veelvoorkomende curl-opties en converteert ze naar de juiste PHP cURL-code:
A: De gegenereerde PHP cURL-code is compatibel met PHP 5.5 en hoger. Voor oudere PHP-versies kunnen kleine aanpassingen nodig zijn, vooral voor de CURLFile-klasse die wordt gebruikt bij bestandsuploads.
A: Ja, de gegenereerde code bevat basis foutafhandeling voor cURL-fouten. Voor productiecode wilt u mogelijk uitgebreidere foutafhandeling toevoegen die specifiek is voor uw applicatiebehoeften.
A: Voor JSON-responses gebruikt u json_decode() om de response te verwerken naar een PHP-array of -object. Voor andere formaten kunt u de ruwe responsestring naar behoefte verwerken.
A: Ja, u heeft de cURL-extensie nodig die is ingeschakeld in uw PHP-installatie. De meeste moderne PHP-installaties hebben cURL standaard ingeschakeld. U kunt dit controleren met php -m | grep curl
in uw terminal.
A: Voor bestandsuploads in PHP moet u de CURLFile-klasse gebruiken. Onze converter verwerkt curl-opdrachten met -F
of --form
opties en genereert de juiste PHP-code met CURLFile.
A: PHP's cURL-extensie biedt opties voor cookie-afhandeling. Wanneer u curl-opdrachten converteert die cookie-afhandeling bevatten (met -b
of --cookie
), genereert onze tool PHP-code die cookies correct beheert met CURLOPT_COOKIE of CURLOPT_COOKIEFILE/CURLOPT_COOKIEJAR opties.
A: Terwijl command-line curl uitstekend is voor snelle API-tests, stelt PHP cURL u in staat om HTTP-verzoeken direct in uw PHP-applicaties te integreren. Het converteren van curl naar PHP helpt de kloof tussen testen en implementatie in PHP-ontwikkeling te overbruggen.
Het begrijpen van curl-opdrachten is essentieel voor effectief API-testen met PHP. Hier is een snelle referentie van veelvoorkomende curl-opties die onze converter ondersteunt:
curl [options] [URL]
-X, --request METHOD
: Specify request method (GET, POST, PUT, DELETE, etc.)-H, --header LINE
: Add header to the request-d, --data DATA
: Send data in POST request-F, --form CONTENT
: Submit form data-u, --user USER:PASSWORD
: Server user and password-k, --insecure
: Allow insecure server connections-I, --head
: Show document info only-v, --verbose
: Make the operation more verbose-s, --silent
: Silent mode--connect-timeout SECONDS
: Maximum time for connectionOnze PHP-converter verwerkt complexe curl-opdrachten, inclusief meerdere headers, authenticatie, data payloads en verschillende opties. Plak simpelweg uw curl-opdracht en krijg schone, moderne PHP-code met de cURL-extensie.
Volg bij het werken met PHP cURL deze best practices voor efficiënte en veilige API-interacties:
2. Gebruik curl_setopt_array voor meerdere opties
"https://api.example.com/data", CURLOPT_RETURNTRANSFER => true, CURLOPT_TIMEOUT => 30, CURLOPT_CUSTOMREQUEST => "GET", CURLOPT_HTTPHEADER => [ "Authorization: Bearer token123", "Accept: application/json" ], ]); $response = curl_exec($curl); curl_close($curl);3. Implementeer uitgebreide foutafhandeling
"https://api.example.com/data", CURLOPT_RETURNTRANSFER => true, CURLOPT_TIMEOUT => 30, CURLOPT_CUSTOMREQUEST => "GET", ]); $response = curl_exec($curl); $errno = curl_errno($curl); $httpCode = curl_getinfo($curl, CURLINFO_HTTP_CODE); curl_close($curl); if ($errno) { // Handle cURL errors switch ($errno) { case CURLE_OPERATION_TIMEDOUT: echo "Request timed out"; break; case CURLE_COULDNT_CONNECT: echo "Could not connect to server"; break; default: echo "cURL error ({$errno}): " . curl_strerror($errno); } } else if ($httpCode >= 400) { // Handle HTTP errors echo "HTTP error: {$httpCode}"; } else { // Process successful response $data = json_decode($response, true); // Continue processing... }