I have a Windows7 PC with XAMPP installed in it. Whenever I need to setup multiple sites in my machine, I used to put the site folders under C:\xampp\htdocs\
folder, which is the default localhost
directory. The reason is that dynamically linked files need a host to run perfectly.
An alternative way or the perfect solution to this method is to use the Virtual Hosts. Through this way we are able to make virtual hosts irrespective of the location of working directory of the website. In simple words, we don’t need to put all the website files to default location of localhost directory (C:\xampp\htdocs).
Virtual host is actually localhost itself, but with a different alias. Every virtual host points to local IP, i.e., 127.0.0.1. The simple way to setup virtual hosts for multiple sites for the Apache server in xampp is described below:
-
Stop the apache service from xampp control panel.
-
Open file
C:\xampp\apache\conf\extra\httpd-vhosts.conf
with a text editor. -
Uncomment the line 19 “
# NameVirtualHost *:80
“. So, we will get,
NameVirtualHost *:80
- Concatenate the following snippet at the end of the file. This will help you to access ‘localhost’ all time.
<VirtualHost *>
ServerAdmin [email protected]
DocumentRoot "C:/xampp/htdocs"
ServerName localhost
ServerAlias localhost
<Directory "C:/xampp/htdocs">
Options Indexes FollowSymLinks Includes ExecCGI
Order allow,deny
Allow from all
</Directory>
</VirtualHost>
- For any additional virtual host, add the code to the bottom of the above file. For example, I want to setup a virtual host ‘testhost’ at D:\websites\
<VirtualHost *>
ServerAdmin [email protected]
DocumentRoot "D:\website"
ServerName testhost
ServerAlias testhost
<Directory "D:\website">
Order allow,deny
Allow from all
</Directory>
</VirtualHost>
Don’t forget to save the httpd-vhosts.conf file.
-
Now we have to set the IP for virtual host. For that, open Windows hosts file (C:\Windows\System32\drivers\etc\hosts) with a text editor.
-
Find the following lines in hosts file:
# localhost name resolution is handled within DNS itself.
# 127.0.0.1 localhost
add the virtual host ip as same as localhost after that line.
# localhost name resolution is handled within DNS itself.
127.0.0.1 localhost
127.0.0.1 testhost #this is the virtual host name
- Restart Apache and type ‘testhost‘ in addressbar of browser. You can see your website running in the new virtual host!