it-swarm.com.de

Ist die Formatierungsfunktion sanitize_title_with_dashes zu liberal (in Bezug auf akzeptierte Zeichen)?

sanitize_title_with_dashes (siehe Code unten als Referenz) ist die Funktion, mit der Wordpress "hübsche" URLs formatiert. Im Gegensatz zur Kommentarkopfzeile der Funktion sind jedoch weit mehr als alphanumerische Zeichen, Unterstriche (_) und Bindestriche (-) zulässig. Es erlaubt auch Zeichen wie ° usw.

Wie gehe ich vor, um wirklich nur alphanumerische Zeichen und Bindestriche zuzulassen?

/**
 * Sanitizes title, replacing whitespace with dashes.
 *
 * Limits the output to alphanumeric characters, underscore (_) and dash (-).
 * Whitespace becomes a dash.
 *
 * @since 1.2.0
 *
 * @param string $title The title to be sanitized.
 * @return string The sanitized title.
 */
function sanitize_title_with_dashes($title) {
    $title = strip_tags($title);
    // Preserve escaped octets.
    $title = preg_replace('|%([a-fA-F0-9][a-fA-F0-9])|', '---$1---', $title);
    // Remove percent signs that are not part of an octet.
    $title = str_replace('%', '', $title);
    // Restore octets.
    $title = preg_replace('|---([a-fA-F0-9][a-fA-F0-9])---|', '%$1', $title);

    $title = remove_accents($title);
    if (seems_utf8($title)) {
        if (function_exists('mb_strtolower')) {
            $title = mb_strtolower($title, 'UTF-8');
        }
        $title = utf8_uri_encode($title, 200);
    }

    $title = strtolower($title);
    $title = preg_replace('/&.+?;/', '', $title); // kill entities
    $title = str_replace('.', '-', $title);
    $title = preg_replace('/[^%a-z0-9 _-]/', '', $title);
    $title = preg_replace('/\s+/', '-', $title);
    $title = preg_replace('|-+|', '-', $title);
    $title = trim($title, '-');

    return $title;
}
1
julien_c

Betrachten Sie diese Funktion als groben Platzhalter. Es hat mehr Mängel, als Sie sich vorstellen können ... :)
Es gibt viele Plugins, um die Konvertierung für verschiedene Sprachen und Bedürfnisse zu verbessern. Sie können sich mein Plugin Germanix ansehen, um zu sehen, wie das gemacht werden kann.

1
fuxia