phpMyAdmin is a free web software to work with MySQL on the web. It provides a convenient visual front end to the MySQL capabilities.
Before working with phpMyAdmin, you need to have LAMP installed on your server. If you don't have the Linux, Apache, MySQL, PHP stack on your server, you can find the tutorial for setting it up here.
Once you have the user and required software, you can start installing phpMyAdmin on your VPS!
The easiest way to install phpmyadmin is through apt-get:
sudo apt-get install phpmyadmin
During the installation, phpMyAdmin will walk you through a basic configuration. Once the process starts up, follow these steps:
After the installation has completed, add phpmyadmin to the apache configuration.
sudo nano /etc/apache2/apache2.conf
Add the phpmyadmin config to the file.
Include /etc/phpmyadmin/apache.conf
Restart apache:
sudo service apache2 restart
You can then access phpmyadmin by going to youripaddress/phpmyadmin. The screen should look like this.
Unfortunately, older versions of phpMyAdmin have had serious security vulnerabilities, including allowing remote users to eventually exploit root on the underlying virtual private server. One can prevent a majority of these attacks through a simple process: locking down the entire directory with Apache's native user/password restrictions which will prevent these remote users from even attempting to exploit older versions of phpMyAdmin.
To set this up, start off by allowing the .htaccess file to work within the phpmyadmin directory. You can accomplish this in the phpmyadmin configuration file:
sudo nano /etc/phpmyadmin/apache.conf
Under the directory section, add the line “AllowOverride All” under “Directory Index”, making the section look like this:
<Directory /usr/share/phpmyadmin> Options FollowSymLinks DirectoryIndex index.php AllowOverride All [...]
With the .htaccess file allowed, we can proceed to set up a native user whose login would be required to even access the phpmyadmin login page.
Start by creating the .htaccess page in the phpmyadmin directory:
sudo nano /usr/share/phpmyadmin/.htaccess
Follow up by setting up the user authorization within .htaccess file. Copy and paste the following text in:
AuthType Basic AuthName "Restricted Files" AuthUserFile /path/to/passwords/.htpasswd Require valid-user
Below you’ll see a quick explanation of each line:
Now we will go ahead and create the valid user information.
Start by creating a htpasswd file. Use the htpasswd command, and place the file in a directory of your choice as long as it is not accessible from a browser. Although you can name the password file whatever you prefer, the convention is to name it .htpasswd.
sudo htpasswd -c /path/to/passwords/.htpasswd username
A prompt will ask you to provide and confirm your password.
Once the username and passwords pair are saved you can see that the password is encrypted in the file.
Finish up by restarting apache:
sudo service apache2 restart
phpMyAdmin will now be much more secure since only authorized users will be able to reach the login page. Accessing youripaddress/phpmyadmin should display a screen like this.
Fill it in with the username and password that you generated. After you login you can access phpmyadmin with the MySQL username and password.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
Having an issue after doing everything (I suppose) like suggested - popup appears, I login successfully but then there’s white screen showing Internal Server Error OS: Debian 7 64
Also, I’m using Ispconfig3 and plan to have multiple users. Wouldn’t this master password be required to be entered by each of my users? I suppose then it’s not such a good idea to have it set up like this…?
Forgot to mention an important fact - instead of running phpmyadmin, a Save As dialog appears. I’m afraid there’s something wrong with the .htaccess file.
@deno.kajda: Check apache’s error logs, do you see any errors?
Error to create the htpasswd file
any solutions? thanks
Hello I followed your steps above. However I am getting the error:
#1045 Cannot log in to the MySQL server
Can you advise how to fix this?
Hi! Instead of getting to phpmyadmin page, browser starts download file… what it could be?
Is there a way to update phpmyadmin to the latest version? the Version that gets installed is donkey years old!
Hello, can anyone please help? I get this error aafter i add the include thing in the buttom. It saays i cant restart apache 2 and says there more info, but i cant see the info. :/ Help pleaase
I followed this guide to install on Debian 8. It seemed to work, however I did not get asked for a password so I can log in to it or I somehow skipped that question. Do you know how I can go back and add the password to log in?
I followed the remainder of the guide https://www.digitalocean.com/community/tutorials/how-to-install-and-secure-phpmyadmin-on-debian-7 When I go to the page myip/phpmyadmin/ it goes straight to the phpmyadmin login and not the login that was set up with the .htaccess and htpasswd file that were setup as described on the above page.