![]() |
Problem mit Download
Hi,
also ich hab ne Unit zum Downloaden von Dateien kopiert ... Das Problem ist, dass wenn ich auf download klicke und diesen thread aufrufe, mir das programm anzeigt, der download sei beendet obwohl es noch nicht mal angefangen hat ! Seltsamerweise läuft der Download derselben Datei manchmal (?) bis zu Ende. Beim Ausführen der gedownloadeten Datei kommt dann die Meldung, dass die Datei nicht korrekt sei ... Hier mal der Download-Thread:
Delphi-Quellcode:
unit ThreadUnit;
interface uses ShellAPI, UrlMon, StdCtrls, ExtCtrls, Windows, SysUtils, Classes, ActiveX, Dialogs, Controls, DownloadServerLink; type cDownloadStatusCallback = class(TObject,IUnknown,IBindStatusCallback) private function QueryInterface(const IID: TGUID; out Obj): HResult; stdcall; function _AddRef: Integer; stdcall; function _Release: Integer; stdcall; function OnStartBinding(dwReserved: DWORD; pib: IBinding): HResult; stdcall; function GetPriority(out nPriority): HResult; stdcall; function OnLowResource(reserved: DWORD): HResult; stdcall; function OnProgress(ulProgress, ulProgressMax, ulStatusCode: ULONG; szStatusText: LPCWSTR): HResult; stdcall; function OnStopBinding(hresult: HResult; szError: LPCWSTR): HResult; stdcall; function GetBindInfo(out grfBINDF: DWORD; var bindinfo: TBindInfo): HResult; stdcall; function OnDataAvailable(grfBSCF: DWORD; dwSize: DWORD; formatetc: PFormatEtc; stgmed: PStgMedium): HResult; stdcall; function OnObjectAvailable(const iid: TGUID; punk: IUnknown): HResult; stdcall; end; type TDownloadThread = class(TThread) private { Private declarations } procedure UpdateForm1; protected procedure Execute; override; procedure DownloadFiles; public { Public declarations } constructor Create(finfo, saveas,todownload : string); //stimmt das? end; implementation uses UInformationen; var fileinfo, speichernals,runterladen : string; function cDownloadStatusCallback._AddRef: Integer; begin Result := 0; end; function cDownloadStatusCallback._Release: Integer; begin Result := 0; end; function cDownloadStatusCallback.QueryInterface(const IID: TGUID; out Obj): HResult; begin if(GetInterface(IID,Obj)) then begin Result := 0 end else begin Result := E_NOINTERFACE; end; end; function cDownloadStatusCallback.OnStartBinding(dwReserved: DWORD; pib: IBinding): HResult; begin Result := S_OK; end; function cDownloadStatusCallback.GetPriority(out nPriority): HResult; begin Result := S_OK; end; function cDownloadStatusCallback.OnLowResource(reserved: DWORD): HResult; begin Result := S_OK; end; function cDownloadStatusCallback.OnStopBinding(hresult: HResult; szError: LPCWSTR): HResult; stdcall; begin Result := S_OK; end; function cDownloadStatusCallback.GetBindInfo(out grfBINDF: DWORD; var bindinfo: TBindInfo): HResult; stdcall; begin Result := S_OK; end; function cDownloadStatusCallback.OnDataAvailable(grfBSCF: DWORD; dwSize: DWORD; formatetc: PFormatEtc; stgmed: PStgMedium): HResult; begin Result := S_OK; end; function cDownloadStatusCallback.OnObjectAvailable(const iid: TGUID; punk: IUnknown): HResult; stdcall; begin Result := S_OK; end; procedure dl; var Handle : THandle; begin MessageDlg ('Neuere Datenbank erfolgreich heruntergeladen !',mtInformation,[mbOk],0); PagesDlg2.CancelBtn.Enabled := true; PagesDlg2.OKBtn.Enabled := true; PagesDlg2.Button1.Enabled := true; if MessageDlg ('Programm beenden und Packet installieren ?',mtConfirmation,[mbYes,mbNo],0) = mrNo then exit; ShellExecute(Handle, NIL, pchar(speichernals),'','',SW_SHOWNORMAL); halt; end; function cDownloadStatusCallback.OnProgress(ulProgress, ulProgressMax, ulStatusCode: ULONG; szStatusText: LPCWSTR): HResult; begin case ulStatusCode of BINDSTATUS_FINDINGRESOURCE : begin PagesDlg2.Label4.Caption := '"'+fileinfo+'" gefunden...'; end; BINDSTATUS_CONNECTING : begin PagesDlg2.Label4.Caption := 'Verbindungsaufbau...'; end; BINDSTATUS_BEGINDOWNLOADDATA : begin PagesDlg2.Label4.Caption := 'Download "'+fileinfo+'" beginnt ...'; end; BINDSTATUS_DOWNLOADINGDATA : begin PagesDlg2.ProgressBar1.Position := MulDiv(ulProgress,100,ulProgressMax); PagesDlg2.Label4.Caption := 'Download "'+fileinfo+'" läuft ...'; end; BINDSTATUS_ENDDOWNLOADDATA : begin PagesDlg2.Label4.Caption := 'Download "'+fileinfo+'" fertiggestellt ...'; DownloadThread.UpdateForm1; end; end; Result := S_OK; end; procedure TDownloadThread.UpdateForm1; begin PagesDlg2.Label4.Caption := 'Download "Programm Datenbank" fertiggestellt ...'; MessageDlg ('Neuere Datenbank erfolgreich heruntergeladen !',mtInformation,[mbOk],0); PagesDlg2.CancelBtn.Enabled := true; PagesDlg2.OKBtn.Enabled := true; PagesDlg2.Button1.Enabled := true; if MessageDlg ('Programm beenden und Packet installieren ?',mtConfirmation,[mbYes,mbNo],0) = mrNo then exit; ShellExecute(Handle, NIL, pchar(speichernals),'','',SW_SHOWNORMAL); halt; end; procedure TDownloadThread.DownloadFiles; var cDownStatus : cDownloadStatusCallback; begin cDownStatus := cDownloadStatusCallBack.Create; try UrlDownloadtoFile(nil, PCHAR(runterladen), PCHAR(speichernals), 0, CDownStatus); finally cDownStatus.Free; end; end; constructor TDownloadThread.Create(finfo,saveas,todownload : string); begin speichernals := saveas; runterladen := todownload; fileinfo := finfo; // Diese Variablen beinhalten Adresse zum Speichern und Downloaden der Zieldatei // Werte sind korrekt inherited Create(false); FreeOnTerminate := True; end; procedure TDownloadThread.Execute; begin DownloadThread.DownloadFiles; end; end.
Code:
Hoffe ihr könnt mir da helfen (das ist der code aus der c.-lib)
// Aufruf des Threads (aus anderer Unit):
pos := GetCurrentDir; DownloadThread := TDownloadThread.Create('Programm',pos+'\Programm_NewVersion.exe,server_adress+'\newprog.exe'); devnull |
Re: Problem mit Download
Arggg... Weis keiner, warum immer die letzten 8 bytes fehlen ???
|
Re: Problem mit Download
Woran genau es hängt, kann ich dir auch nicht sagen, aber das eine oder andere fällt mir schon auf:
1. Globale Variablen (fileinfo, speichernals,runterladen) sind für einen Thread nicht sehr günstig. 2. UpdateForm1 sollte mit Synchronize(UpdateForm1) aufgerufen werden, eben so die einzelnen bezüge auf PagesDlg2, da sie ja nicht zum aktuellen Thread gehören. 3. Du rufst in der Callback DownloadThread auf, eigentlich müsstest du der Callback den aktuellen Thread übergeben, etwa so:
Delphi-Quellcode:
Aufruf mit:
type
cDownloadStatusCallback = class(TObject,IUnknown,IBindStatusCallback) protected FDownloadThread : TDownloadThread; //... public constructor Create(ADownloadThread : TDownloadThread); //... end; constructor cDownloadStatusCallback.Create(ADownloadThread : TDownloadThread); begin inherited Create; FDownloadThread := ADownloadThread; end;
Delphi-Quellcode:
Aufruf von UpdateForm1 dann so:
procedure TDownloadThread.DownloadFiles;
var cDownStatus : cDownloadStatusCallback; begin cDownStatus := cDownloadStatusCallBack.Create(self); //...
Delphi-Quellcode:
FDownloadThread.Synchronize(FDownloadThread.UpdateForm1);
|
Re: Problem mit Download
Ich hab jetzt die Änderungen vorgenommen. Ich weis nicht, obs daran lag, aber jetzt funktioniert das.
Nur eine kleine Frage noch: - Warum werden alle Returns ($0D) in gedownloadetetn Dateien in $0A (--> Tab) umgewandelt ? devnull |
Re: Problem mit Download
Moin Devnull,
Zitat:
Ausserdem ist 0A der unter UNIX übliche Zeilenvorschub, also das was dem "uns" gewohnten 0D0A entspricht. Durch das Laden in eine StringList, und anschliessendes Speichern, lässt sich das 0A in 0D0A umwandeln. |
Re: Problem mit Download
Zitat:
Jaja, hast Recht. Danke |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:22 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz