1

我正在 NginX 服务器上设置 PHPMyAdmin。系统本身可以工作,但是,我应该能够更改设置(即构建新的 config.inc.php)的 /setup 页面是空白的。它不显示错误,返回 200 OK 并且 /var/log/nginx/error.log 中没有任何内容。

这是我对此服务器块的 nginx 配置:

listen [::]:80;

root                /usr/share/phpmyadmin; # path to my pma installation
index               index.php;
charset             utf-8;

server_name         my-host;

location / {
    autoindex       off;
}

location ~ \.php$ {
    try_files       $uri =404;
    fastcgi_split_path_info ^(.+\.php)(/.+)$;
    fastcgi_pass    127.0.0.1:9000;
    fastcgi_index   index.php;
    include         fastcgi_params;
}

location ~ /\. {
    deny            all;
}

location /libraries {
    deny            all;
}

location /setup/lib {
    deny            all;
}

有谁知道这里发生了什么?

/setup/lib/common.inc.php 文件中似乎有错误:

<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
 * Loads libraries/common.inc.php and preforms some additional actions
 *
 * @package PhpMyAdmin-setup
 */

/**
 * Do not include full common.
 * @ignore
 */
echo 1;
define('PMA_MINIMUM_COMMON', true);
define('PMA_SETUP', true);
chdir('..');
echo 2;
if (!file_exists('./libraries/common.inc.php')) {
    die('Bad invocation!');
}

echo 3;
require_once './libraries/common.inc.php';
require_once './libraries/config/config_functions.lib.php';
require_once './libraries/config/messages.inc.php';
require_once './libraries/config/ConfigFile.class.php';
require_once './libraries/url_generating.lib.php';
require_once './libraries/user_preferences.lib.php';
echo 4;

// use default error handler
restore_error_handler();

echo 5;

// Save current language in a cookie, required since we use PMA_MINIMUM_COMMON
$GLOBALS['PMA_Config']->setCookie('pma_lang', $GLOBALS['lang']);

echo 6;

ConfigFile::getInstance()->setPersistKeys(array(
    'DefaultLang',
    'ServerDefault',
    'UploadDir',
    'SaveDir',
    'Servers/1/verbose',
    'Servers/1/host',
    'Servers/1/port',
    'Servers/1/socket',
    'Servers/1/extension',
    'Servers/1/connect_type',
    'Servers/1/auth_type',
    'Servers/1/user',
    'Servers/1/password'));

echo 7;

// allows for redirection even after sending some data
ob_start();

输出:123456

4

3 回答 3

2

我遇到了同样的问题,我通过更改特定于我的 phpmyadmin 目录的 nginx conf 中的默认缓冲区大小来解决它。最后 4 行是我添加/更改的行。

location ~ \.php$ {
  try_files $uri =404;
  fastcgi_pass unix:/var/run/php5-fpm.sock;
  fastcgi_index index.php;
  fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  include fastcgi_params;
  fastcgi_buffer_size 128k;
  fastcgi_buffers 256 4k;
  fastcgi_busy_buffers_size 256k;
  fastcgi_temp_file_write_size 256k;
}
于 2015-05-04T20:21:05.977 回答
0

这很可能与错误 #1175142相同,已在 4:4.0.1-2 修复。问题是在 Debian 打包的 phpMyAdmin 中,配置脚本包含一个辅助函数,这阻止了配置文件被多次加载。

于 2014-03-31T07:23:55.240 回答
0

修复了在我的 /etc/nginx/conf.d/virtual.conf 文件中添加这些选项的问题:

location ~ \.php$ {
....
  include fastcgi_params;
  fastcgi_buffer_size 128k;
  fastcgi_buffers 256 4k;
  fastcgi_busy_buffers_size 256k;
  fastcgi_temp_file_write_size 256k;
...
}

并重新启动 nginx。

于 2016-03-01T13:07:06.873 回答