Phpmyadmin 404 не найден на Apache 2.4

Кажется, я не могу заставить phpmyadmin работать правильно с моей текущей установкой Apache/2.4.7 (Ubuntu:Trusty).

Phpmyadmin установлен правильно, и я включил /etc/phpmyadmin/apache.conf файл в VirtualHost сам, но переход к https://www.domain.com/phpmyadminpanel/, дает мне ответ 404, в то время как остальная часть сайта работает правильно.

Я не совсем уверен, что может быть причиной этого, я упускаю что-то очевидное?

/etc/phpmyadmin/apache.conf

# phpMyAdmin default Apache configuration

Alias /phpmyadminpanel /usr/share/phpmyadmin

<Directory /usr/share/phpmyadmin>
    Options FollowSymLinks
    DirectoryIndex index.php

    <IfModule mod_php5.c>
        AddType application/x-httpd-php .php

        php_flag magic_quotes_gpc Off
        php_flag track_vars On
        php_flag register_globals Off
        php_admin_flag allow_url_fopen Off
        php_value include_path .
        php_admin_value upload_tmp_dir /var/lib/phpmyadmin/tmp
        php_admin_value open_basedir /usr/share/phpmyadmin/:/etc/phpmyadmin/:/var/lib/phpmyadmin/:/usr/share/php/php-gettext/:/usr/share/javascript/
    </IfModule>

</Directory>

# Authorize for setup
<Directory /usr/share/phpmyadmin/setup>
    <IfModule mod_authn_file.c>
    AuthType Basic
    AuthName "phpMyAdmin Setup"
    AuthUserFile /etc/phpmyadmin/htpasswd.setup
    </IfModule>
    Require valid-user
</Directory>

# Disallow web access to directories that don't need it
<Directory /usr/share/phpmyadmin/libraries>
    Order Deny,Allow
    Deny from All
</Directory>
<Directory /usr/share/phpmyadmin/setup/lib>
    Order Deny,Allow
    Deny from All
</Directory>

/etc/apache2/sites-enabled/domain.com.conf

# Redirect HTTP traffic to HTTPS
<VirtualHost *:80>

    ServerName  domain.com
    ServerAlias  www.domain.com
    Redirect / https://www.domain.com/za

</VirtualHost>

# Redirect HTTP traffic to HTTPS
<VirtualHost *:80>

    ServerName  sub.domain.com
    Redirect / https://sub.domain.com/na

</VirtualHost>

# HTTPS configuration
<IfModule mod_ssl.c>
    <VirtualHost _default_:443>

        ServerName domain.com
        ServerAlias www.domain.com
        ServerAlias sub.domain.com

        ServerAdmin info@domain.com
        DocumentRoot /var/www/html
        DirectoryIndex index.php

        # Logging and such
        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined

        # Enable mod_ssl and mod_rewrite
        RewriteEngine on
        SSLEngine on

        RewriteCond %{HTTP_HOST} ^sub.domain.com$
        RewriteCond %{REQUEST_URI} ^/?$
        RewriteRule ^/?(.*)$ /na/ [R=301]

        RewriteCond %{HTTP_HOST} ^domain.com$ [OR]
        RewriteCond %{HTTP_HOST} ^www.domain.com$
        RewriteCond %{REQUEST_URI} ^/?$
        RewriteRule ^/?(.*)$ https://www.domain.com/za/ [R=301]

        RewriteCond %{HTTP_HOST} ^domain.com$ [OR]
        RewriteCond %{HTTP_HOST} ^www.domain.com$
        RewriteCond %{REQUEST_URI} ^/na/.*$
        RewriteRule ^/na/(.*)$ https://www.domain.com/za/$1 [R=301]

        RewriteCond %{HTTP_HOST} ^sub.domain.com$
        RewriteCond %{REQUEST_URI} ^/za/.*$
        RewriteRule ^/za/(.*)$ /na/$1 [R=301]

        RewriteCond %{REQUEST_URI} ^.*\.php$
        RewriteRule ^/(.*)\.php$ /$1 [R=301,QSA]

        RewriteCond %{REQUEST_URI} !^/za/admn/.*
        RewriteCond %{REQUEST_URI} !^/za/ea/.*
        RewriteCond %{REQUEST_URI} ^/.*/index$
        RewriteRule ^/(.*)/index$ /$1 [R=301,QSA]

        RewriteCond %{HTTP_HOST} ^sub.domain.com$
        RewriteCond %{REQUEST_URI} ^/na/.*$
        RewriteRule ^/na/(.*)$ /za/$1

        RewriteCond %{REQUEST_FILENAME} !-d
        RewriteCond %{REQUEST_FILENAME} !-f
        RewriteCond %{DOCUMENT_ROOT}/$1\.php -f
        RewriteRule ^/(.*)$ /$1.php [L,QSA]

        # SSL Stuff goes here
        SSLCertificateFile  /etc/ssl/certs/ssl-cert-snakeoil.pem
        SSLCertificateKeyFile /etc/ssl/private/ssl-cert-snakeoil.key

        <FilesMatch "\.(cgi|shtml|phtml|php)$">
            SSLOptions +StdEnvVars
        </FilesMatch>
        <Directory /usr/lib/cgi-bin>
            SSLOptions +StdEnvVars
        </Directory>
        <Directory /var/www/>
            Options Indexes FollowSymLinks
            AllowOverride All
            Order allow,deny
            allow from all
        </Directory>

        BrowserMatch "MSIE [2-6]" \
                       nokeepalive ssl-unclean-shutdown \
                       downgrade-1.0 force-response-1.0

        Include /etc/phpmyadmin/apache.conf

    </VirtualHost>
</IfModule>

1 ответ

У вас есть конфигурация include для PHPMyAdmin после вашей другой конфигурации, которая включает в себя перенаправление catch-all:

RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{DOCUMENT_ROOT}/$1\.php -f
RewriteRule ^/(.*)$ /$1.php [L,QSA]

Итак, переместите Include Заявление ранее в файле конфигурации.

Другие вопросы по тегам