From: [EMAIL PROTECTED]
Operating system: Any
PHP version: 4.1.2
PHP Bug Type: cURL related
Bug description: curl post doesn't behave as per the manual
The curl extension is not behaving as described in the manual.
If you set CURLOPT_POST to 1, and then pass an array to
CURLOPT_POSTFIELDS, it sets Content-type to multipart/form-data instead of
application/x-www-form-urlencoded. This is wrong: the multipart header
should only be used when CURLOPT_PUT is set. To quote the PHP manual:
{{{CURLOPT_POST: Set this option to a non-zero value if you want PHP to do
a regular HTTP POST. This POST is a normal
application/x-www-form-urlencoded kind, most commonly used by HTML
forms.}}}
Here is what the author of curl (Daniel Stenberg) says - full message at
<http://curl.haxx.se/mail/curlphp-2001-11/0003.html>:
{{{I took a tour into the inner workings of the php curl wrapper code and
I've now returned to tell about my findings! ;-)
When you pass an array to CURLOPT_POSTFIELDS, it is passed as a
multipart/form-data post exactly as you describe. The problem with this is
that it uses the libcurl function curl_formparse() to accomplish this, and
that is a lame function(*).
It does not support newlines in the contents like you tried here.
The wrapper should instead use the new (and much better) curl_formadd()
function for this purpose. It does not have this newline problem.
(*) = yet it was the only available one for a very long time.}}}
I think there is enough evidence here to change the behaviour of the
extension - I think it can be done without breaking backwards
compatibility. The extension was never meant to behave like this, as the
manual testifies.
Regards,
Peter Bowyer.
--
Edit bug report at http://bugs.php.net/?id=16305&edit=1
--
Fixed in CVS: http://bugs.php.net/fix.php?id=16305&r=fixedcvs
Fixed in release: http://bugs.php.net/fix.php?id=16305&r=alreadyfixed
Need backtrace: http://bugs.php.net/fix.php?id=16305&r=needtrace
Try newer version: http://bugs.php.net/fix.php?id=16305&r=oldversion
Not developer issue: http://bugs.php.net/fix.php?id=16305&r=support
Expected behavior: http://bugs.php.net/fix.php?id=16305&r=notwrong
Not enough info: http://bugs.php.net/fix.php?id=16305&r=notenoughinfo
Submitted twice: http://bugs.php.net/fix.php?id=16305&r=submittedtwice