sql >> Databáze >  >> Database Tools >> phpMyAdmin

Chyba ukládání konfigurace phpMyAdmin

Po prozkoumání kódu jsem skončil u této funkce.

/**
 * 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 php dovednosti jsou omezené, ale mohu říci, že to pročítá soubory v adresáři plugins/transformations a vrací tyto názvy souborů do skriptů, které odkazují na tuto funkci. Když jsem procházel tento adresář z terminálu, všiml jsem si, že je zaplněn soubory ._ vytvořenými Finderem. K vývoji používám mac a stáhl jsem tuto nejnovější kopii phpmyadmin pomocí finderu místo wget, takže byly vytvořeny všechny tyto ._ soubory. Něco na nich tuto funkci zkazilo a jakmile jsem je odstranil příkazem find na základní úrovni, vše fungovalo, jak bylo zamýšleno. Zde je příkaz find pro každého, kdo zažívá něco podobného:

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

Znovu to spusťte na základní úrovni adresáře phpmyadmin a vše by mělo být v pořádku.




  1. jak vybrat datový řádek z pole hodnot oddělených čárkami

  2. Jak nastavit (kombinovat) dva primární klíče v tabulce

  3. Vzdálený přístup phpMyAdmin

  4. phpMyAdmin zamrzne při použití LIMIT