Redirection WordPress basée sur les rôles à l'aide du hook login_url
P粉533898694
P粉533898694 2023-09-11 17:53:57
0
1
639

J'essaie d'utiliser login_url Cela fonctionne pour les utilisateurs qui ne sont pas connectés. Mais ça ne marche pas pour les utilisateurs connectés (ça les redirige vers la page /access-denied/, ce qui est bizarre) et je ne sais pas trop pourquoi.

global $current_user;
$current_user = wp_get_current_user();

function my_login_page( $login_url ) {
    $user = $current_user;
    $valid_roles = [ "administrator", "editor", "custom-role" ];
    $the_roles = array_intersect( $valid_roles, $user->roles );

    if ( empty( $the_roles ) ) {
        return ( "/access-denied/" );
    } else {
        return ( "/login/" );
    }
}
add_filter( "login_url", "my_login_page", 10 );

P粉533898694
P粉533898694

répondre à tous(1)
P粉369196603

Ce n'est pas trop difficile :

$user = $current_user;
$valid_roles = [ 'administrator', 'editor', 'custom-role' ];
$the_roles = array_intersect( $valid_roles, $user->roles );

if ( empty( $the_roles ) ) {
    nocache_headers();
    wp_safe_redirect( '/access-denied/' ); 
    exit;
}
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!