"When the initial request by wget is responded by a 3XX redirect

response sent in chunked transfer encoding, the code path to
resubmit the request to the redirected URL forgets to reset
got_clen and chunked variables in the loop.  If the redirected
URL does not use chunked transfer encoding, this causes the code
that slurps the body of the response to incorrectly try to parse
out the chunk length which does not exist." - junkio@

----------------------------------------------------------------------
This commit is contained in:
Glenn L McGrath 2003-08-28 22:03:19 +00:00
parent 83e4a5bccf
commit e7bdfccb3f

View File

@ -295,6 +295,8 @@ int wget_main(int argc, char **argv)
* HTTP session
*/
do {
got_clen = chunked = 0;
if (! --try)
close_delete_and_die("too many redirections");
@ -337,7 +339,8 @@ int wget_main(int argc, char **argv)
/*
* Retrieve HTTP response line and check for "200" status code.
*/
read_response: if (fgets(buf, sizeof(buf), sfp) == NULL)
read_response:
if (fgets(buf, sizeof(buf), sfp) == NULL)
close_delete_and_die("no response from server");
for (s = buf ; *s != '\0' && !isspace(*s) ; ++s)
@ -816,7 +819,7 @@ progressmeter(int flag)
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
* $Id: wget.c,v 1.55 2003/08/28 21:55:22 bug1 Exp $
* $Id: wget.c,v 1.56 2003/08/28 22:03:19 bug1 Exp $
*/