Sample code for 30+ languages & platforms
PureBasic

HTTPS multipart/form-data POST

See more HTTP Examples

Demonstrates how to send a multipart/form-data POST over HTTPS (using TLS).

Chilkat PureBasic Downloads

PureBasic
IncludeFile "CkHttpResponse.pb"
IncludeFile "CkHttp.pb"
IncludeFile "CkHttpRequest.pb"

Procedure ChilkatExample()

    success.i = 0

    ; This example assumes the Chilkat HTTP API to have been previously unlocked.
    ; See Global Unlock Sample for sample code.

    ; This example demonstrates how to send a multipart/form-data POST that
    ; looks like this:

    ; 	POST /cgi/XXX.pl HTTP/1.0
    ; 	Accept: text/html
    ; 	Connection: Keep-Alive
    ; 	User-Agent: XXX/8.0.15
    ; 	Content-type: multipart/form-data, boundary=XXXxyxy
    ; 	Content-Length: 682
    ; 
    ; 	--XXXxyxy
    ; 	content-disposition: form-data; name="UploadAgent"
    ; 
    ; 	InterfaceVersion1.5
    ; 	--XXXxyxy
    ; 	content-disposition: form-data; name="user"
    ; 
    ; 	userValue
    ; 	--XXXxyxy
    ; 	content-disposition: form-data; name="password"
    ; 
    ; 	passwordValue
    ; 	--XXXxyxy
    ; 	content-disposition: form-data; name="file"
    ; 
    ; 	fileValue
    ; 	--XXXxyxy
    ; 	content-disposition: form-data; name="data_version"
    ; 
    ; 	dataVersion
    ; 	--XXXxyxy
    ; 	content-disposition: form-data; name="content2"; filename="XXX"
    ; 
    ; 	THE FILE CONTENT GOES HERE...
    ; 	--XXXxyxy--
    ; 

    ; First, let's build the HTTP request object
    req.i = CkHttpRequest::ckCreate()
    If req.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    CkHttpRequest::setCkHttpVerb(req, "POST")
    CkHttpRequest::setCkPath(req, "/cgi/XXX.pl")

    ; The boundary string is automatically generated and added by Chilkat.
    ; The value for the boundary string doesn't matter. (As long as it's a unique string that doesn't occur elsewhere in the request.)
    CkHttpRequest::setCkContentType(req, "multipart/form-data")

    ; Adding the Connection: Keep-Alive is optional.  It only makes sense if the intent is to send
    ; additional requests to the same domain (your-namespace-sb.accesscontrol.windows.net) within a reasonable time period.
    CkHttpRequest::ckAddHeader(req,"Connection","Keep-Alive")

    ; --------------------------------------------------
    ; IMPORTANT: Never set the Content-Length header.  
    ; Chilkat will automatically compute the correct Content-Length and will add it.
    ; --------------------------------------------------

    ; If a specific User-Agent header field is needed, it can be added by calling AddHeader.
    CkHttpRequest::ckAddHeader(req,"User-Agent","XXX/8.0.15")

    ; The "Accept" header, if present, tells the server what Content-Type responses will be accepted.
    ; In this case, we're telling the server that we'll only accept "text/html" responses, and therefore
    ; the server SHOULD only send a text/html response.  Technically, the Accept header is not required.
    CkHttpRequest::ckAddHeader(req,"Accept","text/html")

    ; Add the params to the request.  Given that the Content-Type is set to "multipart/form-data", when
    ; Chilkat composes the request, it will put each param in it's own MIME sub-part (i.e. in it's own
    ; part delimited by the boundary string).
    CkHttpRequest::ckAddParam(req,"UploadAgent","InterfaceVersion1.5")
    CkHttpRequest::ckAddParam(req,"user","userValue")
    CkHttpRequest::ckAddParam(req,"password","passwordValue")
    CkHttpRequest::ckAddParam(req,"file","fileValue")
    CkHttpRequest::ckAddParam(req,"data_version","dataVersion")

    ; The last param is the contents of a file.
    ; If it's a file on disk, we can add it like this:
    pathToFileOnDisk.s = "c:/someDir/someFile.dat"
    success = CkHttpRequest::ckAddFileForUpload(req,"content2",pathToFileOnDisk)
    If success = 0
        Debug CkHttpRequest::ckLastErrorText(req)
        CkHttpRequest::ckDispose(req)
        ProcedureReturn
    EndIf

    ; Alternatively, if the contents of the file are in memory, perhaps in a string
    ; variable, the file can be added like this instead.
    fileContents.s = "This is the content of the file being uploaded."
    success = CkHttpRequest::ckAddStringForUpload(req,"content2","XXX",fileContents,"utf-8")

    ; -----------------------------------------------------------
    ; IMPORTANT: To duplicate the HTTP request shown above, you'll want to choose 
    ; either AddStringForUpload or AddFileForUpload, but not both.  It's possible to upload
    ; any number of files by calling AddStringForUpload and/or AddFileForUpload any number
    ; of times, once per file to be uploaded.  This of course assumes that the receiving
    ; end is programmed to receive multiple files..
    ; ------------------------------------------------------------

    http.i = CkHttp::ckCreate()
    If http.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    ; The request is ready... now send it using HTTPS (which is port 443 by default).

    resp.i = CkHttpResponse::ckCreate()
    If resp.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    success = CkHttp::ckHttpSReq(http,"www.myserver.com",443,1,req,resp)
    If success = 0
        Debug CkHttp::ckLastErrorText(http)
        CkHttpRequest::ckDispose(req)
        CkHttp::ckDispose(http)
        CkHttpResponse::ckDispose(resp)
        ProcedureReturn
    EndIf

    Debug "HTTP response status: " + Str(CkHttpResponse::ckStatusCode(resp))

    ; In this case, the response would be HTML because our Accept header
    ; told the server to only return HTML.  The HTML is available on the BodyStr
    ; property of the response object:
    htmlStr.s = CkHttpResponse::ckBodyStr(resp)
    Debug "Received:"
    Debug htmlStr


    CkHttpRequest::ckDispose(req)
    CkHttp::ckDispose(http)
    CkHttpResponse::ckDispose(resp)


    ProcedureReturn
EndProcedure