Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi ActiveX) Cancel HTTP Get Async Task if not Completed after a Max TimeDemonstrates how to wait a maximum amount of time for an asynchronous task to completed. If not completed in the allotted amount of time, the task is cancelled.
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB; ... procedure TForm1.Button1Click(Sender: TObject); var success: Integer; http: TChilkatHttp; url: WideString; task: IChilkatTask; waitMaxMs: Integer; wasCanceled: Integer; responseStr: WideString; begin // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. http := TChilkatHttp.Create(Self); // Set some timeouts, in seconds: http.ConnectTimeout := 15; // ReadTimeout specifies the max number of seconds that must elapse when no additional data is received before // timing out. For example, if a server sends a 300 byte response at the rate of 1 byte per second, then // ReadTimeout would never cause a timeout because there is never a 15 second interval when nothing arrives. http.ReadTimeout := 15; url := 'https://your-url.com/something'; task := http.QuickGetStrAsync(url); task.Run(); // Wait a maximum of waitMaxMs for the task (i.e. the HTTP GET) to complete. // The Wait method returns when the task has been canceled, aborted, or completed, or when the max allotted time has passed. waitMaxMs := 20000; task.Wait(waitMaxMs); // At this point, the GET may or may not have completed. // Rather than checking the Task status, we can call task.Cancel because // if the Task is no longer running (because it already completed, was canceled or aborted), then the // call to Cancel is a NO-OP (meaning it does nothing and the Task's status is unaffected). // Also, task.Cancel returns 1 if the task was in the "queued" or "running" state and was canceled or aborted. // The method returns 0 if the task has any other status. wasCanceled := task.Cancel(); if (wasCanceled = 1) then begin Memo1.Lines.Add('The HTTP GET took too long and was canceled.'); end else begin // Find out what happened. if (task.StatusInt = 7) then begin // The task completed, which means the background thread's call to QuickGetStr completed // with success or failure. Find out which... if (task.TaskSuccess = 1) then begin // Get the string response for the call to QuickGetStr (which happened in Chilkat's background thread). responseStr := task.GetResultString(); Memo1.Lines.Add(responseStr); Memo1.Lines.Add('HTTP GET successful!'); end else begin Memo1.Lines.Add('HTTP GET failed prior to waitMaxMs...'); Memo1.Lines.Add(task.ResultErrorText); end; end else begin // The task must've been canceled or aborted by some other means.. Memo1.Lines.Add('Task did not complete. Final status: ' + task.Status); end; end; end; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.