]> granicus.if.org Git - php/commitdiff
MFH (r-1.51) #32371 php://input sometimes returns duplicate data
authorSara Golemon <pollita@php.net>
Thu, 17 Nov 2005 19:40:38 +0000 (19:40 +0000)
committerSara Golemon <pollita@php.net>
Thu, 17 Nov 2005 19:40:38 +0000 (19:40 +0000)
ext/standard/php_fopen_wrapper.c

index dec178051de1cb6cc7138506d41474660a2280c5..0202592145caf89d054b6830ddc98febaf6a28d3 100644 (file)
@@ -73,17 +73,19 @@ static size_t php_stream_input_write(php_stream *stream, const char *buf, size_t
 
 static size_t php_stream_input_read(php_stream *stream, char *buf, size_t count TSRMLS_DC)
 {
+       off_t *position = (off_t*)stream->abstract;
        size_t read_bytes = 0;
+
        if(!stream->eof) {
                if(SG(request_info).raw_post_data) { /* data has already been read by a post handler */
-                       read_bytes = SG(request_info).raw_post_data_length - stream->position;
+                       read_bytes = SG(request_info).raw_post_data_length - *position;
                        if(read_bytes <= count) {
                                stream->eof = 1;
                        } else {
                                read_bytes = count;
                        }
                        if(read_bytes) {
-                               memcpy(buf, SG(request_info).raw_post_data + stream->position, read_bytes);
+                               memcpy(buf, SG(request_info).raw_post_data + *position, read_bytes);
                        }
                } else if(sapi_module.read_post) {
                        read_bytes = sapi_module.read_post(buf, count TSRMLS_CC);
@@ -96,12 +98,15 @@ static size_t php_stream_input_read(php_stream *stream, char *buf, size_t count
                }
        }
 
+       *position += read_bytes;
        SG(read_post_bytes) += read_bytes;
     return read_bytes;
 }
 
 static int php_stream_input_close(php_stream *stream, int close_handle TSRMLS_DC)
 {
+       efree(stream->abstract);
+
        return 0;
 }
 
@@ -162,7 +167,7 @@ php_stream * php_stream_url_wrap_php(php_stream_wrapper *wrapper, char *path, ch
        }
        
        if (!strcasecmp(path, "input")) {
-               return php_stream_alloc(&php_stream_input_ops, NULL, 0, "rb");
+               return php_stream_alloc(&php_stream_input_ops, ecalloc(1, sizeof(off_t)), 0, "rb");
        }  
        
        if (!strcasecmp(path, "stdin")) {