Curl_follow: handle redirects to "//hostname/path"

This commit is contained in:
Daniel Stenberg 2011-09-20 11:13:32 +02:00
parent 49c35a7f9f
commit 81b41095ef
3 changed files with 108 additions and 19 deletions

View File

@ -1699,26 +1699,37 @@ static char *concat_url(const char *base, const char *relurl)
} }
} }
else { else {
/* We got a new absolute path for this server, cut off from the /* We got a new absolute path for this server */
first slash */
pathsep = strchr(protsep, '/'); if((relurl[0] == '/') && (relurl[1] == '/')) {
if(pathsep) { /* the new URL starts with //, just keep the protocol part from the
/* When people use badly formatted URLs, such as original one */
"http://www.url.com?dir=/home/daniel" we must not use the first *protsep=0;
slash, if there's a ?-letter before it! */ useurl = &relurl[2]; /* we keep the slashes from the original, so we
char *sep = strchr(protsep, '?'); skip the new ones */
if(sep && (sep < pathsep))
pathsep = sep;
*pathsep=0;
} }
else { else {
/* There was no slash. Now, since we might be operating on a badly /* cut off the original URL from the first slash, or deal with URLs
formatted URL, such as "http://www.url.com?id=2380" which doesn't without slash */
use a slash separator as it is supposed to, we need to check for a pathsep = strchr(protsep, '/');
?-letter as well! */ if(pathsep) {
pathsep = strchr(protsep, '?'); /* When people use badly formatted URLs, such as
if(pathsep) "http://www.url.com?dir=/home/daniel" we must not use the first
slash, if there's a ?-letter before it! */
char *sep = strchr(protsep, '?');
if(sep && (sep < pathsep))
pathsep = sep;
*pathsep=0; *pathsep=0;
}
else {
/* There was no slash. Now, since we might be operating on a badly
formatted URL, such as "http://www.url.com?id=2380" which doesn't
use a slash separator as it is supposed to, we need to check for a
?-letter as well! */
pathsep = strchr(protsep, '?');
if(pathsep)
*pathsep=0;
}
} }
} }
@ -1731,8 +1742,8 @@ static char *concat_url(const char *base, const char *relurl)
urllen = strlen(url_clone); urllen = strlen(url_clone);
newest = malloc( urllen + 1 + /* possible slash */ newest = malloc(urllen + 1 + /* possible slash */
newlen + 1 /* zero byte */); newlen + 1 /* zero byte */);
if(!newest) { if(!newest) {
free(url_clone); /* don't leak this */ free(url_clone); /* don't leak this */

View File

@ -75,6 +75,7 @@ test1118 test1119 test1120 test1121 test1122 test1123 test1124 test1125 \
test1126 test1127 test1128 test1129 test1130 test1131 test1200 test1201 \ test1126 test1127 test1128 test1129 test1130 test1131 test1200 test1201 \
test1202 test1203 test1300 test1301 test1302 test1303 test1304 test1305 \ test1202 test1203 test1300 test1301 test1302 test1303 test1304 test1305 \
test1306 test1307 test1308 test1309 test1310 test1311 test1312 test1313 \ test1306 test1307 test1308 test1309 test1310 test1311 test1312 test1313 \
test1314 \
test2000 test2001 test2002 test2003 test2004 test2000 test2001 test2002 test2003 test2004
EXTRA_DIST = $(TESTCASES) DISABLED EXTRA_DIST = $(TESTCASES) DISABLED

77
tests/data/test1314 Normal file
View File

@ -0,0 +1,77 @@
<testcase>
<info>
<keywords>
HTTP
HTTP GET
followlocation
</keywords>
</info>
# Server-side
<reply>
<data>
HTTP/1.1 301 This is a weirdo text message swsbounce
Server: test-server/fake
Location: //somewhere.example.com/reply/1314
Content-Length: 32
Connection: close
Redirect to the same URL again!
</data>
<data1>
HTTP/1.1 200 okidoki
Server: test-server/fake
Content-Length: 4
Connection: close
moo
</data>
<datacheck>
HTTP/1.1 301 This is a weirdo text message swsbounce
Server: test-server/fake
Location: //somewhere.example.com/reply/1314
Content-Length: 32
Connection: close
HTTP/1.1 200 okidoki
Server: test-server/fake
Content-Length: 4
Connection: close
moo
</datacheck>
</reply>
# Client-side
<client>
<server>
http
</server>
<name>
HTTP Location: following a // prefixed url
</name>
<command>
http://firstplace.example.com/want/1314 -L -x http://%HOSTIP:%HTTPPORT
</command>
</client>
# Verify data after the test has been "shot"
<verify>
<strip>
^User-Agent: curl/.*
</strip>
<protocol>
GET http://firstplace.example.com/want/1314 HTTP/1.1
Host: firstplace.example.com
Accept: */*
Proxy-Connection: Keep-Alive
GET http://somewhere.example.com/reply/1314 HTTP/1.1
Host: somewhere.example.com
Accept: */*
Proxy-Connection: Keep-Alive
</protocol>
</verify>
</testcase>