phpMyAdmin
 sql >> Baza danych >  >> Database Tools >> phpMyAdmin

Błąd przechowywania konfiguracji phpMyAdmin

Po przejrzeniu kodu trafiłem na tę funkcję.

/**
 * Gets all available MIME-types
 *
 * @access  public
 * @staticvar   array   mimetypes
 * @return array    array[mimetype], array[transformation]
 */
function PMA_getAvailableMIMEtypes()
{
    static $stack = null;

    if (null !== $stack) {
        return $stack;
    }

    $stack = array();
    $filestack = array();

    $handle = opendir('./libraries/plugins/transformations');

    if (! $handle) {
        return $stack;
    }

    while ($file = readdir($handle)) {
        $filestack[] = $file;
    }

    closedir($handle);
    sort($filestack);

    foreach ($filestack as $file) {
        if (preg_match('|^.*_.*_.*\.class\.php$|', $file)) {
            // File contains transformation functions.
            $parts = explode('_', str_replace('.class.php', '', $file));
            $mimetype = $parts[0] . "/" . $parts[1];
            $stack['mimetype'][$mimetype] = $mimetype;
            $stack['transformation'][] = $mimetype . ': ' . $parts[2];
            $stack['transformation_file'][] = $file;

        } elseif (preg_match('|^.*\.class.php$|', $file)) {
            // File is a plain mimetype, no functions.
            $base = str_replace('.class.php', '', $file);

            if ($base != 'global') {
                $mimetype = str_replace('_', '/', $base);
                $stack['mimetype'][$mimetype] = $mimetype;
                $stack['empty_mimetype'][$mimetype] = $mimetype;
            }
        }
    }

    return $stack;
}

Moje umiejętności php są ograniczone, ale mogę powiedzieć, że czyta on pliki w katalogu plugins/transformations i zwraca te nazwy plików do skryptów, które odwołują się do tej funkcji. Kiedy przeglądałem ten katalog z terminala, zauważyłem, że jest on wypełniony plikami ._ utworzonymi przez finder. Używam mac do mojego rozwoju i ściągnąłem tę najnowszą kopię phpmyadmina za pomocą finder zamiast wget, więc wszystkie te pliki ._ zostały utworzone. Coś w nich zepsuło tę funkcję i kiedy usunąłem je za pomocą polecenia wyszukiwania na poziomie podstawowym, wszystko działało zgodnie z przeznaczeniem. Oto polecenie znajdź dla każdego, kto doświadcza czegoś podobnego:

find . -type f -name '._*' -exec rm {} \;

Ponownie uruchom to na podstawowym poziomie katalogu phpmyadmin i wszystko powinno być w porządku.




  1. DBeaver
  2.   
  3. phpMyAdmin
  4.   
  5. Navicat
  6.   
  7. SSMS
  8.   
  9. MySQL Workbench
  10.   
  11. SQLyog
  1. Zapytanie SQL nie działa w phpMyAdmin, ponieważ otrzymuję błąd

  2. Zapytanie Mysql działa w phpmyadmin, ale nie w php (ze względu na datę)

  3. phpMyAdmin w Xampp nie działa

  4. Jak WYBRAĆ DOMYŚLNĄ wartość pola

  5. SQL Jak usunąć dane z tabeli za pomocą INNER JOIN