Swift
Swift
SOAP with MTOM XOP 8bit (binary) Attachment
See more HTTP Examples
Demonstrates how to send the following sample SOAP request with an MTOM/XOP attachment:
Content-Type: Multipart/Related; start-info="text/xml"; type="application/xop+xml"; boundary="----=_Part_0_1744155.1118953559416"
Content-Length: 3453
SOAPAction: "some-SOAP-action"
------=_Part_1_4558657.1118953559446
Content-Type: application/xop+xml; type="text/xml"; charset=utf-8
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<Detail xmlns="http://example.org/mtom/data">
<image>
<xop:Include xmlns:xop="http://www.w3.org/2004/08/xop/include" href="cid:5aeaa450-17f0-4484-b845-a8480c363444@example.org" />
</image>
</Detail>
</soap:Body>
</soap:Envelope>
------=_Part_1_4558657.1118953559446
Content-Type: image/jpeg
Content-ID: _LT_5aeaa450-17f0-4484-b845-a8480c363444@example.org_GT_
Content-Disposition: 8bit
... binary data ...
Chilkat Swift Downloads
func chilkatTest() {
var success: Bool = false
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
let http = CkoHttp()!
let soapXml = CkoXml()!
soapXml.tag = "soap:Envelope"
success = soapXml.addAttribute(name: "xmlns:soap", value: "http://schemas.xmlsoap.org/soap/envelope/")
soapXml.newChild2(tagPath: "soap:Body", content: "")
success = soapXml.getChild2(index: 0)
soapXml.newChild2(tagPath: "Detail", content: "")
success = soapXml.getChild2(index: 0)
success = soapXml.addAttribute(name: "xmlns", value: "http://example.org/mtom/data")
soapXml.newChild2(tagPath: "image", content: "")
success = soapXml.getChild2(index: 0)
soapXml.newChild2(tagPath: "xop:Include", content: "")
success = soapXml.getChild2(index: 0)
success = soapXml.addAttribute(name: "xmlns:xop", value: "http://www.w3.org/2004/08/xop/include")
success = soapXml.addAttribute(name: "href", value: "cid:5aeaa450-17f0-4484-b845-a8480c363444@example.org")
soapXml.getRoot2()
soapXml.emitXmlDecl = false
var xmlBody: String? = soapXml.getXml()
print("\(xmlBody!)")
let req = CkoHttpRequest()!
req.httpVerb = "POST"
req.path = "/something/someTarget"
req.contentType = "multipart/related; start-info=\"text/xml\"; type=\"application/xop+xml\""
req.addHeader(name: "SOAPAction", value: "some-SOAP-action")
success = req.addString(forUpload2: "", filename: "", strData: xmlBody, charset: "utf-8", contentType: "application/xop+xml; type=\"text/xml\"; charset=utf-8")
// The bytes will be sent as binary (not base64 encoded).
success = req.addFile(forUpload2: "", path: "qa_data/jpg/starfish.jpg", contentType: "image/jpeg")
// The JPEG data is the 2nd sub-part, and therefore is at index 1 (the first sub-part is at index 0)
success = req.addSubHeader(index: 1, name: "Content-ID", value: "<5aeaa450-17f0-4484-b845-a8480c363444@example.org>")
// Add the Content-Disposition: 8bit sub-header
success = req.addSubHeader(index: 1, name: "Content-Disposition", value: "8bit")
http.followRedirects = true
// For debugging, set the SessionLogFilename property
// to see the exact HTTP request and response in a log file.
// (Given that the request contains binary data, you'll need an editor
// that can gracefully view text + binary data. I use EmEditor for most simple editing tasks..)
http.sessionLogFilename = "qa_output/mtom_sessionLog.txt"
var useTls: Bool = true
// Note: Please don't run this example without changing the domain to your own domain...
let resp = CkoHttpResponse()!
success = http.httpSReq(domain: "www.example.org", port: 443, ssl: useTls, request: req, response: resp)
if success == false {
print("\(http.lastErrorText!)")
return
}
let xmlResponse = CkoXml()!
success = xmlResponse.load(xmlData: resp.bodyStr)
print("\(xmlResponse.getXml()!)")
}