From da9ace7cf9a61fa32c1c74df78baa5fffc01e4b0 Mon Sep 17 00:00:00 2001 From: riderkick Date: Sat, 9 May 2015 10:40:21 +0800 Subject: [PATCH] updater: fix redirection this should fix multiple redirection --- updater/uMain.pas | 33 +++++++++++++++++---------------- updater/updater.lpi | 2 +- 2 files changed, 18 insertions(+), 17 deletions(-) diff --git a/updater/uMain.pas b/updater/uMain.pas index ab8c326d4..dae5ed189 100644 --- a/updater/uMain.pas +++ b/updater/uMain.pas @@ -390,20 +390,24 @@ procedure TDownloadThread.Execute; end; var - regx :TRegExpr; - i, ctry :Integer; + regx : TRegExpr; + i, ctry : Cardinal; Sza, rurl, fname, sproject, sdir, - sfile :String; - st :TStringList; + sfile : String; + st, HTTPHeaders: TStringList; + begin URL := Trim(URL); + HTTPHeaders := TStringList.Create; regx := TRegExpr.Create; try PrepareHTTP(FHTTP); + FHTTP.Headers.NameValueSeparator := ':'; + HTTPHeaders.NameValueSeparator := ':'; regx.ModifierI := True; if isSFURL then begin @@ -439,11 +443,12 @@ procedure TDownloadThread.Execute; FileName := 'new_version.7z'; end; + FHTTP.Headers.Text := HTTPHeaders.Text; //**loading page UpdateStatus(RS_LoadingPage); ctry := 0; while (not FHTTP.HTTPMethod('HEAD', rurl)) or - (FHTTP.ResultCode >= 300) or (FHTTP.ResultCode < 100) do + (FHTTP.ResultCode >= 400) or (FHTTP.ResultCode < 100) do begin if Self.Terminated then Break; if (FHTTP.ResultCode >= 500) or (FHTTP.ResultCode < 100) then @@ -473,21 +478,15 @@ procedure TDownloadThread.Execute; ShowErrorMessage(Format(RS_FileNotFound_mfdatalink, [mf_data_link])); end; Break; - end - else - if FHTTP.ResultCode >= 300 then - begin - UpdateStatus(RS_Redirected); - FHTTP.Headers.Add('Referer: ' + rurl); - rurl := HeaderByName(FHTTP.Headers, 'location: '); end; FHTTP.Clear; end; if (FHTTP.ResultCode >= 300) or isSFURL then begin + HTTPHeaders.Values['Referer'] := ' ' + rurl; UpdateStatus(RS_Redirected); - rurl := HeaderByName(FHTTP.Headers, 'location: '); + rurl := Trim(FHTTP.Headers.Values['Location']); if isSFURL then begin if (Pos('use_mirror=', rurl) > 0) then @@ -504,10 +503,10 @@ procedure TDownloadThread.Execute; UpdateStatus(Format(RS_Downloading, [FileName])); if (FHTTP.ResultCode >= 100) and (FHTTP.ResultCode < 400) then begin + HTTPHeaders.Values['Accept'] := ' */*'; ctry := 0; FHTTP.Clear; - FHTTP.Headers.Add('Accept: */*'); - FHTTP.Headers.Add('Referer: ' + URL); + FHTTP.Headers.Text := HTTPHeaders.Text; while (not FHTTP.HTTPMethod('GET', rurl)) or (FHTTP.ResultCode >= 300) do begin @@ -543,10 +542,11 @@ procedure TDownloadThread.Execute; else if FHTTP.ResultCode >= 300 then begin - FHTTP.Headers.Add('Referer: ' + rurl); + HTTPHeaders.Values['Referer'] := ' ' + rurl; rurl := HeaderByName(FHTTP.Headers, 'location: '); end; FHTTP.Clear; + FHTTP.Headers.Text := HTTPHeaders.Text; end; end; @@ -629,6 +629,7 @@ procedure TDownloadThread.Execute; frmMain.ExceptionHandler(Self, E); end; regx.Free; + HTTPHeaders.Free; end; { TfrmMain } diff --git a/updater/updater.lpi b/updater/updater.lpi index bb7789dc9..85916e602 100644 --- a/updater/updater.lpi +++ b/updater/updater.lpi @@ -19,7 +19,7 @@ - +