我使用自定义登录表单,这是代码。成功登录后,它会重定向到/ 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。这里发生了什么?我做了什么?
答案 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>