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
(C) PostUrlEncoded ClarifiedThis example is intended to help clarify the behavior of the PostUrlEncoded method. The intent of PostUrlEncoded is to send a POST request with the HTTP request parameters located in the HTTP request body using the x-www-form-urlencoded format. In many cases, the developer already has the desired request params in a typical GET URL format, where the params are specified in the URL (after the "?" character). For example: https://www.chilkatsoft.com/blah/moreblah?key=ABC123&value=XYZThe PostUrlEncoded method makes it possible to send this request as a POST, where the "key=ABC123&value=XYZ" is contained in the body of the request. The path part of the URL is "/blah/moreblah". Therefore, the POST request would look like this: POST /blah/moreblah HTTP/1.1 Content-Type: application/x-www-form-urlencoded Host: www.chilkatsoft.com Content-Length: 20 key=ABC123&value=XYZSometimes the desire is to send a POST, such that some (or all) request parameters are found in the path, and not in the request body. For example, let's say a program wants to send this request: POST /blah/moreblah?key=ABC123 HTTP/1.1 Content-Type: application/x-www-form-urlencoded Host: www.chilkatsoft.com Content-Length: 10 value=XYZ This can be done by calling SynchronousRequest. The SynchronousRequest method allows for the parts of the request to be explicitly built via the HTTP request object. (see the example code below).
#include <C_CkHttp.h> #include <C_CkHttpRequest.h> #include <C_CkHttpResponse.h> void ChilkatSample(void) { HCkHttp http; HCkHttpRequest req; HCkHttpResponse resp; HCkHttpRequest req2; BOOL bUseTls; const char *domain; int port; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. http = CkHttp_Create(); // To see the exact HTTP request sent and the response, set the SessionLogFilename property: CkHttp_putSessionLogFilename(http,"/httpLogs/chilkatHttpLog.txt"); // Send the POST where all request parameters are located in the HTTP request body // in the x-www-form-urlencoded format. (We are passing a default/empty HTTP request object. // The HTTP request object is where additional headers, or additional request parameters // be added.) req = CkHttpRequest_Create(); resp = CkHttp_PostUrlEncoded(http,"https://www.chilkatsoft.com/blah/moreblah?key=ABC123&value=XYZ",req); if (CkHttp_getLastMethodSuccess(http) == FALSE) { printf("%s\n",CkHttp_lastErrorText(http)); CkHttp_Dispose(http); CkHttpRequest_Dispose(req); return; } // Do whatever is desired with the response object... CkHttpResponse_Dispose(resp); // Show how to call SynchronousRequest to send a POST where "key=ABC123" is in the path // of the request, and the "value=XYZ" is in the request body. req2 = CkHttpRequest_Create(); CkHttpRequest_putPath(req2,"/blah/moreblah?key=ABC123"); CkHttpRequest_AddParam(req2,"value","XYZ"); CkHttpRequest_putHttpVerb(req2,"POST"); bUseTls = TRUE; domain = "www.chilkatsoft.com"; port = 443; resp = CkHttp_SynchronousRequest(http,domain,port,bUseTls,req2); if (CkHttp_getLastMethodSuccess(http) == FALSE) { printf("%s\n",CkHttp_lastErrorText(http)); CkHttp_Dispose(http); CkHttpRequest_Dispose(req); CkHttpRequest_Dispose(req2); return; } // Do whatever is desired with the response object... CkHttpResponse_Dispose(resp); CkHttp_Dispose(http); CkHttpRequest_Dispose(req); CkHttpRequest_Dispose(req2); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.