$ wget https://files.phpmyadmin.net/phpMyAdmin/5.2.0/phpMyAdmin-5.2.0-english.tar.gz
apache.conf later) and set ownership:$ tar xvf phpMyAdmin-5.2.0-english.tar.gz sudo mv phpMyAdmin-5.2.0-english/ /home/user/html/phpMyAdmin $ sudo chown -R www-data:www-data /home/user/html/phpMyAdmin
apache.conf, config.inc.php, and htpasswd.setup./home/user/html/phpMyAdmin).$ sudo mkdir -m770 /home/user/html/phpMyAdmin/tmp
config.sample.inc.php to config.inc.php and edit as follows$ sudo vim /home/user/html/phpMyAdmin/config.inc.php $cfg['blowfish_secret'] = 'new 32 byte secret key';
config.inc.php:$cfg['FirstLevelNavigationItems'] = 150; // number of databases in navigation, default: 100 $cfg['MaxNavigationItems'] = 150; // number of tables in db navigation, default: 50 $cfg['NavigationWidth'] = 300; // width of the navigation window, default: 240 $cfg['RetainQueryBox'] = true; // retain query box, results of query shown below box, default: false $cfg['ShowPhpInfo'] = true; // show phpinfo link on home screen, default: false $cfg['TempDir'] = '/home/user/html/phpMyAdmin/tmp'; // you may omit this line as the default is ./tmp
config.inc.php unchanged. The pma settings are better done within phpMyAdmin, where you click “Find out why” in the warning at the bottom of the screen when you first run phpMyAdmin, and then create the database phpmyadmin which will contain those settings./home/user/html/phpMyAdmin/apache.conf:# phpMyAdmin default Apache configuration
Alias /phpmyadmin /home/bco/html/phpMyAdmin
<Directory /home/bco/html/phpMyAdmin>
Options SymLinksIfOwnerMatch
DirectoryIndex index.php
<IfModule mod_php.c>
<IfModule mod_mime.c>
AddType application/x-httpd-php .php
</IfModule>
<FilesMatch ".+\.php$">
SetHandler application/x-httpd-php
</FilesMatch>
php_value include_path .
php_admin_value upload_tmp_dir /home/bco/html/phpMyAdmin/tmp
php_admin_value open_basedir /home/bco/html/phpMyAdmin/:/usr/share/
</IfModule>
</Directory>
# Authorize for setup
<Directory /home/bco/html/phpMyAdmin/setup>
<IfModule mod_authz_core.c>
<IfModule mod_authn_file.c>
AuthType Basic
AuthName "phpMyAdmin Setup"
AuthUserFile /home/bco/html/phpMyAdmin/htpasswd.setup
</IfModule>
Require valid-user
</IfModule>
</Directory>
# Disallow web access to directories that don't need it
<Directory /home/bco/html/phpMyAdmin/templates>
Require all denied
</Directory>
<Directory /home/bco/html/phpMyAdmin/libraries>
Require all denied
</Directory>
<Directory /home/bco/html/phpMyAdmin/setup/lib>
Require all denied
</Directory>
# Secure access to phpMyAdmin by restricting access to it's parent, for example by IP address or domain name, local or external
<Directory /home/bco/html>
<RequireAny>
Require ip 127.0.0.1
Require forward-dns ddns.domain.name
</RequireAny>
</Directory>
Require all denied as we will not use the setup script. However, if you do want to use the setup script prior to creating config.inc.php, first create the password file to access the setup script's directory:$ sudo htpasswd -c /home/user/html/phpMyAdmin/htpasswd.setup user
$ sudo ln -s /home/user/html/phpMyAdmin/apache.conf /etc/apache2/conf-enabled/phpmyadmin.conf $ sudo service apache2 restart
$ sudo mariadb MariaDB [(none)]> CREATE USER 'user'@'localhost' IDENTIFIED BY 'password' WITH GRANT OPTION; MariaDB [(none)]> FLUSH PRIVILEGES; MariaDB [(none)]> exit
/home/user/html/ and /home/user/www//phpmyadmin to any website url hosted on the same server.