- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我创建了一个共享相同用户(共享相同的 wp_users 和 wp_user_meta 表)的 Woocommerce 商店(数据库前缀 wp_)和一个 Wordpress 博客(数据库前缀 wp_new_)。
我不仅要同步用户,还要同步所有用户的用户角色(多个用户角色)。
为此,我尝试了 https://kinsta.com/blog/share-logins-wordpress/ 提供的解决方案
function ksu_save_role( $user_id, $role ) {
$prefix_1 = 'wp_';
$prefix_2 = 'wp_new_';
$caps = get_user_meta( $user_id, $prefix_1 . 'capabilities', true );
$level = get_user_meta( $user_id, $prefix_1 . 'user_level', true );
if ( $caps ){
update_user_meta( $user_id, $prefix_2 . 'capabilities', $caps );
}
if ( $level ){
update_user_meta( $user_id, $prefix_2 . 'user_level', $level );
}
}
add_action( 'set_user_role', 'ksu_save_role', 10, 2 );
当只有一个用户角色分配给用户时,上述解决方案非常有效。但是,如果一个用户被分配了多个用户角色,那么它就不起作用了。我的意思是,它不会同步所有用户角色。
通过数据库挖掘后,我了解到解决方案在于将“wp_capabilities”的“meta_value”克隆到“wp_new_capabilities”(在 wp_usermeta 中)
有没有办法将“user_id”的整个“meta_value”从“wp_capabilities”复制到“wp_new_capabilities”?
如果我们可以将整个元值从“wp_capabilities”复制到“wp_new_capabilities”,那么可以同步分配给用户的所有用户角色。
那么需要对上述代码做哪些更改才能实现这一点?
谢谢!
最佳答案
我在同步用户角色(每个用户多个用户角色)方面遇到了问题。经过两个多晚上的挑灯夜战,我找到了愚蠢的神奇解决方案:)
我只是在“add_action( 'set_user_role', 'ksu_save_role', 10, 2 );”中将 'set_user_role' 更改为 'add_user_role'
小魔法调整后的结束代码
function ksu_save_role( $user_id, $role ) {
// Site 1
// Change value if needed
$prefix_1 = 'first_';
// Site 2 prefix
// Change value if needed
$prefix_2 = 'second_';
$caps = get_user_meta( $user_id, $prefix_1 . 'capabilities', true );
$level = get_user_meta( $user_id, $prefix_1 . 'user_level', true );
if ( $caps ){
update_user_meta( $user_id, $prefix_2 . 'capabilities', $caps );
}
if ( $level ){
update_user_meta( $user_id, $prefix_2 . 'user_level', $level );
}
}
add_action( 'add_user_role', 'ksu_save_role', 10, 2 ); // THE MAGIC MODIFICATION
代码学分:https://kinsta.com/blog/share-logins-wordpress/
将它添加到 functions.php,你就可以开始了。
它与“Woocommerce Subscriptions”和“YITH Automatic Role Changer for WooCommerce Premium”等角色转换器插件兼容
您可以根据需要设置和更改任意数量的角色。
关于php - 在共享相同 wp_users 和 wp_usermeta 表的两个 Wordpress 安装之间同步所有用户角色。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49279891/
我正在使用 XAMPP 在 Mac (OSx Sierra) 上本地开发一个 WordPress 主题。它被设置为当我在 URL 中键入 localhost/ThemeName 时,我被带到我的站点。
在表 WP_USER 中添加新列是否好 - 或者 - 我应该在 metauser 表中添加内容吗?我在质疑这个,因为有一个 WP 功能 /* Get full WP_User object insta
正在脱机处理一个站点,突然出现 mysql 端口冲突错误,然后我不得不花很多时间研究它的解决方案,但没有运气。所以我从 xampp 手动获取主题文件和数据库,并将它们粘贴到另一个安装了新 xampp
在表 WP_USER 中添加新列是否好 - 或者 - 我应该在 metauser 表中添加内容吗?我在质疑这个,因为有一个 WP 功能 /* Get full WP_User object insta
我需要自定义数据,这就是为什么我在应用插入查询时创建了一个名为 company_name 的列,然后插入了所有数据,但未插入 company_name 数据。 下面是我的代码示例: $userdata
SELECT * FROM `wp_users` group by date(user_registered),month(user_registered) 表中有 4 条记录,但查询仅返回每个日
当用户注册时,数据将进入标准 wp_users 表。但我创建了一个新表,我想将所有(新)注册用户存储在其中。我怎样才能改变它? 最佳答案 add_action('user_register', 'my
我有一个代码示例: function custom_func(){ global $wpdb; $wpdb->flush(); //tried with and without
我使用网站的仪表板在 Wordpress 上创建了一个新用户。新用户已成功创建,我可以使用创建的用户登录。然而,当我检查网站使用的 MySQL 数据库时,我惊讶地发现 wp_user 表中没有新条目反
我无法登录到管理仪表板。当我转到 localhost/nutri/wp-admin 时,它会自动将我重定向到: http://localhost/nutri/wp-login.php?redirect
我正在编写一个基本插件。这是我的代码: $new_user = get_userdata($user_id); //$user_id is passed as a parameter $fir
我创建了一个简单的 html 表单来向我编写的 php 脚本提交一个值。我正在使用WordPress。我希望脚本在 user_meta 表中查找用户,然后选择用户 ID。然后我希望脚本在 wp_use
有没有办法从单独的 WordPress 安装中检索 WP_User 对象? 我正在尝试显示另一个 Wordpress 站点的用户列表。我不一定希望新的 WordPress 网站共享相同的用户,我只需要
我创建了一个简单的 html 表单,用于向我编写的 php 脚本提交两个值(车牌号和状态)。我正在使用 wordpress。我希望脚本在 wp_usermeta 表中查找用户,并选择具有与表单中提交的
我正在编写一个插件,它使用...从 WordPress 数据库中获取一组数据 $data = $wpdb->get_results("SELECT * FROM $wpdb->users", ARRA
我有一个自定义查询,可以使用我编写的统计插件的 user_meta 拉取用户。我可以根据日期范围选择 (WHERE),也可以按任何元字段进行排序,但是,我不能同时进行这两项操作。我快疯了!!这是我的查
如果我这样做,我会显示许多属性,包括 display_name,但不会显示名字和姓氏 $user = get_userdata( 4 ); print_r( $user ); 但是它们显然存在,因为如
这就是我能够将每个用户记录的所有相关数据提取到一行中的方法: SELECT user_login, user_pass, user_email, user_registered, meta1.meta
默认情况下,wordpress 会清理写入 wp_users 表中的 user_nicename 列的内容。它将删除空格、一些特殊字符并将大写字母更改为小写字母。是否可以在不进行清理的情况下更新 us
我们正在使用 WordPress 来开发您的网站。当 user_status=2 时,用户处于事件状态;当 user_status=0 时,用户处于非事件状态。那么user_status=1是什么意思
我是一名优秀的程序员,十分优秀!