|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
[2009-08-26 13:30 UTC] sergk at sergk dot org dot ua
Description:
------------
There is segfault in strncasecmp calling from this code:
curl/interface.c:186 :
if (!strncasecmp("file", uri->scheme, sizeof("file"))) {
...
when URI is without protocol part hence uri->scheme is NULL.
Like in this example of backtrace:
#0 0xb7e20a8b in strncasecmp () from /lib/i686/cmov/libc.so.6
#1 0xb777dd11 in php_curl_option_url (ch=0x856be00,
url=0x856e360 "show.setlinks.ru/?host=SCREENEDHOSTNAME&k=WINDOWS-1251&p=b44eff595164745dee4a6a655a57a425",
len=<value optimized out>) at /opt/src/build/apache-1-dweb/dbuild/003d/php-5.2.10/ext/curl/interface.c:187
This bug is also present in last 5.2.x development snapshot.
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
|
|||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Thu Oct 30 22:00:01 2025 UTC |
this patch will fix bug: --- php-5.2.10.orig/ext/curl/interface.c 2009-06-15 12:38:11.000000000 +0000 +++ php-5.2.10/ext/curl/interface.c 2009-08-26 11:22:15.000000000 +0000 @@ -183,10 +183,12 @@ return 0; } - if (!strncasecmp("file", uri->scheme, sizeof("file"))) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "Protocol 'file' disabled in cURL"); - php_url_free(uri); - return 0; + if (uri->scheme != NULL) { + if (!strncasecmp("file", uri->scheme, sizeof("file")-1)) { + php_error_docref(NULL TSRMLS_CC, E_WARNING, "Protocol 'file' disabled in cURL"); + php_url_free(uri); + return 0; + } } php_url_free(uri); #endifYes, this one trigger segfault, but only in mod_php mode: <?PHP $curl = curl_init("www.php.net/manual/en/function.curl-init.php"); curl_exec($curl); curl_close($curl); ?>Please don't apply that patch, you can do it with single line change too.. if (uri->scheme && !strncasecmp("file", uri->scheme, sizeof("file"))) rather than having several lines changed for nothing.