mirror of
https://github.com/php/php-src.git
synced 2024-11-25 02:44:58 +08:00
Fixed bug #48929 (Double \r\n after HTTP headers when "header" context option is an array)
This commit is contained in:
parent
a56e81fe13
commit
c0aab038ba
2
NEWS
2
NEWS
@ -8,6 +8,8 @@ PHP NEWS
|
||||
- Added support for proc_open()'s bypass_shell feature for Unix systems
|
||||
(Gwynne, Nuno)
|
||||
|
||||
- Fixed bug #48929 (Double \r\n after HTTP headers when "header" context
|
||||
option is an array). (David Zülke)
|
||||
- Fixed bug #48899 (is_callable returns true even if method does not exist in
|
||||
parent class). (Felipe)
|
||||
- Fixed bug #48893 (Problems compiling with Curl). (Felipe)
|
||||
|
@ -348,7 +348,8 @@ php_stream *php_stream_url_wrap_http_ex(php_stream_wrapper *wrapper, char *path,
|
||||
}
|
||||
}
|
||||
smart_str_0(&tmpstr);
|
||||
tmp = tmpstr.c;
|
||||
/* Remove newlines and spaces from start and end. there's at least one extra \r\n at the end that needs to go. */
|
||||
tmp = php_trim(tmpstr.c, strlen(tmpstr.c), NULL, 0, NULL, 3 TSRMLS_CC);
|
||||
}
|
||||
if (Z_TYPE_PP(tmpzval) == IS_STRING && Z_STRLEN_PP(tmpzval)) {
|
||||
/* Remove newlines and spaces from start and end php_trim will estrndup() */
|
||||
|
56
ext/standard/tests/http/bug48929.phpt
Normal file
56
ext/standard/tests/http/bug48929.phpt
Normal file
@ -0,0 +1,56 @@
|
||||
--TEST--
|
||||
Bug #: duplicate \r\n sent after last header line
|
||||
--SKIPIF--
|
||||
<?php require 'server.inc'; http_server_skipif('tcp://127.0.0.1:12342'); ?>
|
||||
--FILE--
|
||||
<?php
|
||||
require 'server.inc';
|
||||
|
||||
function do_test($context_options) {
|
||||
|
||||
$context = stream_context_create(array('http' => $context_options));
|
||||
|
||||
$responses = array(
|
||||
"data://text/plain,HTTP/1.0 200 OK\r\n\r\n",
|
||||
);
|
||||
|
||||
$pid = http_server("tcp://127.0.0.1:12342", $responses, $output);
|
||||
|
||||
foreach($responses as $r) {
|
||||
|
||||
$fd = fopen('http://127.0.0.1:12342/', 'rb', false, $context);
|
||||
|
||||
fseek($output, 0, SEEK_SET);
|
||||
var_dump(stream_get_contents($output));
|
||||
fseek($output, 0, SEEK_SET);
|
||||
}
|
||||
|
||||
http_server_kill($pid);
|
||||
}
|
||||
|
||||
echo "-- Test: requests with 'header' as array --\n";
|
||||
|
||||
do_test(array('header' => array('X-Foo: bar', 'Content-Type: text/plain'), 'method' => 'POST', 'content' => 'ohai'));
|
||||
|
||||
echo "-- Test: requests with 'header' as string --\n";
|
||||
|
||||
do_test(array('header' => "X-Foo: bar\r\nContent-Type: text/plain", 'method' => 'POST', 'content' => 'ohai'));
|
||||
|
||||
?>
|
||||
--EXPECT--
|
||||
-- Test: requests with 'header' as array --
|
||||
string(103) "POST / HTTP/1.0
|
||||
Host: 127.0.0.1:12342
|
||||
Content-Length: 4
|
||||
X-Foo: bar
|
||||
Content-Type: text/plain
|
||||
|
||||
ohai"
|
||||
-- Test: requests with 'header' as string --
|
||||
string(103) "POST / HTTP/1.0
|
||||
Host: 127.0.0.1:12342
|
||||
Content-Length: 4
|
||||
X-Foo: bar
|
||||
Content-Type: text/plain
|
||||
|
||||
ohai"
|
Loading…
Reference in New Issue
Block a user