XAMPP is an easy-to-install package that bundles the Apache web server, PHP, Xdebug, and the MySQL database. This allows you to create the environment you need to run Joomla! on your local machine. The latest version of XAMPP is available at the Apache Friends website. Downloads are available for Linux, Windows and Mac OS X. Download the package for your platform.
Important Note Regarding XAMPP and Skype: Apache and Skype both use port 80 as an alternative for incoming connections. If you use Skype, go into the Tools-Options-Advanced-Connection panel and deselect the Use 80 and 443 as alternatives for incoming connections option. If Apache starts as a service, it will take 80 before Skype starts and you will not see a problem. But, to be safe, disable the option in Skype.
Installation on Windows
Installation for Windows is very simple. You can use the XAMPP installer executable (for example, xampp-windows-x64-7.4.4-0-VC15-installer.exe). Detailed installation instructions for Windows are available here.
If you are on Windows XP or 2003 they are not supported by the main package but there are compatible versions of XAMPP for these platforms listed on the download page (but you will only be able to run PHP 5.4 or lower – and therefore will only be able to test Joomla 3.x and lower).
For Windows, it is recommended that you install XAMPP in c:xampp (not in c:program files). If you do this, your Joomla! (and any other local website folders) will go into the folder c:xampphtdocs. (By convention, all web content goes under the htdocs folder.)
If you have multiple HTTP servers (such as IIS) you can change the XAMPP listening port. In xamppDirapacheconfhttpd.conf, modify the line Listen 80 to Listen [portnumber] (for example: Listen 8080).
Installation on Linux
Open Terminal and enter:
sudo tar xvfz xampp-linux-1.7.7.tar.gz -C /opt
(replace xampp-linux-1.7.7.tar.gz with the version of xampp you downloaded). It has been reported that the MYSQL database of xampp 1.7.4 does not work with Joomla 1.5.22
This installs … Apache2, MySQL and PHP5 as well as an ftp server.
sudo /opt/lampp/lampp start
sudo /opt/lampp/lampp stop
starts/stops all the services
Test Your XAMPP localhost Server
Open your Browser and point it to
The index.php will redirect to
There you will find instructions on how to change default usernames/passwords. On a PC that does not serve files to the Internet or LAN then changing the defaults is a personal decision.
Download the latest Joomla instalation zip 
Unzip to your hard drive
Connect to localhost with an FTP client Default
Create a folder for your Joomla on the localhost server
FTP the unpacked Joomla installation files to the newly created Joomla folder.
- The XAMPP installation sets the correct Ownership of the files and permissions.
- Using the CHOWN command will cause Ownership problems with XAMPP.
- Using nautilus to manipulate folders/files on localhost will cause Ownership problems with XAMPP.
Default Database name
Default Database user
There is no default Password.
Administrator password is your choice.
Installing Sample Data is recommended for the novice user.
After installation delete the installation directory and point your Browser to:
Creating a Link in the Ubuntu Menu
To create a GUI for XAMPP connected to your Ubuntu menu
Open up the Terminal and type
sudo gedit /usr/share/applications/xampp-control-panel.desktop
Then copy the following into the gedit and save.
[Desktop Entry] Encoding=UTF-8 Name=XAMPP Control Panel Comment=Start and Stop XAMPP Exec=gksudo “python /opt/lampp/share/xampp-control-panel/xampp-control-panel.py” Icon=/usr/share/icons/Tango/scalable/devices/network-wired.svg Terminal=false Type=Application Categories=GNOME;Application;Network; StartupNotify=true
If the control panel fails to launch, try running the Exec command directly in the terminal:
gksudo “python /opt/lampp/share/xampp-control-panel/xampp-control-panel.py”
If you receive the error:
Error importing pygtk2 and pygtk2-libglade
Install the missing libraries:
sudo apt-get install python-glade2
Xdebug PHP Debugger
The XAMPP package for Linux does not includes the Xdebug PHP debugger. To install Xdebug on Debian or Ubuntu:
– Install the build-essential package:
sudo apt-get update sudo apt-get install build-essential sudo apt-get install autoconf
– Download the development package for your version of XAMPP and extract it to your existing installation:
sudo tar xvfz xampp-linux-devel-1.7.7.tar.gz -C /opt
– Build Xdebug:
wget http://xdebug.org/files/xdebug-2.1.3.tgz tar xzf xdebug-2.1.3.tgz cd xdebug-2.1.3/ /opt/lampp/bin/phpize
After this you will have following output on your console:
Configuring for: PHP Api Version: 20090626 Zend Module Api No: 20090626 Zend Extension Api No: 20090626 ./configure -with-php-config=/opt/lampp/bin/php-config make sudo make install
Then the output will be this.. please monitor the directory specified.
Installing shared extensions: /opt/lampp/lib/php/extensions/no-debug-non-zts-20090626/
Create a folder in your temp folder that will hold the data file generated by Xdebug:
sudo mkdir /opt/lampp/tmp/xdebug sudo chmod a+rwx -R /opt/lampp/tmp/xdebug
Install using PHP extensions community library (PECL) bundled with XAMPP:
sudo /opt/lampp/bin/pecl install xdebug
On Ubuntu/Debian you can install using:
apt-get install php5-xdebug
(warning: this will also install Apache and PHP from apt repositories).
Warning for 64-bit users
When compiling Xdebug or installing via apt-get, you will receive an error when (re)starting xampp:
/opt/lampp/lib/php/extensions/no-debug-non-zts-20090626/xdebug.so: wrong ELF class: ELFCLASS64
This is because XAMPP runs 32-bit but Xdebug is 64-bit. To overcome this problem, either make xdebug.so on a 32-bit machine or download it from ActiveState
Download the PHP Remote Debugging Client file for Linux (x86). Extract the contents of the file on your computer. This compressed file contains several folders with version numbers ex: 4.4, 5.0, 5.1… 5.3 and so forth, get in the folder with the higher version number or the one that works for you. Then copy the xdebug.so file to the following location (overwrite if needed):
Remember this location could be different on your computer.
Installation on Mac OS X
Mac OS X includes an Apache server out-of-the-box, but most developers will prefer to use the integrated tools and configurability provided by XAMPP.
As with most programs on Mac, installation is a breeze. Visit Apache Friends for the universal binary download.
Once the file has finished downloading, open the disk image, and drag the XAMPP folder to the Applications folder alias.
To start the server, open XAMPP Control.app and press the start button next to Apache.
A Little Troubleshooting
Many Mac users have a little difficulty at this stage when trying to set up another instance of Apache on their machine. If you cannot start XAMPP’s Apache, you have two options: Change the listening port of XAMPP. In ApplicationsXAMPPxamppfilesetchttpd.conf, modify the Listen 80 line to Listen [portNumber]. For example: Listen 8080
Change the listening port of the pre-installed Apache server. In finder, go to /etc (CMD+SHIFT+G). From here you will be able to navigate through the normally hidden Apache files. Find the folder labeled Apache2, and edit the http.conf file. Modify the Listen 80 line to Listen [portNumber]. For example: Listen 8080
Note If you choose to change the port of the pre-installed Apache server, you may need to restart your computer for the changes to take effect. You will also have to authenticate as an administrator to change these files.
Test XAMPP Installation
Once XAMPP is installed and you have started the Apache service with the XAMPP Control Panel tool, you can test it by opening your browser and navigating to http://localhost. You should see the XAMPP welcome screen similar to the one below.
Select the phpinfo() link in the top menu. This will display a long screen of information about the PHP configuration, as shown below.
At this point, XAMPP is installed successfully. Notice the Loaded Configuration File. We will be editing this file in the next section to configure Xdebug.