From: Pierrick Charron Date: Sat, 21 Nov 2009 01:22:32 +0000 (+0000) Subject: Fixed bug #50219 (soap call Segmentation fault on a redirected url). X-Git-Tag: php-5.4.0alpha1~191^2~2371 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=121f1066857aba3e014fe105ea73dda31505e99f;p=php Fixed bug #50219 (soap call Segmentation fault on a redirected url). --- diff --git a/ext/soap/php_http.c b/ext/soap/php_http.c index dae863a4c7..0207cf7cc1 100644 --- a/ext/soap/php_http.c +++ b/ext/soap/php_http.c @@ -996,12 +996,20 @@ try_again: new_url->host = phpurl->host ? estrdup(phpurl->host) : NULL; new_url->port = phpurl->port; if (new_url->path && new_url->path[0] != '/') { - char *t = phpurl->path; - char *p = strrchr(t, '/'); - if (p) { - char *s = emalloc((p - t) + strlen(new_url->path) + 2); - strncpy(s, t, (p - t) + 1); - s[(p - t) + 1] = 0; + if (phpurl->path) { + char *t = phpurl->path; + char *p = strrchr(t, '/'); + if (p) { + char *s = emalloc((p - t) + strlen(new_url->path) + 2); + strncpy(s, t, (p - t) + 1); + s[(p - t) + 1] = 0; + strcat(s, new_url->path); + efree(new_url->path); + new_url->path = s; + } + } else { + char *s = emalloc(strlen(new_url->path) + 2); + s[0] = '/'; s[1] = 0; strcat(s, new_url->path); efree(new_url->path); new_url->path = s;