我正试图使用wordpress多站点开发ajax登录,但由于某些原因,我无法实现。我将凭据发送到我的脚本中,看起来还可以,它返回了正确的用户数据。问题是,当我用没有"_nopriv"的hook进行另一个ajax调用时,它返回false,所以用户没有登录,就好像WP不记得用户一样。
这是我的php代码:
add_action( 'wp_ajax_admin_login', 'admin_login' );
add_action( 'wp_ajax_nopriv_admin_login', 'admin_login' );
function admin_login() {
$succ = true;
$creds = array(
'user_login' => $_POST["user_login"],
'user_password' => $_POST["user_pass"],
'remember' => true
);
$user = wp_signon( $creds );
if ( is_wp_error( $user ) ) {
$succ = false;
$user = "Login failed!";
}
else{
do_action('wp_signon', $user->user_login);
wp_set_auth_cookie($user->ID);
wp_set_current_user($user->ID, $_POST["user_login"]);
}
echo json_encode(array('success' => $succ, 'currUser' => wp_get_current_user()));
wp_die();
}
我用js中的/admin/wp-admin/admin-ajax.php调用所需博客的url。请帮忙!
您需要在wp_signon
中传递$cred
数组。'user_login'
只包含用户的用户名。
do_action('wp_signon', $user->user_login);
而是
do_action('wp_signon', $creds);