Using Microsoft's XMLHTTP Object to Get Data From Other Web Pages
By Richard LoweThere are several popular commercial COM components that retrieve data from other web sites via HTTP requests, such as AspTear and AspHTTP. There is another lesser know option from Microsoft, however. Microsoft's suite of XML DOM (Document Object Model) components includes the XMLHTTP object. This object was originally designed to provide client-side access to XML documents on remote servers through the HTTP protocol. It exposes a simple API which allows you to send requests (yes, even POSTS) and get the resultant XML, HTML or binary data!
(There is one side note at the time of this writing: Microsoft's MSXML 3.0 has just been released. It contains a server-side specific version of the XMLHTTP component for use in web or application servers. Therefore, unless you download v3.0 you are going to have to use the original version, which shouldn't be a problem for most applications.)
Getting Started
If you've been keeping up with versions of Internet Explorer, you probably have some version of MSXML
installed. If you need to install it, you can either install the latest version of MDAC
or the MSXML component itself. If you don't have it
installed, you may get the error: Invalid ProgID
when you execute
Server.CreateObject("Microsoft.XMLHTTP")
.
The most basic function of XMLHTTP is simply returning the entire text of a web page, here is the syntax:
|
This code will write the entire 4GuysFromRolla.com default page to the browser that requests
it. The responseText
property contains a the entire text of the page returned as a string.
Getting Binary Data
It's extremely simple to return binary data using the XMLHTTP object, the syntax is exactly the same, but you
return the respondsBody
property, which is an array of unsigned bytes:
|
We'll continue our investigation of XMLHTTP's capabilities in Part 2 of this article!