Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi ActiveX) Use Socket Object for the ConnectionThe Chilkat Socket API provides many features for establishing connections, which includes the following:
Rather than reproducing all of the properties and methods required for these features, the REST object can use a Socket object's connection by calling the UseConnection method. This allows for an application to use the features of the Socket API to establish the connection, and then use it from the REST API.
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 rest: TChilkatRest; socket: TChilkatSocket; bTls: Integer; port: Integer; maxWaitMs: Integer; success: Integer; bAutoReconnect: Integer; responseJson: WideString; begin // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // This example shows how to use the Chilkat socket object's connection. rest := TChilkatRest.Create(Self); socket := TChilkatSocket.Create(Self); // Establish the connection using the socket object: bTls := 1; port := 443; maxWaitMs := 5000; success := socket.Connect('www.alphavantage.co',port,bTls,maxWaitMs); if (success <> 1) then begin Memo1.Lines.Add('Connect Failure Error Code: ' + IntToStr(socket.ConnectFailReason)); Memo1.Lines.Add(socket.LastErrorText); Exit; end; bAutoReconnect := 1; // Use the connection: success := rest.UseConnection(socket.ControlInterface,bAutoReconnect); if (success <> 1) then begin Memo1.Lines.Add(rest.LastErrorText); Exit; end; // Get a stock quote: // Sending GET request to https://www.alphavantage.co/query?function=TIME_SERIES_DAILY&symbol=MSFT&apikey=my_api_key success := rest.AddQueryParam('function','TIME_SERIES_DAILY'); success := rest.AddQueryParam('symbol','AAPL'); success := rest.AddQueryParam('apikey','my_api_key'); responseJson := rest.FullRequestNoBody('GET','/query'); if (rest.LastMethodSuccess <> 1) then begin Memo1.Lines.Add(rest.LastErrorText); Exit; end; Memo1.Lines.Add(responseJson); // Sample response: // { // "Meta Data": { // "1. Information": "Daily Prices (open, high, low, close) and Volumes", // "2. Symbol": "AAPL", // "3. Last Refreshed": "2019-12-06", // "4. Output Size": "Compact", // "5. Time Zone": "US/Eastern" // }, // "Time Series (Daily)": { // "2019-12-06": { // "1. open": "267.4800", // "2. high": "271.0000", // "3. low": "267.3000", // "4. close": "270.7100", // "5. volume": "25447644" // }, // "2019-12-05": { // "1. open": "263.7900", // "2. high": "265.8900", // "3. low": "262.7300", // "4. close": "265.5800", // "5. volume": "18661343" // }, // "2019-12-04": { // "1. open": "261.0700", // "2. high": "263.3100", // "3. low": "260.6800", // "4. close": "261.7400", // "5. volume": "16810388" // }, // ... // "2019-07-18": { // "1. open": "204.0000", // "2. high": "205.8800", // "3. low": "203.7000", // "4. close": "205.6600", // "5. volume": "18582161" // } // } // } end; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.