From:
Operating system: Windows 7 Pro x64
PHP version: 5.2.13
Package: cURL related
Bug Type: Bug
Bug description:file_get_contents('php://input') - empty string if called more
than once
Description:
------------
Second and consecutive calls of file_get_contents('php://input') return
empty string if client issued an HTTP command other than 'GET' or 'POST'
(see example code). If 'GET' or 'POST' HTTP command was issued
file_get_contents('php://input') works correctly.
Not sure if this is cURL related bug, maybe some other PHP package is
responsible.
I am using Apache 2.2 and IE8.
Test script:
---------------
#bug_curl.php
$hcurl = curl_init();
curl_setopt($hcurl, CURLOPT_URL, 'http://test/bug.php');
curl_setopt($hcurl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($hcurl, CURLOPT_HTTPHEADER, array('Content-Type:
text/plain'));
curl_setopt($hcurl, CURLOPT_POSTFIELDS, 'some request text');
curl_setopt($hcurl, CURLOPT_CUSTOMREQUEST, 'DELETE');
//curl_setopt($hcurl, CURLOPT_HTTPGET, true); - this works ok
//curl_setopt($hcurl, CURLOPT_POST, true); - this works ok
$out = curl_exec($hcurl);
curl_close($hcurl);
echo '<pre>'.htmlspecialchars($out).'</pre>';
# bug.php
var_dump(file_get_contents('php://input'));
var_dump(file_get_contents('php://input')); // returns empty string if HTTP
command is not 'GET' or POST'
var_dump(apache_request_headers());
Expected result:
----------------
string(17) "some request text"
string(17) "some request text"
array(4) {
["Host"]=>
string(4) "test"
["Accept"]=>
string(3) "*/*"
["Content-Type"]=>
string(10) "text/plain"
["Content-Length"]=>
string(2) "17"
}
Actual result:
--------------
string(17) "some request text"
string(0) ""
array(4) {
["Host"]=>
string(4) "test"
["Accept"]=>
string(3) "*/*"
["Content-Type"]=>
string(10) "text/plain"
["Content-Length"]=>
string(2) "17"
}
--
Edit bug report at http://bugs.php.net/bug.php?id=51592&edit=1
--
Try a snapshot (PHP 5.2):
http://bugs.php.net/fix.php?id=51592&r=trysnapshot52
Try a snapshot (PHP 5.3):
http://bugs.php.net/fix.php?id=51592&r=trysnapshot53
Try a snapshot (PHP 6.0):
http://bugs.php.net/fix.php?id=51592&r=trysnapshot60
Fixed in SVN:
http://bugs.php.net/fix.php?id=51592&r=fixed
Fixed in SVN and need be documented:
http://bugs.php.net/fix.php?id=51592&r=needdocs
Fixed in release:
http://bugs.php.net/fix.php?id=51592&r=alreadyfixed
Need backtrace:
http://bugs.php.net/fix.php?id=51592&r=needtrace
Need Reproduce Script:
http://bugs.php.net/fix.php?id=51592&r=needscript
Try newer version:
http://bugs.php.net/fix.php?id=51592&r=oldversion
Not developer issue:
http://bugs.php.net/fix.php?id=51592&r=support
Expected behavior:
http://bugs.php.net/fix.php?id=51592&r=notwrong
Not enough info:
http://bugs.php.net/fix.php?id=51592&r=notenoughinfo
Submitted twice:
http://bugs.php.net/fix.php?id=51592&r=submittedtwice
register_globals:
http://bugs.php.net/fix.php?id=51592&r=globals
PHP 4 support discontinued: http://bugs.php.net/fix.php?id=51592&r=php4
Daylight Savings: http://bugs.php.net/fix.php?id=51592&r=dst
IIS Stability:
http://bugs.php.net/fix.php?id=51592&r=isapi
Install GNU Sed:
http://bugs.php.net/fix.php?id=51592&r=gnused
Floating point limitations:
http://bugs.php.net/fix.php?id=51592&r=float
No Zend Extensions:
http://bugs.php.net/fix.php?id=51592&r=nozend
MySQL Configuration Error:
http://bugs.php.net/fix.php?id=51592&r=mysqlcfg