0

我正在创建一个简单的登录/注册页面,其中包含用户审核和引导 wp 以完成繁重的工作。

我可以将新用户添加到数据库中,并创建密码并对其进行哈希处理,但是当我使用该帐户登录时,密码将不起作用。我难住了……

但是,当我在我的管理员帐户下进入管理员并更改用户的密码时,它允许我登录就好了......

有人看到我缺少的东西吗?

require_once( ABSPATH . WPINC . '/registration.php' );
$user_pass = wp_generate_password();
$userdata = array(
  'user_pass' => $user_pass,
  'user_login' => esc_attr( $_POST['user_email'] ),
  'user_email' => esc_attr( $_POST['user_email'] ),
);

if( !$userdata['user_login'] )
  $error .= __('An Email Address is required for registration.', 'frontendprofile');
elseif ( username_exists( $userdata['user_login'] ) )
  $error .= __('Sorry, that Email Address is already in use for another account.', 'frontendprofile');
elseif ( !is_email( $userdata['user_email'] ) )
  $error .= __('You must enter a valid Email Address.', 'frontendprofile');
elseif ( email_exists( $userdata['user_email'] ) )
  $error .= __('Sorry, that Email Address is already for another account.', 'frontendprofile');

else{
  $new_user = wp_update_user( $userdata );
}
4

2 回答 2

1

现在你需要使用这个
例如:

$password   = wp_generate_password( 8, false );
wp_set_password( $password, $user->ID );
于 2020-04-24T16:24:51.807 回答
0

知道了。我猜不能使用 wp_update_user 进行新添加。

需要使用:

wp_create_user( $userdata['user_login'], $userdata['user_pass'], $userdata['user_email'] );

于 2011-03-16T14:08:04.600 回答