Nginx phpmyadmin redirecionando para / em vez de / phpmyadmin após o login


9

Estou tendo problemas com o meu phpmyadmin na minha instalação do nginx.

Quando entro <ServerIP>/phpmyadmine faço login, sou redirecionado para, em <ServerIP>/index.php?<tokenstuff>vez de<ServerIP>/phpmyadmin/index.php?<tokenstuff>

Arquivo de configuração do Nginx:

user  nginx;
worker_processes  5;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  2;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}

Default.conf:

server {
    listen       80;
    server_name  _;

    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.php index.html index.htm;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    location ~ \.php$ {
        root           /usr/share/nginx/html;
        try_files $uri =404;
        fastcgi_pass   unix:/tmp/php5-fpm.sock;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    location ~ /\.ht {
        deny  all;
    }
    location /phpmyadmin {
    root /usr/share/;
    index index.php index.html index.htm;
    location ~ ^/phpmyadmin/(.+\.php)$ {
        try_files $uri =404;
        root /usr/share/;
        fastcgi_pass unix:/tmp/php5-fpm.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $request_filename;
        include fastcgi_params;
        fastcgi_param PATH_INFO $fastcgi_script_name;
    }

    location ~* ^/phpmyadmin/(.+\.(jpg|jpeg|gif|css|png|js|ico|html|xml|txt))$ {
        root /usr/share/;
    }
}
}

(Quaisquer dicas gerais sobre como arrumar esses arquivos de configuração também são aceitas)


@ MichaelHampton Na verdade, acho que esse foi o problema. Eu removi o pacote instalado via yum e baixei as últimas do site phpmyadmin e voilá. Se você responder, eu aceito.
Frederik Nielsen

Respostas:


2

Isso não parece um problema do nginx. Parece que o phpMyAdmin não foi instalado corretamente e pensa que está no /lugar de /phpmyadmin. Verifique sua configuração do phpMyAdmin.


Foi isso que me levou à resposta certa - reinstalando o phpmyadmin - Obrigado! :)
Frederik Nielsen

4
"apenas reinstalar" é uma resposta absurda. Se a configuração do phpMyAdmin estiver incorreta, deve haver uma maneira de reconfigurar sem precisar reinstalar o aplicativo inteiro!
alexw

1
Isso requer mais informações: Por favor, vincule a uma fonte que explica como e onde definir o parâmetro 'onde o PHP pensa que está'.
Diana

Isso é mais um comentário do que uma resposta. Ótima sugestão, mas verifique o phpMyAdmin para quê?
SherylHohman

@ SherylHohman Isso pode fazer uma pergunta interessante feita separadamente. Mas este foi resolvido há muito tempo.
Michael Hampton

13

Embora o autor tenha resolvido o problema de reinstalar o phpMyAdmin, o nginx precisa ser configurado corretamente para lidar com o redirecionamento no login corretamente.

Depois de dias esmagando minha cabeça no teclado, finalmente encontrei a solução real e estou compartilhando aqui, pois esse segmento ainda tem alta prioridade na pesquisa do google.

Conforme indicado no link: http://www.samundra.com.np/use-phpmyadmin-with-nginx-and-php7/1374

Para resolver o problema, você deve adicionar o seguinte bloco de código ao site padrão do nginx disponível: você o acessará com:

sudo nano /etc/nginx/sites-available/default

Coloque este bloco no serverbloco:

