Are there any bug reports about this at bugs.php.net ? If not, enter one and put the patch online somewhere were we can download it as text file. (and the url to that into the bug report)
Does this problem exist with PHP_4_3 branch?
--Jani
On Wed, 16 Mar 2005, Jozef Hatala wrote:
In some cases, the php://input stream returns incorrect data. This was discovered as a data corruption when directly parsing a POSTed XML with a long text-node.
The problem is between main/streams/streams.c and ext/standard/php_fopen_wrapper.c.
The XML parser requests data from the stream in 4000 byte chunks.
_php_stream_read requests data from the handler for php://input in 8192 byte chunks. It uses two counters stream->readpos and stream->writepos to handle the buffering. Just before returning the next 4000 byte chunk, _php_stream_read advances the stream->position.
The handler for php://input in php_stream_input_read uses stream->position to address the contents of SG(request_info).raw_post_data and serves a 8192 byte chunk starting at that position.
The problem shows itself on the third call of _php_stream_read. In the first iteration of the while(size>0) loop, it uses the 192 bytes left over in the buffer. In the second iteration it needs to refill to buffer, so it calls php_stream_input_read. But stream->position has not been advanced by 192 yet, so php_stream_input_read ends up returning a buffer starting with the same 192 bytes.
The patch consists in simply updating stream->position immediately, instead of accumulating didread and only updating stream->position at the end. This way php_stream_input_read always sees an accurate value of the stream->position.
Here it is. It is made against php-5.0.3, but it also applies to php5-200503161930.
==== begin ==== diff -ru php-5.0.3.orig/main/streams/streams.c php-5.0.3/main/streams/streams.c --- php-5.0.3.orig/main/streams/streams.c 2004-11-15 15:44:14.000000000 -0800 +++ php-5.0.3/main/streams/streams.c 2005-03-16 13:08:02.000000000 -0800 @@ -560,6 +560,7 @@ size -= toread; buf += toread; didread += toread; + stream->position += toread; }
/* ignore eof here; the underlying state might have changed */ @@ -584,6 +585,7 @@ } if (toread > 0) { didread += toread; + stream->position += toread; buf += toread; size -= toread; } else { @@ -596,10 +598,6 @@ break; }
- if (didread > 0) { - stream->position += didread; - } - return didread; }
==== end ====
-- https://www.paypal.com/xclick/[EMAIL PROTECTED]&no_note=1&tax=0¤cy_code=EUR
-- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php
