Setting Up Perl and CGI For Wamp Server

First you need to download Wamp Server from and install Wamp Server on your machine. The default installation directory is ‘C:wamp” and here I am using the default options for installation. To complete the installation you have to set the host name for your mail server and your email address, here you can leave the default option again. That will do no harm.

The current Wamp Server will install Apache 2.2.11, PHP 5.2.9-2 + PECL, MySQL 5.1.33, SQLitemanager and PhpMyadmin.

Now you have to download ActivePerl (currently 5.10.0) from and install it. The default installation directory is “C:Perl“, but for simplicity and ease of use I use different directory. I create a new folder name “perl” inside “C:wampbin“. So I install Active Perl in “C:wampbinperl” directory. The next thing you need to do is configure the Apache web server to execute Perl and CGI script.

This is the most important part here. You need to edit the Apache configuration file. Now go to “C:wampbinapacheApache2.2.11conf” directory and open “httpd.conf” file. Edit the httpd.conf file as below.

1. Inside httpd.conf, look for the line that says “<Directory “c:/wamp/www/”>“, just a few lines below this you’ll find the line that says “Options Indexes FollowSymLinks“. Add “Includes ExecCGI” in the line just next to FollowSymLinks, thus it look like this:

Options Indexes FollowSymLinks Includes ExecCGI

This will enable CGI script inside your www folder.

2. Now look for the line “AddHandler cgi-script .cgi“, this line is commented out. You need to enable this by un-comment this line, to do that remove the # character at the beginning of this line. This will add handler for files with .cgi extension. If you want to use .pl file extension in your server add “AddHandler cgi-script .pl” just below the above line. Now you will be able to execute CGI and Perl script with .cgi and .pl, extension.

Lines to add:

AddHandler cgi-script .cgi
AddHandler cgi-script .pl

3. To add directory index file, look for the line “DirectoryIndex index.php index.php3 index.html index.htm“. Add index.cgi and in this line.

Lines to add:

DirectoryIndex index.php index.php3 index.html index.htm index.cgi

Your server is now configured and ready to run perl and cgi script. Next thing you might need to do is to configure perl to use mysql database. You need to download and install mysql driver to enable database connection through your perl script. You have to grab the driver from the ActivePerl package repository. However, mysql driver module is not available in the default ActivePerl Package Repository. So, you need to add additional repository and install from that repository. Follow the steps below:

1. Open command prompt [type cmd in run], navigate to your perl/bin folder (“cd c:wampbinperlbin”), then type “ppm repo add uwinnipeg” and press enter.

2. After the “uwinnipeg” repository is added successfully, you can install DBD-mysql by typing this command “ppm install DBD-mysql” and hit enter.

Note: The ActivePerl default package repository contains DBD-mysqlPP module. If you install that one, you will get an error in your SQL SELECT query and especially when you use the WHERE clause. Your localhost will hang if you run this kind of query with the WHERE clause, so to get it work you need to install the package that I mentioned above only.

At the top of every file you wish to run (.pl or .cgi), ensure you add this line:

This article is a repeat from:,52757,52757, Posted by: venkat437 on August 12, 2009 09:19AM
It was recreated here for archiving…

Leave a Reply

Your email address will not be published. Required fields are marked *