# Phpmyadmin Configurations
    location /phpmyadmin {
       root /usr/share/;
       index index.php index.html index.htm;
       location ~ ^/phpmyadmin/(.+\.php)$ {
               try_files $uri =404;
               root /usr/share/;
               #fastcgi_pass 127.0.0.1:9000;
               #fastcgi_param HTTPS on; # <-- add this line
               fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
               fastcgi_index index.php;
               fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
               include fastcgi_params;
       }
       location ~* ^/phpmyadmin/(.+\.(jpg|jpeg|gif|css|png|js|ico|html|xml|txt))$ {
               root /usr/share/;
       }
   }

   # Dealing with the uppercased letters
   location /phpMyAdmin {
       rewrite ^/* /phpmyadmin last;
   }

Espero que isso ajude alguém um dia ...


Fico feliz que isso tenha resolvido seu problema! Happy codings!
Daniel Alves

É isso aqui mesmo ... corrige todos os problemas ...
ThatTechGuy 12/11/16

definitivamente me salvou mais de um dia. até votado!
Xu Yin

Não corrige isso para mim. Alguma outra ideia?
Diana

E se eu não quiser o phpmyadmin em / phpmyadmin, mas em / o que quer que seja? Tentei alterar os "locais" aninhados, mas não funcionou.
0lli.rocks

4

Esse problema é causado pela configuração comum de cgi.fix_pathinfo = 0 que desativa o caminho atual do PHP-FPM. Uma solução rápida é alterar cgi.fix_pathinfo de volta para 1 ou definir os parâmetros do caminho no bloco do servidor virtual do nginx.


2

Seu problema parece ser semelhante a este: /programming/1011101/nginx-location-directive-doesnt-seem-to-be-working-am-i-missing-something

Se lendo isso e alterando sua configuração, você ainda tiver problemas, por favor, diga!


Eu li esse segmento, e tentou algumas das configurações, mas ainda o mesmo problema - ou será redirecionado para / em vez de / phpmyadmin, ou apenas vai 404.
Frederik Nielsen

404 é "gerado" por "try_files", o que significa que não está encontrando arquivos phpmyadmin ... talvez algo errado com a instalação do phpmyamdin?
Mikec

Apenas observe o outro comentário -.- Eu acho que era o phpmyadmin config depois de tudo!
Mikec

Pode ser ... acho que foi uma combinação dos dois.
Frederik Nielsen


0

adicione um host virtaul ao servidor da lâmpada com qualquer nome de domínio como phpmyadmin1.com

server {
    #listen 80 default_server;
    #listen [::]:80 default_server ipv6only=on;

    root /var/www/phpmyadmin;
    #some /var/www/html/phpmyadmin
    index index.php index.html index.htm;

    server_name phpmyadmin1.com;

        location / {
        try_files $uri $uri/ /index.php?$args;
     }

    location ~ \.php$ {
        root           /usr/share/nginx/html;
        try_files $uri =404;
        fastcgi_pass   unix:/tmp/php5-fpm.sock;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
}

Edite seu arquivo Hosts

adicione esta linha na parte inferior

192.168.1.xx  phpmyadmin1.com

salve e feche e reinicie o servidor

service nginx restart

service php5-fpm restart

Acesse o URL do host virtual no navegador e veja a página de login do phpmyadmin

http://screencloud.net/v/nGK5

http://screencloud.net/v/6M8r


Bem-vindo à falha do servidor! Em ambas as suas perguntas e respostas por favor, tente se abster de utilizar nomes aleatórios de domínio e use o seu próprio domínio ou um dos RFC 6761 nomes de domínio reservados tais como example.com, example.org ou semelhantes. Consulte estas perguntas e respostas para obter nossas recomendações sobre como e o que não ocultar em suas perguntas.
HBruijn

0

Só isso funcionou para mim

location /utils/phpmyadmin/ {
    try_files $uri $uri/ =404;
    index index.php index.html index.htm
    proxy_set_header Proxy "";
}

-1

O phpMyAdmin dos repositórios do Ubuntu 16.04 e posterior não redireciona corretamente.

Acabei de baixar a nova versão do phpmyadmin no site oficial do phpmyadmin:

sudo wget https://files.phpmyadmin.net/phpMyAdmin/4.6.6/phpMyAdmin-4.6.6-all-languages.tar.gz

sudo tar xvf phpMyAdmin-4.6.6-all-languages.tar.gz

sudo mv phpMyAdmin-4.6.6-all-languages /usr/share/phpmyadmin

sudo rm -rf phpMyAdmin-4.6.6-all-languages.tar.gz

sudo cp /usr/share/phpmyadmin/config.sample.inc.php /usr/share/phpmyadmin/config.inc.php

abra config.inc.php:

sudo nano /usr/share/phpmyadmin/config.inc.php

e colocar algum caracter aleatório entre

$cfg['blowfish_secret'] = 'i\kywQ>_h4L~S-Pt2rS'VAe)QpED7JI#';

salve e abra seu domínio / phpmyadmin no navegador

Também é possível alterar o link para phpmyadmin (para melhor segurança) e adicionar autenticação básica do nginx ao link:

sudo ln -s /usr/share/phpmyadmin /var/www/html

cd /var/www/html

sudo mv phpmyadmin anything

agora seu phpmyadmin trabalha em https: // domain / qualquer coisa , vamos adicionar uma senha:

sudo sh -c "echo -n 'YourNameForLoginThere:' >> /etc/nginx/pmapass"
sudo sh -c "openssl passwd -apr1 >> /etc/nginx/pmapass"

agora abra sua configuração do nginx (por padrão: sudo nano / etc / nginx / sites-available / default ) e adicione befor last}

location /anything {
    auth_basic "Restricted";
    auth_basic_user_file /etc/nginx/pmapass;
}

Ativar armazenamento de configuração:

sudo nano /usr/share/phpmyadmin/config.inc.php

Localize as seguintes linhas:

// $cfg['Servers'][$i]['controluser'] = 'pma';
// $cfg['Servers'][$i]['controlpass'] = 'pmapass';

Mudar para:

$cfg['Servers'][$i]['controluser'] = 'yourdatabaseuser';
$cfg['Servers'][$i]['controlpass'] = 'yourdatabasepassword';

Localizar:

// $cfg['Servers'][$i]['pmadb'] = 'phpmyadmin';
// $cfg['Servers'][$i]['bookmarktable'] = 'pma__bookmark';
// $cfg['Servers'][$i]['relation'] = 'pma__relation';
// $cfg['Servers'][$i]['table_info'] = 'pma__table_info';
// $cfg['Servers'][$i]['table_coords'] = 'pma__table_coords';
// $cfg['Servers'][$i]['pdf_pages'] = 'pma__pdf_pages';
// $cfg['Servers'][$i]['column_info'] = 'pma__column_info';
// $cfg['Servers'][$i]['history'] = 'pma__history';
// $cfg['Servers'][$i]['table_uiprefs'] = 'pma__table_uiprefs';
// $cfg['Servers'][$i]['tracking'] = 'pma__tracking';
// $cfg['Servers'][$i]['userconfig'] = 'pma__userconfig';
// $cfg['Servers'][$i]['recent'] = 'pma__recent';
// $cfg['Servers'][$i]['favorite'] = 'pma__favorite';
// $cfg['Servers'][$i]['users'] = 'pma__users';
// $cfg['Servers'][$i]['usergroups'] = 'pma__usergroups';
// $cfg['Servers'][$i]['navigationhiding'] = 'pma__navigationhiding';
// $cfg['Servers'][$i]['savedsearches'] = 'pma__savedsearches';
// $cfg['Servers'][$i]['central_columns'] = 'pma__central_columns';
// $cfg['Servers'][$i]['designer_settings'] = 'pma__designer_settings';
// $cfg['Servers'][$i]['export_templates'] = 'pma__export_templates';

Descomente-os ( remova // )

Agora salve e saia.

Vá para o seu mysql (por padrão: sudo mysql -u root -p )

GRANT SELECT, INSERT, UPDATE, DELETE ON phpmyadmin.* TO 'yourdatabaseuser'@'localhost' IDENTIFIED BY 'yourdatabasepassword';
exit;

agora tente abrir domínio / qualquer coisa no navegador

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.