BoxLang 🚀 A New JVM Dynamic Language Learn More...
BoltHTTP is a HTTP client for CFML, it is a CFC that wraps the Apache
HttpComponents java library. You can use the bolthttp
CFC
instead of CFHTTP when making HTTP requests within CFML.
Here's a simple example:
bolt = new bolthttp();
response = bolt.request(url="http://httpbin.org/robots.txt", method="GET");
writeOutput(response.fileContent);
The return value of request
value is a
struct
that contains keys mostly compatibale
with what the cfhttp
tag would return.
The request method has the following signature:
request(string url, string method="GET", array params=[], boolean close=true, struct options={})
url
the url to request, the only required argument.
method
the HTTP request method
params
similar to the cfhttpparam
tag, an
array of structs for headers, formfields, etc. For example passing a
header you would use [{type="header",
name="X-MyHeader", value="My Value"}]
close
when true
it closes the internal HTTP
Client for you once the request is complete, this means that you need
to create another instance of bolthttp
if you want to
make a subsequent request, or set it to false
and call
getHttpClient().close()
when you are done with the instance.
options
a struct of request level options. Currently
supported options are: maxredirects
redirect
sockettimeout
connecttimeout
and connectrequesttimeout
The response struct also contains a key httpResponse
which is an instance of a org.apache.http.HttpResponse
object. You should be able to get any part of the HTTP response you
need from this object.
If you want to only work with the HttpResponse
object
instead of using the request()
method of bolthttp you can
use the rawRequest()
method which only returns the
HttpResponse
object. Using rawRequest
instead of request().httpResponse
will offer better
performance becauase it does not need to parse the response object to
build the struct.
It requires Java 1.7 and ColdFusion 9 or greater or Lucee 4.5+
The requirement of ColdFusion 9+ is mainly due to it being written as a script based CFC, if you convert it to a tag based CFC it would probably run on CF8 or below as well.
$
box install bolthttp