]> granicus.if.org Git - php/commitdiff
Fixed bug #49851 (http wrapper breaks on 1024 char long headers).
authorIlia Alshanetsky <iliaa@php.net>
Thu, 10 Dec 2009 03:23:05 +0000 (03:23 +0000)
committerIlia Alshanetsky <iliaa@php.net>
Thu, 10 Dec 2009 03:23:05 +0000 (03:23 +0000)
NEWS
ext/standard/http_fopen_wrapper.c

diff --git a/NEWS b/NEWS
index 2d81093a87e39d539ed2adc56537b1810aa20d2a..4be86efe9f7c8deddb292c956a82326862a98d0e 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -95,6 +95,7 @@ PHP                                                                        NEWS
 - Fixed bug #49866 (Making reference on string offsets crashes PHP). (Dmitry)
 - Fixed bug #49855 (import_request_variables() always returns NULL). (Ilia,
   sjoerd at php dot net)
+- Fixed bug #49851 (http wrapper breaks on 1024 char long headers). (Ilia)
 - Fixed bug #49800 (SimpleXML allow (un)serialize() calls without warning).
   (Ilia, wmeler at wp-sa dot pl)
 - Fixed bug #49719 (ReflectionClass::hasProperty returns true for a private
index 0e598909fa93256bedf9ea1bf71fefda55cf64b9..9e144b79544ef57a588b3dad419c9899506a142c 100644 (file)
@@ -610,6 +610,10 @@ php_stream *php_stream_url_wrap_http_ex(php_stream_wrapper *wrapper, char *path,
                size_t http_header_line_length;
                if (php_stream_get_line(stream, http_header_line, HTTP_HEADER_BLOCK_SIZE, &http_header_line_length) && *http_header_line != '\n' && *http_header_line != '\r') {
                        char *e = http_header_line + http_header_line_length - 1;
+                       if (*e != '\n') { /* partial header */
+                               php_stream_get_line(stream, http_header_line, HTTP_HEADER_BLOCK_SIZE, &http_header_line_length);
+                               continue;
+                       }
                        while (*e == '\n' || *e == '\r') {
                                e--;
                        }