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
(VB.NET) eBay -- Download Data using FileTransferServiceDemonstrates how to download a data file using the eBay File Transfer API. Note: This example requires Chilkat v9.5.0.67 or later.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Use a previously obtained access token. The token should look something like this: ' "AgAAAA**AQA ..." Dim accessToken As String = "EBAY_ACCESS_TOKEN" Dim http As New Chilkat.Http Dim req As New Chilkat.HttpRequest req.HttpVerb = "POST" req.Path = "/FileTransferService" req.ContentType = "application/xml" ' Build the XML body for the request. Dim xml As New Chilkat.Xml xml.Tag = "downloadFileRequest" xml.AddAttribute("xmlns","http://www.ebay.com/marketplace/services") xml.UpdateChildContent("taskReferenceId","50013004806") xml.UpdateChildContent("fileReferenceId","50015579016") req.LoadBodyFromString(xml.GetXml(),"utf-8") ' The XML body looks like this: ' <?xml version="1.0" encoding="UTF-8"?> ' <downloadFileRequest xmlns="http://www.ebay.com/marketplace/services"> ' <taskReferenceId>50013004806</taskReferenceId> ' <fileReferenceId>50015579016</fileReferenceId> ' </downloadFileRequest> req.AddHeader("X-EBAY-SOA-OPERATION-NAME","downloadFile") req.AddHeader("X-EBAY-SOA-SECURITY-TOKEN",accessToken) Dim resp As Chilkat.HttpResponse = http.SynchronousRequest("storage.sandbox.ebay.com",443,True,req) If (http.LastMethodSuccess <> True) Then Debug.WriteLine(http.LastErrorText) Exit Sub End If Dim statusCode As Integer = resp.StatusCode Debug.WriteLine("Response status code = " & statusCode) Dim responseBody As New Chilkat.BinData resp.GetBodyBd(responseBody) ' We can save the response body to a file for examination if we get an unanticipated response. ' (It's binary, so it won't open well in a text editor.) responseBody.WriteFile("qa_output/response.mime") If (statusCode <> 200) Then Debug.WriteLine("Failed.") Exit Sub End If ' The response body looks like this: ' --MIMEBoundaryurn_uuid_2B668636C1E17A4D4114925305818684241 ' Content-Type: application/xop+xml; charset=utf-8; type="text/xml" ' Content-Transfer-Encoding: binary ' Content-ID: <0.urn:uuid:2B668636C1E17A4D4114925305818684242> ' ' <?xml version='1.0' encoding='UTF-8'?> ' <downloadFileResponse xmlns="http://www.ebay.com/marketplace/services"> ' <ack>Success</ack> ' <version>1.1.0</version> ' <timestamp>2017-04-18T15:49:41.868Z</timestamp> ' <fileAttachment> ' <Size>587</Size> ' <Data> ' <xop:Include xmlns:xop="http://www.w3.org/2004/08/xop/include" href="cid:urn:uuid:A37C3C73E994C267F11492530585522"/> ' </Data> ' </fileAttachment> ' </downloadFileResponse> ' --MIMEBoundaryurn_uuid_2B668636C1E17A4D4114925305818684241 ' Content-Type: application/zip ' Content-Transfer-Encoding: binary ' Content-ID: <urn:uuid:A37C3C73E994C267F11492530585522> ' ' <the binary bytes of the zip start here...> ' ' Load the binary response into a MIME object. Dim mime As New Chilkat.Mime Dim success As Boolean = mime.LoadMimeBd(responseBody) If (success <> True) Then Debug.WriteLine(mime.LastErrorText) Exit Sub End If ' Make sure we have 2 sub-parts. The 1st sub-part is the XML response, the 2nd sub-part ' is the zip containing the data. ' Note: The 2nd sub-part can be a "zip" or "gzip". These are two different file formats. ' A zip is indicated with a Content-Type header equal to "application/zip", ' whereas a gzip is indicated with a Content-Type header equal to "application/x-gzip" If (mime.NumParts <> 2) Then Debug.WriteLine("Expected the MIME to have 2 parts.") Debug.WriteLine("NumParts = " & mime.NumParts) Debug.WriteLine("Failed.") Exit Sub End If ' Get the XML from the 1st MIME sub-part. Dim part0 As Chilkat.Mime = mime.GetPart(0) Dim downloadResponseXml As String = part0.GetBodyDecoded() Dim xmlResp As New Chilkat.Xml xmlResp.LoadXml(downloadResponseXml) Debug.WriteLine("Download Response XML:") Debug.WriteLine(xmlResp.GetXml()) Debug.WriteLine("----") ' Now get the zip from the second part (index=1), unzip, and examine.. Dim part1 As Chilkat.Mime = mime.GetPart(1) Dim zipData As New Chilkat.BinData ' This example requires Chilkat v9.5.0.67 or later. ' The GetBodyBd method was added in v9.5.0.67. part1.GetBodyBd(zipData) ' Check to see if we have a zip or gzip. Dim sbContentType As New Chilkat.StringBuilder sbContentType.Append(part1.ContentType) Dim xmlFromZip As New Chilkat.Xml If (sbContentType.Contains("gzip",False) = True) Then ' This is a gzip compressed file. Dim gzip As New Chilkat.Gzip ' in-place uncompress the data. ' Note: The UncompressBd method was added in Chilkat v9.5.0.67 success = gzip.UncompressBd(zipData) If (success <> True) Then Debug.WriteLine(gzip.LastErrorText) Exit Sub End If xmlFromZip.LoadXml(zipData.GetString("utf-8")) Else ' This is a zip archive. ' Load the body into a Zip object. Dim zip As New Chilkat.Zip success = zip.OpenBd(zipData) If (success <> True) Then Debug.WriteLine(zip.LastErrorText) Exit Sub End If ' Save the .zip to a file (so we can examine it for debugging if something is not as expected) zipData.WriteFile("qa_output/ebay_data.zip") ' The zip should contain a single XML file. If (zip.NumEntries <> 1) Then Debug.WriteLine("Expected the .zip to have 1 entry.") Debug.WriteLine("NumEntries = " & zip.NumEntries) Debug.WriteLine("Failed.") Exit Sub End If Dim entry As Chilkat.ZipEntry = zip.GetEntryByIndex(0) xmlFromZip.LoadXml(entry.UnzipToString(0,"utf-8")) End If Debug.WriteLine("XML contained in the zip:") Debug.WriteLine(xmlFromZip.GetXml()) Debug.WriteLine("----") Debug.WriteLine("Success.") |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.