Hur kontrollerar jag om en eller flera användare är inloggade med Cookie i WordPress?
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.