iliaa Sun Dec 29 15:01:34 2002 EDT
Modified files:
/php4/ext/standard http_fopen_wrapper.c
Log:
Fixed bug #21267 (opening URLs that result in redirection to a relative
path was failing).
Index: php4/ext/standard/http_fopen_wrapper.c
diff -u php4/ext/standard/http_fopen_wrapper.c:1.54
php4/ext/standard/http_fopen_wrapper.c:1.55
--- php4/ext/standard/http_fopen_wrapper.c:1.54 Thu Dec 5 15:59:49 2002
+++ php4/ext/standard/http_fopen_wrapper.c Sun Dec 29 15:01:33 2002
@@ -18,7 +18,7 @@
| Wez Furlong <[EMAIL PROTECTED]> |
+----------------------------------------------------------------------+
*/
-/* $Id: http_fopen_wrapper.c,v 1.54 2002/12/05 20:59:49 helly Exp $ */
+/* $Id: http_fopen_wrapper.c,v 1.55 2002/12/29 20:01:33 iliaa Exp $ */
#include "php.h"
#include "php_globals.h"
@@ -339,19 +339,25 @@
zval *entry, **entryp;
char new_path[HTTP_HEADER_BLOCK_SIZE];
+ char loc_path[HTTP_HEADER_BLOCK_SIZE];
*new_path='\0';
- if (strlen(location)<8 || (strncasecmp(location, "http://", 7)
&& strncasecmp(location, "https://", 8))) {
- strcpy(new_path, resource->scheme);
- strlcat(new_path, resource->host, sizeof(new_path));
- if ((use_ssl && resource->port != 443) || (!use_ssl &&
resource->port != 80)) {
- snprintf(new_path+strlen(new_path),
sizeof(new_path)-strlen(new_path)-1, ":%d", resource->port);
- }
+ if (strlen(location)<8 || (strncasecmp(location, "http://",
+sizeof("http://")-1) && strncasecmp(location, "https://", sizeof("https://")-1))) {
if (*location != '/') {
- php_dirname(resource->path,
strlen(resource->path));
- snprintf (new_path+strlen(new_path),
sizeof(new_path)-strlen(new_path)-1, "%s/", resource->path);
+ if (*(location+1) != '\0') {
+
+ php_dirname(resource->path,
+strlen(resource->path));
+ snprintf(loc_path, sizeof(loc_path) -
+1, "%s%s", resource->path, location);
+ } else {
+ snprintf(loc_path, sizeof(loc_path) -
+1, "/%s", location);
+ }
+ } else {
+ strlcpy(loc_path, location, sizeof(loc_path));
+ }
+ if ((use_ssl && resource->port != 443) || (!use_ssl &&
+resource->port != 80)) {
+ snprintf(new_path, sizeof(new_path) - 1,
+"%s://%s:%d%s", resource->scheme, resource->host, resource->port, loc_path);
+ } else {
+ snprintf(new_path, sizeof(new_path) - 1,
+"%s://%s%s", resource->scheme, resource->host, loc_path);
}
- strlcat(new_path, location, sizeof(new_path));
}
else {
strlcpy(new_path, location, sizeof(new_path));
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php