使用 login_url 鉤子基於角色的 WordPress 重定向
P粉533898694
P粉533898694 2023-09-11 17:53:57
0
1
719

我正在嘗試使用login_url 它適用於未登入的用戶。 但它對登入使用者不起作用(它將他們重定向到 /access-denied/ 頁面,這很奇怪),我真的不知道為什麼。

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

全部回覆(1)
P粉369196603

這並不太難:

$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;
}
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板