PHP 8.4.1 Released!

Temel bir curl örneği

PHP, cURL desteğiyle derlenmişse cURL işlevleri kullanılabilir. cURL işlevlerinin kullanım amacı ve sırası, ana hatlarıyla, curl_init() işlevini kullanarak bir cURL oturumu başlatıp, aktarımın tüm seçeneklerini curl_setopt() ile belirledikten sonra oturumu curl_exec() ile çalıştırıp iş bitince curl_close() ile oturumu sonlandırmak şeklindedir. Burada, example.com ana sayfasını bir dosyaya aktarmak amacıyla cURL işlevlerinin kullanımı örneklenmiştir:

Örnek 1 - example.com ana sayfasını bir dosyaya aktarmak amacıyla cURL işlevlerinin kullanımı

<?php

$ch
= curl_init("http://www.example.com/");
$fp = fopen("example_homepage.txt", "w");

curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HEADER, 0);

curl_exec($ch);
if(
curl_error($ch)) {
fwrite($fp, curl_error($ch));
}
curl_close($ch);
fclose($fp);
?>

add a note

User Contributed Notes 1 note

up
48
Roberto Braga
9 years ago
It is important to notice that when using curl to post form data and you use an array for CURLOPT_POSTFIELDS option, the post will be in multipart format

<?php
$params
=['name'=>'John', 'surname'=>'Doe', 'age'=>36];
$defaults = array(
CURLOPT_URL => 'http://myremoteservice/',
CURLOPT_POST => true,
CURLOPT_POSTFIELDS => $params,
);
$ch = curl_init();
curl_setopt_array($ch, ($options + $defaults));
?>
This produce the following post header:

--------------------------fd1c4191862e3566
Content-Disposition: form-data; name="name"

Jhon
--------------------------fd1c4191862e3566
Content-Disposition: form-data; name="surnname"

Doe
--------------------------fd1c4191862e3566
Content-Disposition: form-data; name="age"

36
--------------------------fd1c4191862e3566--

Setting CURLOPT_POSTFIELDS as follow produce a standard post header

CURLOPT_POSTFIELDS => http_build_query($params),

Which is:
name=John&surname=Doe&age=36

This caused me 2 days of debug while interacting with a java service which was sensible to this difference, while the equivalent one in php got both format without problem.
To Top