From: Dmitry Stogov Date: Wed, 1 Feb 2012 11:26:57 +0000 (+0000) Subject: Fixed basic HTTP authentication for WSDL sub requests X-Git-Tag: php-5.4.0RC7~6 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=dc7c5eba5a52d4adbdce20b1bb1754459d535f3b;p=php Fixed basic HTTP authentication for WSDL sub requests --- diff --git a/NEWS b/NEWS index a1df805e5d..26ba9c0979 100644 --- a/NEWS +++ b/NEWS @@ -16,6 +16,9 @@ PHP NEWS . Fixed bug #60860 (session.save_handler=user without defined function core dumps). (Felipe) +- SOAP: + . Fixed basic HTTP authentication for WSDL sub requests. (Dmitry) + 19 Jan 2012, PHP 5.4.0 RC6 - Core: diff --git a/ext/soap/php_sdl.c b/ext/soap/php_sdl.c index 6fa40506cb..22b3fc60aa 100644 --- a/ext/soap/php_sdl.c +++ b/ext/soap/php_sdl.c @@ -242,6 +242,40 @@ void sdl_set_uri_credentials(sdlCtx *ctx, char *uri TSRMLS_DC) if (!s) return; s = strchr(s+3, '/'); l2 = s - (char*)uri; + if (l1 != l2) { + /* check for http://...:80/ */ + if (l1 > 11 && + ctx->sdl->source[4] == ':' && + ctx->sdl->source[l1-3] == ':' && + ctx->sdl->source[l1-2] == '8' && + ctx->sdl->source[l1-1] == '0') { + l1 -= 3; + } + if (l2 > 11 && + uri[4] == ':' && + uri[l2-3] == ':' && + uri[l2-2] == '8' && + uri[l2-1] == '0') { + l2 -= 3; + } + /* check for https://...:443/ */ + if (l1 > 13 && + ctx->sdl->source[4] == 's' && + ctx->sdl->source[l1-4] == ':' && + ctx->sdl->source[l1-3] == '4' && + ctx->sdl->source[l1-2] == '4' && + ctx->sdl->source[l1-1] == '3') { + l1 -= 4; + } + if (l2 > 13 && + uri[4] == 's' && + uri[l2-4] == ':' && + uri[l2-3] == '4' && + uri[l2-2] == '4' && + uri[l2-1] == '3') { + l2 -= 4; + } + } if (l1 != l2 || memcmp(ctx->sdl->source, uri, l1) != 0) { /* another server. clear authentication credentals */ context = php_libxml_switch_context(NULL TSRMLS_CC);