✅ WEB- och WordPress -nyheter, teman, plugins. Här delar vi tips och bästa webbplatslösningar.

Hur kontrollerar jag om en eller flera användare är inloggade med Cookie i WordPress?

26

WordPress tillhandahåller ett API is_user_logged_in() för att kontrollera om någon användare är inloggad, men tyvärr är det inte direkt tillgängligt när du skriver plugins t.ex. Plugins laddas innan pluggable.php vilket är där is_user_logged_in() definieras.

Från implementeringen av is_user_logged_in() kan du se att det är:

function is_user_logged_in() {
    $user = wp_get_current_user(); 
    return $user->exists();
}

Så vi kan ändra funktionen för att kontrollera om en angiven användare har loggat in.

function is_username_logged_in($username) {
    $user = wp_get_current_user(); 
    return $user->user_login == $username;  
}

Däremot är kärnfunktionen wp_get_current_user fortfarande definierad i pluggable.php. Följande implementerar en funktion som tar en rad tillåtna användarnamn och returnerar true om något tillåtet användarnamn har loggat in.

function allowedUsersLoggedIn($allowd_users) {
    if (count($_COOKIE)) {
        foreach ($_COOKIE as $key => $val) {
            if (substr($key, 0, 19) === "wordpress_logged_in") {
                if (preg_match('/^('. implode('|', $allowed_users). ')/', $val, $matches)) {
                    return true;
                }
            }
        }
    }
    return false;
}

Du kan säkert använda den här funktionen var som helst, även utan WP-miljön. Exempelanvändningen skulle vara:

if (allowedUsersLoggedIn(array("helloacm", "steakovercooked")) {
  // code that only allowed users run
}

Principen för den här funktionen är att kontrollera COOKIE för specificerad sträng när tillåtna användare är inloggade.

Inspelningskälla: helloacm.com

Denna webbplats använder cookies för att förbättra din upplevelse. Vi antar att du är ok med detta, men du kan välja bort det om du vill. Jag accepterar Fler detaljer