Come verificare se uno o più utenti hanno effettuato l’accesso utilizzando i cookie in WordPress?
WordPress fornisce un’API is_user_logged_in() per verificare se un utente sta effettuando il login, ma sfortunatamente non è direttamente disponibile quando si scrivono plug- in, ad esempio i plug-in vengono caricati prima di pluggable.php che è dove is_user_logged_in() è definito.
Dall’implementazione di is_user_logged_in() puoi vedere che è:
function is_user_logged_in() {
$user = wp_get_current_user();
return $user->exists();
}
Quindi, possiamo modificare la funzione per verificare se un utente specificato ha effettuato l’accesso.
function is_username_logged_in($username) {
$user = wp_get_current_user();
return $user->user_login == $username;
}
Tuttavia, la funzione principale wp_get_current_user è ancora definita in pluggable.php. Quanto segue implementa una funzione che accetta una matrice di nomi utente consentiti e restituisce true se un qualsiasi nome utente consentito ha effettuato l’accesso.
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;
}
Puoi tranquillamente utilizzare questa funzione ovunque, anche senza l’ambiente WP. L’uso del campione sarebbe:
if (allowedUsersLoggedIn(array("helloacm", "steakovercooked")) {
// code that only allowed users run
}
Il principio di questa funzione è controllare il COOKIE per la stringa specificata quando gli utenti autorizzati hanno effettuato l’accesso.