我在Woocommerce注册后尝试向WP_USERMETA
表添加自定义字段
add_filter('woocommerce_new_customer_data', 'wc_assign_custom_role', 10, 1);
function wc_assign_custom_role($args) {
update_user_meta($user_id, 'user_pass2', password_hash($_POST['password'], PASSWORD_DEFAULT));
return $args;
}
如您所见,我试图在散列之前捕获密码并将其以其他散列格式保存在该表中
但它不会向表中添加任何内容
我测试了wordpress注册钩user_register
内的同一行,并且行得通,但仅适用于wordpress注册而不是woocommerce
更新
add_filter('woocommerce_new_customer_data', 'wc_assign_custom_role', 10, 1);
function wc_assign_custom_role($args) {
global $current_user;
update_user_meta($current_user->$user_id, 'user_pass2', password_hash($_POST['password'], PASSWORD_DEFAULT));
return $args;
}
仍然不起作用
UPDATE II
function action_woocommerce_created_customer( $customer_id, $new_customer_data, $password_generated ) {
update_user_meta($customer_id, 'user_pass2', password_hash($_POST['password'], PASSWORD_DEFAULT));
};
add_action( 'woocommerce_created_customer', 'action_woocommerce_created_customer', 10, 3 );
此人创建了元数据,但似乎它使用了不同的$_POST['password']
而不是我输入的密码,因此对其他内容进行了哈希处理,而不是密码
有什么想法吗?
答案 0 :(得分:2)
找到了解决方案,我们应该使用$_POST['account_password']
而不是$_POST['password']
function action_woocommerce_created_customer( $customer_id, $new_customer_data, $password_generated ) {
update_user_meta($customer_id, 'user_pass2', password_hash($_POST['account_password'], PASSWORD_DEFAULT));
};
add_action( 'woocommerce_created_customer', 'action_woocommerce_created_customer', 10, 3 );
答案 1 :(得分:1)
在查看woocommerce_created_customer
操作钩所在的源代码时,密码可以找到为$new_customer_data['user_pass']
(请参见答案末尾)。。。 >
因此您的代码应为:
add_action( 'woocommerce_created_customer', 'action_woocommerce_created_customer', 10, 3 );
function action_woocommerce_created_customer( $customer_id, $new_customer_data, $password_generated ) {
update_user_meta($customer_id, 'user_pass2', password_hash($new_customer_data['user_pass'], PASSWORD_DEFAULT));
}
代码进入您的活动子主题(或活动主题)的function.php文件中。应该可以。
这是wc_create_new_customer()
函数中涉及的相关源代码:
$new_customer_data = apply_filters( 'woocommerce_new_customer_data', array(
'user_login' => $username,
'user_pass' => $password,
'user_email' => $email,
'role' => 'customer',
) );
不需要和$_POST['account_password']
,因为已经存储在$password
变量中。