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
(AutoIt) Use an Azure Service SASShows how to use an Azure Service SAS. (In this case, it is an SAS for a blob.)
; Azure Blob Service Example: Upload binary bytes to a block blob. ; This uses a Service SAS for Authorization. ; This example requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oRest = ObjCreate("Chilkat.Rest") ; Connect to the Azure Storage Blob Service Local $bTls = True Local $iPort = 443 Local $bAutoReconnect = True ; In this example, the storage account name is "chilkat". Local $bSuccess = $oRest.Connect("chilkat.blob.core.windows.net",$iPort,$bTls,$bAutoReconnect) If ($bSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf ; ---------------------------------------------------------------------------------------------- ; The code above this comment could be placed inside a function/subroutine within the application ; because the connection does not need to be made for every request. Once the connection is made ; the app may send many requests.. ; ---------------------------------------------------------------------------------------------- ; Note: The application does not need to explicitly set the following ; headers: Content-Length, x-ms-date, Authorization. These headers ; are automatically set by Chilkat. ; Let's load a previously computed Azure Storage Account SAS token and use it. ; See How to Create an Azure Service SAS $oSbToken = ObjCreate("Chilkat.StringBuilder") $bSuccess = $oSbToken.LoadFile("qa_data/tokens/azureStorageServiceSas.txt","utf-8") If ($bSuccess <> True) Then ConsoleWrite("Failed to load SAS token." & @CRLF) Exit EndIf ; Add the Shared Access Signature query params for authorization. $oRest.AddQueryParams($oSbToken.GetAsString()) ; IMPORTANT: Make sure to set the x-ms-blob-type header: $bSuccess = $oRest.AddHeader("x-ms-blob-type","BlockBlob") ; IMPORTANT: Make sure to add the x-ms-date header. ; When the header name is "x-ms-date", Chilkat will recognize the keyword "NOW" ; and will substitute the current system date/time formatted as required by Microsoft. $bSuccess = $oRest.AddHeader("x-ms-date","NOW") ; For this example, we'll just load a JPG file into memory.. $oBinData = ObjCreate("Chilkat.BinData") $bSuccess = $oBinData.LoadFile("qa_data/jpg/starfish.jpg") If ($bSuccess <> True) Then ConsoleWrite("Failed to load JPG file." & @CRLF) Exit EndIf ; Note: The maximum size of a block blob created by uploading in a single step is 64MB. ; For larger files, the upload must be broken up into blocks. There is another Chilkat example for that.. $oSbResponse = ObjCreate("Chilkat.StringBuilder") $bSuccess = $oRest.FullRequestBd("PUT","/mycontainer/starfish.jpg",$oBinData,$oSbResponse) If ($bSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf ; When successful, the Azure Storage service will respond with a 201 response status code, ; with no response body. If ($oRest.ResponseStatusCode <> 201) Then ; Examine the request/response to see what happened. ConsoleWrite("response status code = " & $oRest.ResponseStatusCode & @CRLF) ConsoleWrite("response status text = " & $oRest.ResponseStatusText & @CRLF) ConsoleWrite("response header: " & $oRest.ResponseHeader & @CRLF) ConsoleWrite("response body (if any): " & $oSbResponse.GetAsString() & @CRLF) ConsoleWrite("---" & @CRLF) ConsoleWrite("LastRequestStartLine: " & $oRest.LastRequestStartLine & @CRLF) ConsoleWrite("LastRequestHeader: " & $oRest.LastRequestHeader & @CRLF) ConsoleWrite("Failed." & @CRLF) Exit EndIf ConsoleWrite("Success." & @CRLF) |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.