A very simple C++ web crawler/spider?

popurity09 picture popurity09 · Nov 25, 2010 · Viewed 61.1k times · Source

I am trying to do a very simple web crawler/spider app in C++. I have been searched google for a simple one to understand the concept. And I found this:

http://www.example-code.com/vcpp/spider.asp

But, its kinda bit complicated/hard to digest for me.

What I am trying to do is just, for example:

enter the url: www.example.com (i will use bash->wget, to get the contents/source code)

then, will look for, maybe "a href" link, and then store in some data file.

Any simple tutorial, or guidelines for me?

I am just starting learning C++ (1 month)

Answer

Charles Salvia picture Charles Salvia · Nov 25, 2010

All right, I'll try to point you in the right direction. Conceptually, a webcrawler is pretty simple. It revolves around a FIFO queue data structure which stores pending URLs. C++ has a built-in queue structure in the standard libary, std::queue, which you can use to store URLs as strings.

The basic algorithm is pretty straightforward:

  1. Begin with a base URL that you select, and place it on the top of your queue
  2. Pop the URL at the top of the queue and download it
  3. Parse the downloaded HTML file and extract all links
  4. Insert each extracted link into the queue
  5. Goto step 2, or stop once you reach some specified limit

Now, I said that a webcrawler is conceptually simple, but implementing it is not so simple. As you can see from the above algorithm, you'll need: an HTTP networking library to allow you to download URLs, and a good HTML parser that will let you extract links. You mentioned you could use wget to download pages. That simplifies things somewhat, but you still need to actually parse the downloaded HTML docs. Parsing HTML correctly is a non-trivial task. A simple string search for <a href= will only work sometimes. However, if this is just a toy program that you're using to familiarize yourself with C++, a simple string search may suffice for your purposes. Otherwise, you need to use a serious HTML parsing library.

There are also other considerations you need to take into account when writing a webcrawler, such as politeness. People will be pissed and possibly ban your IP if you attempt to download too many pages, too quickly, from the same host. So you may need to implement some sort of policy where your webcrawler waits for a short period before downloading each site. You also need some mechanism to avoid downloading the same URL again, obey the robots exclusion protocol, avoid crawler traps, etc... All these details add up to make actually implementing a robust webcrawler not such a simple thing.

That said, I agree with larsmans in the comments. A webcrawler isn't the greatest way to learn C++. Also, C++ isn't the greatest language to write a webcrawler in. The raw-performance and low-level access you get in C++ is useless when writing a program like a webcrawler, which spends most of its time waiting for URLs to resolve and download. A higher-level scripting language like Python or something is better suited for this task, in my opinion.