From 14d4d1957d599ca4f1ad269a04a3c9f5c14261f7 Mon Sep 17 00:00:00 2001 From: Hans Leidekker Date: Wed, 1 Jun 2011 11:50:32 +0200 Subject: [PATCH] wininet: Don't change the verb if the server response is HTTP_STATUS_REDIRECT_KEEP_VERB. --- dlls/wininet/http.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/dlls/wininet/http.c b/dlls/wininet/http.c index a8dbd3df405..cc9d480387d 100644 --- a/dlls/wininet/http.c +++ b/dlls/wininet/http.c @@ -4734,7 +4734,8 @@ static DWORD HTTP_HttpSendRequestW(http_request_t *request, LPCWSTR lpszHeaders, dwStatusCode == HTTP_STATUS_REDIRECT_METHOD) && HTTP_HttpQueryInfoW(request,HTTP_QUERY_LOCATION,szNewLocation,&dwBufferSize,NULL) == ERROR_SUCCESS) { - if (strcmpW(request->verb, szGET) && strcmpW(request->verb, szHEAD)) + if (strcmpW(request->verb, szGET) && strcmpW(request->verb, szHEAD) && + dwStatusCode != HTTP_STATUS_REDIRECT_KEEP_VERB) { HeapFree(GetProcessHeap(), 0, request->verb); request->verb = heap_strdupW(szGET); @@ -4904,7 +4905,8 @@ static DWORD HTTP_HttpEndRequestW(http_request_t *request, DWORD dwFlags, DWORD_ dwBufferSize=sizeof(szNewLocation); if (HTTP_HttpQueryInfoW(request, HTTP_QUERY_LOCATION, szNewLocation, &dwBufferSize, NULL) == ERROR_SUCCESS) { - if (strcmpW(request->verb, szGET) && strcmpW(request->verb, szHEAD)) + if (strcmpW(request->verb, szGET) && strcmpW(request->verb, szHEAD) && + dwCode != HTTP_STATUS_REDIRECT_KEEP_VERB) { HeapFree(GetProcessHeap(), 0, request->verb); request->verb = heap_strdupW(szGET);