Tcl
Tcl
Parse Multipart Binary Http Response
See more HTTP Examples
This example demonstrates how to parse an HTTP response that is multipart and contains a binary file, such as a .zip or .pdf.Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
set http [new_CkHttp]
set req [new_CkHttpRequest]
# ...
# Insert code here to construct some kind of HTTP request.
# this example is to show how to parse a particular kind of response.
# ...
# ...
# Send the request (whatever it may be in your case) to get the HTTP response object.
set resp [new_CkHttpResponse]
set success [CkHttp_HttpSReq $http "www.somedomain.com" 443 1 $req $resp]
if {$success == 0} then {
puts [CkHttp_lastErrorText $http]
delete_CkHttp $http
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
exit
}
# Get the response body (which is expected to be binary)
set respBody [new_CkBinData]
CkHttpResponse_GetBodyBd $resp $respBody
# For this example, the response body contains something like this:
# ------=_Part_21302_2029949381.1547401515443
# Content-Type: application/xop+xml; charset=UTF-8; type="text/xml"
# Content-Transfer-Encoding: 8bit
# Content-ID: <rootpart@ws.jboss.org>
#
# <env:Envelope xmlns:env='http://schemas.xmlsoap.org/soap/envelope/'><env:Header></env:Header><env:Body>...</env:Body></env:Envelope>
# ------=_Part_21302_2029949381.1547401515443
# Content-Type: application/octet-stream
# Content-Transfer-Encoding: binary
# Content-Id: <fileArchivio-7d302908-4d64-43d3-bf4e-79ce806d43b3@ws.jboss.org>
#
# BINARY_CONTENT_HERE...
#
# ------=_Part_21302_2029949381.1547401515443--
#
# Load it into a Chilkat MIME object.
set mime [new_CkMime]
set success [CkMime_LoadMimeBd $mime $respBody]
if {$success == 0} then {
puts [CkMime_lastErrorText $mime]
delete_CkHttp $http
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
delete_CkBinData $respBody
delete_CkMime $mime
exit
}
set numParts [CkMime_get_NumParts $mime]
if {$numParts < 2} then {
puts "Expected multipart MIME with at least 2 sub-parts."
delete_CkHttp $http
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
delete_CkBinData $respBody
delete_CkMime $mime
exit
}
# Get the 1st sub-part, which is the XML.
set part0 [new_CkMime]
CkMime_PartAt $mime 0 $part0
# Should be OK because we checked NumParts above..
set xmlStr [CkMime_getBodyDecoded $part0]
puts "$xmlStr"
puts "----"
# Save the 2nd part to a file. (It is a .zip file in our test case..)
set part1 [new_CkMime]
CkMime_PartAt $mime 1 $part1
set success [CkMime_SaveBody $part1 "qa_output/attachedZip.zip"]
# Alternatively, we could extract the binary data to a BinData and use elsewhere..
set zipData [new_CkBinData]
set success [CkMime_GetBodyBd $part1 $zipData]
set success [CkBinData_WriteFile $zipData "qa_output/attachedZip_again.zip"]
puts "OK."
delete_CkHttp $http
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
delete_CkBinData $respBody
delete_CkMime $mime
delete_CkMime $part0
delete_CkMime $part1
delete_CkBinData $zipData