HttpRequest Ruby Reference Documentation
CkHttpRequest
Current Version: 11.1.0
Represents a complete HTTP request.
Object Creation
obj = Chilkat::CkHttpRequest.new()
Properties
Boundary
# ckStr is a CkString
httpRequest.get_Boundary(ckStr);
strVal = httpRequest.boundary();
httpRequest.put_Boundary(strVal);
Sets an explicit boundary string to be used in multipart/form-data requests. If no Boundary is set, then a boundary string is automaticaly generated as needed during the sending of a request.
Charset
# ckStr is a CkString
httpRequest.get_Charset(ckStr);
strVal = httpRequest.charset();
httpRequest.put_Charset(strVal);
Controls the character encoding used in the URL encoding of query params.  The default value of this propoerty is utf-8.
ContentType
# ckStr is a CkString
httpRequest.get_ContentType(ckStr);
strVal = httpRequest.contentType();
httpRequest.put_ContentType(strVal);
The ContentType property sets the Content-Type header field, and identifies the content-type of the HTTP request body.  Common values are:
If ContentType is set equal to the empty string, then no Content-Type header is included in the HTTP request.application/x-www-form-urlencoded multipart/form-data application/json application/xml
DebugLogFilePath
# ckStr is a CkString
httpRequest.get_DebugLogFilePath(ckStr);
strVal = httpRequest.debugLogFilePath();
httpRequest.put_DebugLogFilePath(strVal);
If set to a file path, this property logs the LastErrorText of each Chilkat method or property call to the specified file. This logging helps identify the context and history of Chilkat calls leading up to any crash or hang, aiding in debugging.
Enabling the VerboseLogging property provides more detailed information. This property is mainly used for debugging rare instances where a Chilkat method call causes a hang or crash, which should generally not happen.
Possible causes of hangs include:
- A timeout property set to 0, indicating an infinite timeout.
- A hang occurring within an event callback in the application code.
- An internal bug in the Chilkat code causing the hang.
EntireHeader
# ckStr is a CkString
httpRequest.get_EntireHeader(ckStr);
strVal = httpRequest.entireHeader();
httpRequest.put_EntireHeader(strVal);
Composes and returns the entire MIME header of the HTTP request.
topHttpVerb
# ckStr is a CkString
httpRequest.get_HttpVerb(ckStr);
strVal = httpRequest.httpVerb();
httpRequest.put_HttpVerb(strVal);
The HttpVerb property should be set to the name of the HTTP method that appears on the start line of an HTTP request, such as GET, POST, PUT, DELETE, etc.  It is also possible to use the various WebDav verbs such as PROPFIND, PROPPATCH, MKCOL, COPY, MOVE, LOCK, UNLOCK, etc.  In general, the HttpVerb may be set to anything, even custom verbs recognized by a custom server-side app.
HttpVersion
# ckStr is a CkString
httpRequest.get_HttpVersion(ckStr);
strVal = httpRequest.httpVersion();
httpRequest.put_HttpVersion(strVal);
The HTTP version in the request header.  Defaults to 1.1.  Can only be set to 1.0 or 1.1.
LastErrorHtml
# ckStr is a CkString
httpRequest.get_LastErrorHtml(ckStr);
strVal = httpRequest.lastErrorHtml();
Provides HTML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastErrorText
# ckStr is a CkString
httpRequest.get_LastErrorText(ckStr);
strVal = httpRequest.lastErrorText();
Provides plain text information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
LastErrorXml
# ckStr is a CkString
httpRequest.get_LastErrorXml(ckStr);
strVal = httpRequest.lastErrorXml();
Provides XML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastMethodSuccess
boolVal = httpRequest.get_LastMethodSuccess();
httpRequest.put_LastMethodSuccess(boolVal);
Indicates the success or failure of the most recent method call: true means success, false means failure. This property remains unchanged by property setters or getters.  This method is present to address challenges in checking for null or Nothing returns in certain programming languages.
NumHeaderFields
intVal = httpRequest.get_NumHeaderFields();
Returns the number of request header fields.
topNumParams
intVal = httpRequest.get_NumParams();
Path
# ckStr is a CkString
httpRequest.get_Path(ckStr);
strVal = httpRequest.path();
httpRequest.put_Path(strVal);
The path of the resource requested.  A path of / indicates the default document of a domain.
Explaining the Parts of a URL
http://example.com:8042/over/there?name=ferret#nose \__/ \______________/\_________/ \________/ \__/ | | | | | scheme domain+port path query fragment
This property should be set to the path part of the URL. You may also include the query part in this property value. If the Content-Type of the request is NOT application/x-www-form-urlencoded, then you would definitely want to include query parameters in the path. If the Content-Type of the request IS application/x-www-form-urlencoded, the query parameters are passed in the body of the request. It is also possible to pass some query parameters via the path, and some in the body of a application/x-www-form-urlencoded request, but you shouldn't include the same parameter in both places. You would never need to include the fragment part. The fragment is nothing more than an instruction for a browser to automatically navigate to a particular location in the HTML page (assuming the request returns HTML, otherwise a fragment makes no sense).
SendCharset
boolVal = httpRequest.get_SendCharset();
httpRequest.put_SendCharset(boolVal);
Controls whether the charset is explicitly included in the content-type header field of the HTTP POST request.  The default value of this property is false.
VerboseLogging
boolVal = httpRequest.get_VerboseLogging();
httpRequest.put_VerboseLogging(boolVal);
If set to true, then the contents of LastErrorText (or LastErrorXml, or LastErrorHtml) may contain more verbose information. The default value is false.  Verbose logging should only be used for debugging.  The potentially large quantity of logged information may adversely affect peformance.
Version
# ckStr is a CkString
httpRequest.get_Version(ckStr);
strVal = httpRequest.version();
Methods
AddBdForUpload
# remoteFilename is a string
# byteData is a CkBinData
# contentType is a string
status = httpRequest.AddBdForUpload(name, remoteFilename, byteData, contentType);
Adds a file to an upload request where the contents of the file come from byteData.
name is an arbitrary name.  (In HTML, it is the form field name of the input tag.)
remoteFilename is the name of the file to be created on the HTTP server.
byteData contains the bytes to be uploaded.
contentType contains is the value of the Content-Type header.  An empty string may be passed to allow Chilkat to automatically determine the Content-Type based on the filename extension.
Returns true for success, false for failure.
AddFileForUpload
# filePath is a string
status = httpRequest.AddFileForUpload(name, filePath);
Adds a file to an upload request.  To create a file upload request, set the ContentType property = multipart/form-data  and then call AddFileForUpload, AddBytesForUpload, or AddStringForUpload for each file to be uploaded.   This method does not read the file into memory.  When the upload occurs, the data is streamed directly from the file, thus allowing for very large files to be uploaded without consuming large amounts of memory.
name is an arbitrary name.  (In HTML, it is the form field name of the input tag.)
filePath is the path to an existing file in the local filesystem.
Returns true for success, false for failure.
AddFileForUpload2
# filePath is a string
# contentType is a string
status = httpRequest.AddFileForUpload2(name, filePath, contentType);
Same as AddFileForUpload, but allows the Content-Type header field to be directly specified. (Otherwise, the Content-Type header is automatically determined based on the file extension.)
name is an arbitrary name.  (In HTML, it is the form field name of the input tag.)
filePath is the path to an existing file in the local filesystem.
Returns true for success, false for failure.
AddHeader
# value is a string
httpRequest.AddHeader(name, value);
Adds a request header to the HTTP request. If a header having the same field name is already present, this method replaces it.
Note: Never explicitly set the Content-Length header field. Chilkat will automatically compute the correct length and add the Content-Length header to all POST, PUT, or any other request where the Content-Length needs to be specified. (GET requests always have a 0 length body, and therefore never need a Content-Length header field.)
AddMwsSignature
# mwsSecretKey is a string
status = httpRequest.AddMwsSignature(domain, mwsSecretKey);
Computes the Amazon MWS signature using the mwsSecretKey and adds the Signature parameter to the request.  This method should be called for all Amazon Marketplace Web Service (Amazon MWS) HTTP requests.   It should be called after all request parameters have been added.
Important: The Chilkat v9.5.0.75 release accidentally breaks Amazon MWS (not AWS) authentication. If you need MWS with 9.5.0.75, send email to support@chilkatsoft.com for a hotfix, or revert back to v9.5.0.73, or update to a version after 9.5.0.75.
The domain should be the domain of the request, such as one of the following:
- mws.amazonservices.com
- mws-eu.amazonservices.com
- mws.amazonservices.in
- mws.amazonservices.com.cn
- mws.amazonservices.jp
Note: This method automatically adds or replaces the existing Timestamp parameter to the current system date/time.
Returns true for success, false for failure.
AddParam
# value is a string
httpRequest.AddParam(name, value);
Adds a request query parameter (name/value pair) to the HTTP request. The name and value strings passed to this method should not be URL encoded.
AddStringForUpload
# filename is a string
# strData is a string
# charset is a string
status = httpRequest.AddStringForUpload(name, filename, strData, charset);
Same as AddFileForUpload, but the upload data comes from an in-memory string instead of a file.
Returns true for success, false for failure.
AddStringForUpload2
# filename is a string
# strData is a string
# charset is a string
# contentType is a string
status = httpRequest.AddStringForUpload2(name, filename, strData, charset, contentType);
Same as AddStringForUpload, but allows the Content-Type header field to be directly specified. (Otherwise, the Content-Type header is automatically determined based on the filename's file extension.)
Returns true for success, false for failure.
AddSubHeader
# name is a string
# value is a string
status = httpRequest.AddSubHeader(index, name, value);
Adds a request header to the Nth sub-header of the HTTP request. If a header having the same field name is already present, this method replaces it.
Returns true for success, false for failure.
topGenerateRequestFile
status = httpRequest.GenerateRequestFile(path);
The same as GenerateRequestText, except the generated request is written to the file specified by path.
Returns true for success, false for failure.
GenerateRequestText
status = httpRequest.GenerateRequestText(outStr);
retStr = httpRequest.generateRequestText();
Returns the request text that would be sent if Http.SynchronousRequest was called.
Returns true for success, false for failure.
topGetHeaderField
# outStr is a CkString (output)
status = httpRequest.GetHeaderField(name, outStr);
retStr = httpRequest.getHeaderField(name);
GetHeaderName
# outStr is a CkString (output)
status = httpRequest.GetHeaderName(index, outStr);
retStr = httpRequest.getHeaderName(index);
Returns the Nth request header field name. Indexing begins at 0, and the number of request header fields is specified by the NumHeaderFields property.
Returns true for success, false for failure.
topGetHeaderValue
# outStr is a CkString (output)
status = httpRequest.GetHeaderValue(index, outStr);
retStr = httpRequest.getHeaderValue(index);
Returns the Nth request header field value. Indexing begins at 0, and the number of request header fields is specified by the NumHeaderFields property.
Returns true for success, false for failure.
topGetParam
# outStr is a CkString (output)
status = httpRequest.GetParam(name, outStr);
retStr = httpRequest.getParam(name);
GetParamName
# outStr is a CkString (output)
status = httpRequest.GetParamName(index, outStr);
retStr = httpRequest.getParamName(index);
Returns the Nth request query parameter field name. Indexing begins at 0, and the number of request query parameter fields is specified by the NumParams property.
Returns true for success, false for failure.
GetParamValue
# outStr is a CkString (output)
status = httpRequest.GetParamValue(index, outStr);
retStr = httpRequest.getParamValue(index);
Returns the Nth request query parameter field value. Indexing begins at 0, and the number of request query parameter fields is specified by the NumParams property.
Returns true for success, false for failure.
GetUrlEncodedParams
status = httpRequest.GetUrlEncodedParams(outStr);
retStr = httpRequest.getUrlEncodedParams();
Returns the request parameters in URL encoded form (i.e. in the exact form that would be sent if the ContentType property was application/x-www-form-urlencoded).   For example, if a request has two params:  param1=abc 123 and param2=abc-123, then GetUrlEncodedParams would return  abc+123¶m2=abc%2D123
Returns true for success, false for failure.
LoadBodyFromBd
Uses the contents of the requestBody as the HTTP request body.
Returns true for success, false for failure.
topLoadBodyFromFile
status = httpRequest.LoadBodyFromFile(filePath);
The HTTP protocol is such that all HTTP requests are MIME.  For non-multipart requests, this method may be called to set the MIME body of the HTTP request to the exact contents of filePath. 
Note: A non-multipart HTTP request consists of (1) the HTTP start line, (2) MIME header fields, and (3) the MIME body.  This method sets the MIME body.
Returns true for success, false for failure.
topLoadBodyFromSb
# charset is a string
status = httpRequest.LoadBodyFromSb(requestBody, charset);
Uses the contents of the requestBody as the HTTP request body.   The charset indicates the binary representation of the string, such as utf-8, utf-16, iso-8859-*, windows-125*, etc.  Any of the character encodings supported at the link below are valid.
Returns true for success, false for failure.
LoadBodyFromString
# charset is a string
status = httpRequest.LoadBodyFromString(bodyStr, charset);
The HTTP protocol is such that all HTTP requests are MIME.  For non-multipart requests, this method may be called to set the MIME body of the HTTP request to the exact contents of bodyStr. 
Note: A non-multipart HTTP request consists of (1) the HTTP start line, (2) MIME header fields, and (3) the MIME body.  This method sets the MIME body.
charset indicates the charset, such as utf-8 or iso-8859-1, to be used.  The HTTP body will contain the bodyStr converted to this character encoding.
Returns true for success, false for failure.
RemoveAllParams
RemoveHeader
status = httpRequest.RemoveHeader(name);
Removes all occurrences of a HTTP request header field.  Always returns true.
Returns true for success, false for failure.
topRemoveParam
httpRequest.RemoveParam(name);
SetFromUrl
httpRequest.SetFromUrl(url);
Parses a URL and sets the Path and query parameters (NumParams, GetParam, GetParamName, GetParamValue).
StreamBodyFromFile
status = httpRequest.StreamBodyFromFile(filePath);
Useful for sending HTTP requests where the body is a very large file.  For example, to send an XML HttpRequest containing a very large XML document, one would set the HttpVerb = POST, the ContentType = text/xml, and then call StreamBodyFromFile to indicate that the XML body of the request is to be streamed directly from a file.  When the HTTP request is actually sent, the body is streamed directly from the file, and thus the file never needs to be loaded in its entirety in memory.
Returns true for success, false for failure.
StreamChunkFromFile
# offset is a string
# numBytes is a string
status = httpRequest.StreamChunkFromFile(path, offset, numBytes);
This method is the same as StreamBodyFromFile, but allows for an offset and number of bytes to be specified. The offset and numBytes are integers passed as strings.
Returns true for success, false for failure.
topDeprecated
AddBytesForUpload Deprecated
# remoteFileName is a string
# byteData is a CkByteData
status = httpRequest.AddBytesForUpload(name, remoteFileName, byteData);
Adds a file to an upload request where the contents of the file come from an in-memory byte array.  To create a file upload request, set the ContentType property = multipart/form-data and then call AddBytesForUpload, AddStringForUpload, or AddFileForUpload for each file to be uploaded.
name is an arbitrary name.  (In HTML, it is the form field name of the input tag.)
remoteFileName is the name of the file to be created on the HTTP server.
byteData contains the contents (bytes) to be uploaded.
Returns true for success, false for failure.
topAddBytesForUpload2 Deprecated
# remoteFileName is a string
# byteData is a CkByteData
# contentType is a string
status = httpRequest.AddBytesForUpload2(name, remoteFileName, byteData, contentType);
Same as AddBytesForUpload, but allows the Content-Type header field to be directly specified. (Otherwise, the Content-Type header is automatically determined based on the remoteFileName's file extension.)
Returns true for success, false for failure.
topLoadBodyFromBytes Deprecated
The HTTP protocol is such that all HTTP requests are MIME.  For non-multipart requests, this method may be called to set the MIME body of the HTTP request to the exact contents of the byteData. 
Note: A non-multipart HTTP request consists of (1) the HTTP start line, (2) MIME header fields, and (3) the MIME body.  This method sets the MIME body.
Returns true for success, false for failure.
top