Sample code for 30+ languages & platforms
Visual FoxPro

Download a Text File into a String

See more Azure Cloud Storage Examples

Downloads a text file to a string variable.

Chilkat Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loRest
LOCAL lnBTls
LOCAL lnPort
LOCAL lnBAutoReconnect
LOCAL loAzAuth
LOCAL loSbFileContents
LOCAL lcStrFileContents

lnSuccess = 0

* Azure File Service Example: Download Text File into String
* See:  https://docs.microsoft.com/en-us/rest/api/storageservices/get-file

* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.

loRest = CreateObject('Chilkat.Rest')

* Connect to the Azure Storage Blob Service
lnBTls = 1
lnPort = 443
lnBAutoReconnect = 1
* In this example, the storage account name is "chilkat".
lnSuccess = loRest.Connect("chilkat.file.core.windows.net",lnPort,lnBTls,lnBAutoReconnect)
IF (lnSuccess <> 1) THEN
    ? loRest.LastErrorText
    RELEASE loRest
    CANCEL
ENDIF

* Provide Azure Cloud credentials for the REST calls.
loAzAuth = CreateObject('Chilkat.AuthAzureStorage')
loAzAuth.AccessKey = "AZURE_ACCESS_KEY"
* The account name used here should match the 1st part of the domain passed in the call to Connect (above).
loAzAuth.Account = "chilkat"
loAzAuth.Scheme = "SharedKey"
loAzAuth.Service = "File"
* This causes the "x-ms-version: 2021-08-06" header to be automatically added.
loAzAuth.XMsVersion = "2021-08-06"
lnSuccess = loRest.SetAuthAzureStorage(loAzAuth)

* Note: The application does not need to explicitly set the following
* headers: x-ms-date, Authorization.  These headers
* are automatically set by Chilkat.

* Send a GET request to download the file "hamlet.xml" to a StringBuilder object.
* (The share name is "pip")
loSbFileContents = CreateObject('Chilkat.StringBuilder')
lnSuccess = loRest.FullRequestNoBodySb("GET","/pip/xmlFiles/hamlet.xml",loSbFileContents)
IF (lnSuccess <> 1) THEN
    ? loRest.LastErrorText
    RELEASE loRest
    RELEASE loAzAuth
    RELEASE loSbFileContents
    CANCEL
ENDIF

* When successful, the response status will be 200.
* If a non-success status code is returned, then the sbFileContents actually contains the XML error message.
IF (loRest.ResponseStatusCode <> 200) THEN
    * Examine the request/response to see what happened.
    ? "response status code = " + STR(loRest.ResponseStatusCode)
    ? "response status text = " + loRest.ResponseStatusText
    ? "response header: " + loRest.ResponseHeader
    ? "response body (if any): " + loSbFileContents.GetAsString()
    ? "---"
    ? "LastRequestStartLine: " + loRest.LastRequestStartLine
    ? "LastRequestHeader: " + loRest.LastRequestHeader
    RELEASE loRest
    RELEASE loAzAuth
    RELEASE loSbFileContents
    CANCEL
ENDIF

? "Length of downloaded string = " + STR(loSbFileContents.Length)

lcStrFileContents = loSbFileContents.GetAsString()
? lcStrFileContents

loSbFileContents.WriteFile("qa_output/hamlet.xml","utf-8",0)

RELEASE loRest
RELEASE loAzAuth
RELEASE loSbFileContents