helly Sun May 21 13:37:19 2006 UTC
Added files: (Branch: PHP_5_2)
/php-src/ext/standard/tests/file stream_rfc2397_006.phpt
Modified files:
/php-src/main/streams memory.c
Log:
- MFH Handle corrupt base64 data in data: url
http://cvs.php.net/viewcvs.cgi/php-src/main/streams/memory.c?r1=1.8.2.6.2.4&r2=1.8.2.6.2.5&diff_format=u
Index: php-src/main/streams/memory.c
diff -u php-src/main/streams/memory.c:1.8.2.6.2.4
php-src/main/streams/memory.c:1.8.2.6.2.5
--- php-src/main/streams/memory.c:1.8.2.6.2.4 Sun May 14 19:15:31 2006
+++ php-src/main/streams/memory.c Sun May 21 13:37:19 2006
@@ -16,7 +16,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: memory.c,v 1.8.2.6.2.4 2006/05/14 19:15:31 helly Exp $ */
+/* $Id: memory.c,v 1.8.2.6.2.5 2006/05/21 13:37:19 helly Exp $ */
#define _GNU_SOURCE
#include "php.h"
@@ -652,21 +652,25 @@
}
add_assoc_bool(meta, "base64", base64);
+ /* skip ',' */
+ comma++;
+ dlen--;
+
+ if (base64) {
+ comma = (char*)php_base64_decode((const unsigned char *)comma,
dlen, &ilen);
+ if (!comma) {
+ php_stream_wrapper_log_error(wrapper, options
TSRMLS_CC, "rfc2397: unable to decode");
+ return NULL;
+ }
+ } else {
+ comma = estrndup(comma, dlen);
+ ilen = dlen = php_url_decode(comma, dlen);
+ }
+
if ((stream = php_stream_temp_create_rel(0, ~0u)) != NULL) {
- /* skip ',' */
- comma++;
- dlen--;
/* store data */
- if (base64) {
- comma = (char*)php_base64_decode((const unsigned char
*)comma, dlen, &ilen);
- php_stream_temp_write(stream, comma, ilen TSRMLS_CC);
- efree(comma);
- } else {
- comma = estrndup(comma, dlen);
- dlen = php_url_decode(comma, dlen);
- php_stream_temp_write(stream, comma, dlen TSRMLS_CC);
- efree(comma);
- }
+ php_stream_temp_write(stream, comma, ilen TSRMLS_CC);
+ efree(comma);
php_stream_temp_seek(stream, 0, SEEK_SET, &newoffs TSRMLS_CC);
/* set special stream stuff (enforce exact mode) */
vlen = strlen(mode);
http://cvs.php.net/viewcvs.cgi/php-src/ext/standard/tests/file/stream_rfc2397_006.phpt?view=markup&rev=1.1
Index: php-src/ext/standard/tests/file/stream_rfc2397_006.phpt
+++ php-src/ext/standard/tests/file/stream_rfc2397_006.phpt
--TEST--
Stream: RFC2397 with corrupt? payload
--FILE--
<?php
$streams = array(
"data:;base64,\0Zm9vYmFyIGZvb2Jhcg==",
"data:;base64,Zm9vYmFy\0IGZvb2Jhcg==",
'data:;base64,#Zm9vYmFyIGZvb2Jhcg==',
'data:;base64,#Zm9vYmFyIGZvb2Jhc=',
);
foreach($streams as $stream)
{
var_dump(file_get_contents($stream));
}
?>
===DONE===
<?php exit(0); ?>
--EXPECTF--
string(0) ""
string(6) "foobar"
string(13) "foobar foobar"
Warning: file_get_contents(data:;base64,#Zm9vYmFyIGZvb2Jhc=): failed to open
stream: rfc2397: unable to decode in %sstream_rfc2397_006.php on line %d
bool(false)
===DONE===
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php