在wp_signon

时间:2017-08-28 10:14:08

标签: wordpress authentication wordpress-login

我使用自定义登录表单,这是代码。成功登录后,它会重定向到/ portal页面,但在门户页面中,用户登录状态为false。

$email = $_REQUEST['login_email'];
        $password = $_REQUEST['login_password'];

        $args = array(
            'orderby'      => 'login',
            'order'        => 'ASC',
            'fields'       => 'all'
            );
        $count=0;
        $all_users = get_users( $args );
        $login_data['user_password'] = $password;
        $login_data['user_login'] = $email;
        $login_data['remember'] = true;
        $user_verify = wp_signon( $login_data, true );

        $userID = $user_verify->ID;

        do_action( 'wp_login', $email );
        wp_set_current_user( $userID, $email );
        wp_set_auth_cookie( $userID, true, false );


        if ( is_wp_error($user_verify) ){
            $loginerror = true;
            $errors['login_error']=__("Error in login",'domain');
        }
        else{
            $loginSuccess = true;
            $_SESSION['login_email']=$email; // Initializing Session
            if(empty($previous_location))
            {

                wp_safe_redirect( home_url('/portal/'));
            }
            else{
                wp_safe_redirect($previous_location);
            }
            exit();
        }

但在/portal页面中,当var_dump(is_user_logged_in())时,它返回false。这里发生了什么?我做了什么?

2 个答案:

答案 0 :(得分:0)

我有同样的经历。事实证明我的自定义注册机制是错误。我使用$wpdb对象和插入方法添加了使用自定义SQL查询的新用户。

这种方法与后来的wp_signon用法有所不同。如果您还有自定义注册机制,请尝试使用wp_insert_user方法,然后使用$wpdb->update更新自定义列或其他内容。

答案 1 :(得分:0)

我知道这个问题很旧,但是我在这个问题上苦苦挣扎了很长时间,我只想与下一个人分享我的知识。

我的问题是页面重新加载时页面标题已经发送,因此导致wp_signon()正常工作的问题。为了解决这个问题,我创建了此函数并将其放在我的functions.php文件中:

add_action('template_redirect', 'my_check_login');
function my_check_login(){
    if( is_page_template('custom-login.php') ){
        global $wpdb; 

        //SQL Escape all inputs
        $email = $wpdb->escape($_POST['email']);  
        $password = $wpdb->escape($_POST['password']);  
        $remember = $wpdb->escape($_POST['rememberme']);  

        if($remember) $remember = "true";  
        else $remember = "false";

        $login_data = array();  
        $login_data['user_login'] = $email;  
        $login_data['user_password'] = $password;  
        $login_data['remember'] = $remember;  

        $user_verify = wp_signon( $login_data, false );
        if ( is_wp_error($user_verify) ) {  
            echo "Invalid login details";  
        } else {    
            wp_set_current_user($user_verify->ID);
            wp_set_auth_cookie($user_verify->ID,true);
            echo "<script type='text/javascript'>window.location.href='". home_url() ."'</script>";
            exit();  
        }
    } else {  
        // Add user feedback here
        //echo "Invalid login details";  
    }  
}

其中的custom-login.php文件只是一种简单形式:

<?php  
/** 
 * Template Name: Login page 
 */  
 get_header();   

?>  
<div class="background-light">
    <div class="container">
        <div class="row">
            <div class="offset-3 col-6">
                <form id="login1" class="registration-form" name="form" action="<?php echo home_url(); ?>/login/" method="post">
                    <input id="email" type="text" placeholder="Email" name="email"><br>  
                    <input id="password" type="password" placeholder="Password" name="password">  
                    <input id="submit" type="submit" name="submit" value="Submit">  
                </form>
            </div>
        </div>
    </div>
</div>