我已经尝试了在注册时设置用户密码的所有内容,但没有成功...我有字段显示,验证(如果密码匹配等)我在屏幕上打印它们,我打印用户ID在屏幕上,所以每个参数都需要,但功能似乎根本不起作用...... 这不起作用......
$newpassword = "zzzzzz";
update_user_meta($user_id, 'user_pass', $newpassword);
这也不起作用......
add_action( 'user_register', 'ts_register_extra_fields', 10 );
function ts_register_extra_fields($user_id, $password='11',$meta = array()){
$userdata = array();
if ( $_POST['password'] !== '' ) {
$userdata['user_pass'] = $_POST['password'];
}
$new_user_id = wp_update_user( $userdata );
}
我的客户明天需要这个,所以我现在完全迷失了,我不知道为什么它不起作用......
忘记添加,所有这些代码都添加到我主题的functions.php中。 (它进入它,因为我已经说过我在屏幕上发布变量)。
add_action( 'user_register', 'ts_register_extra_fields', 100 );
function ts_register_extra_fields( $user_id, $password = '', $meta = array() ) {
$userdata = array();
$userdata['ID'] = $user_id;
$userdata['contacto'] = $_POST['contacto'];
$userdata['nif'] = $_POST['nif'];
if ( $_POST['password'] !== '' ) {
$userdata['user_pass'] = $_POST['password'];
echo "im in";
}
$new_user_id = wp_insert_user( $userdata );
echo "id-".$userdata['ID'];
echo "contacto-".$userdata['contacto'];
echo "nif-".$userdata['nif'];
echo "pass-".$userdata['user_pass'];
}
所有那些回声输出正确的数据...例如下次我尝试196等时id = 195 ... contacto和nif显示我在自定义注册字段中输入的数据,并且该通道还显示我在自定义注册字段密码中输入的数据...
答案 0 :(得分:1)
首先,我认为WordPress正在使用MD5加密密码。
$hash = wp_hash_password( $newpassword );
// then wp_update_user with $hash as the user_pass value
其次,您不应通过Internet以明文形式发送密码。如果您可以在发送之前使用javascript加密密码,那么它可能会更加安全。
最后,通过在wp_update_user
中指定ID来尝试更新现有用户。
答案 1 :(得分:1)
HA!发现错误。我安装了另一个名为“New User Aprovement”的插件,需要管理员批准才能让用户登录。当管理员接受用户登录时,该插件生成另一个密码(能够以可读模式将密码发送给用户),使用户注册时生成的密码更新失效(因为它在生成随机密码后生成管理员接受)。
我通过禁用插件和测试functions.php找到了这个。它确实有效。为了使它们都工作,我只删除了生成随机密码的插件中的代码。虽然用户没有通过电子邮件收到帐户摘要。它适合我的需要。
最诚挚的问候, Vcoder