ID:               48419
 User updated by:  juro at shaw dot ca
 Reported By:      juro at shaw dot ca
-Status:           Feedback
+Status:           Open
 Bug Type:         CGI related
 Operating System: Windows XP
 PHP Version:      5.2.10RC1
 New Comment:

Using Windows XP OS we use a generic HTTP server (not Apache, not IIS,
etc.) with CGI/1.1 support (no FCGI). 
PHP script fills a form and uses:

CONTENT_TYPE = application/x-www-form-urlencoded 
REQUEST_METHOD = POST

to post some filled form data. The HTTP server launches PHP-CGI.EX and
writes the posted data to a handle that was redirected to be
PHP-CGI.EXE STDIN. PHP-CGI.EXE does receive the data, which can be
viewed correctly using the code:

        print "$HTTP_RAW_POST_DATA";
        print_r($_SERVER["HTTP_RAW_POST_DATA"]);

Both printouts show correctly (urlencoded) posted data.
However, the $_POST array is empty:

if (empty($_POST)) 
{
        echo "POST empty !!! (No data was submitted)";
}


Previous Comments:
------------------------------------------------------------------------

[2009-05-31 13:57:24] j...@php.net

Not enough information was provided for us to be able
to handle this bug. Please re-read the instructions at
http://bugs.php.net/how-to-report.php

If you can provide more information, feel free to add it
to this bug and change the status back to "Open".

Thank you for your interest in PHP.




------------------------------------------------------------------------

[2009-05-28 20:36:32] juro at shaw dot ca

Description:
------------
Using a generic web server with a simple CGI support (running on
Windows XP), I fail to obtain any $_POST data. However, raw post data
are OK. Raw post data is sent to the PHP-CGI.exe via redirected pipe
handle. PHP-CGI reads correctly posted raw data using stdin.

I suspect the culprit may be with the following PHP source code:

File:cgi_main.c
Routine:static int sapi_cgi_read_post(char *buffer, uint count_bytes
TSRMLS_DC)
                        
...
tmp_read_bytes = read(0, buffer + read_bytes, count_bytes -
read_bytes);
...

Low level i/o functions read,write,open are not 100% portable.
The code is most like meant to read stdin. Assuming that file
descriptor for stdin is numerically equal to 0 on all platforms is
wrong. 

The code should be probably something like this
tmp_read_bytes = read(_fileno(stdin), buffer + read_bytes, count_bytes
- read_bytes);






------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=48419&edit=1

Reply via email to