sql >> Database teknologi >  >> Database Tools >> phpMyAdmin

phpMyAdmin-konfigurationslagringsfejl

Efter at have kigget koden igennem endte jeg ved denne funktion.

/**
 * 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;
}

Mine php-færdigheder er begrænsede, men jeg kan se, at det læser filerne i plugins/transformations-mappen og returnerer disse filnavne til de scripts, der refererer til denne funktion. Da jeg gennemsøgte denne mappe fra en terminal, bemærkede jeg, at den var fyldt op med ._-filer oprettet af finder. Jeg bruger en mac til at lave min udvikling på, og jeg havde trukket denne seneste kopi af phpmyadmin ved hjælp af finder i stedet for wget, så alle disse ._ filer blev oprettet. Noget ved dem forvirrede denne funktion, og når jeg fjernede dem med en find-kommando på basisniveauet, fungerede alt efter hensigten. Her er find-kommandoen til alle, der oplever noget lignende:

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

Igen, kør det på basisniveauet af phpmyadmin-biblioteket, og alt skulle være i orden.




  1. PhpMyAdmin Import Fejl-MySQL-serveren er gået væk/ukendt søgeord

  2. Hvordan får T-SQL-koden til at finde dubletter?

  3. hvordan man får login mulighed for phpmyadmin i xampp

  4. MySQL Workbench-tegnsæt