WordPress数据库错误: [Table 'wibir.w_b2_post_relationships' doesn't exist]
SELECT COUNT(*) FROM w_b2_post_relationships WHERE `type`="post_up" AND `post_id`=762

WordPress数据库错误: [Table 'wibir.w_b2_post_relationships' doesn't exist]
SELECT COUNT(*) FROM w_b2_post_relationships WHERE `type`="post_down" AND `post_id`=762

WordPress根据用户名获取用户id的两种方式

这个问题是我在做前端登陆注册,并通过邮件激活账户的时候发现的,因为WordPress并没有封装单独的根据用户名获取用户id的方法,百度后找到两种方式来获得用户id。一种是直接操作数据库,通过数据库查询找到我们需要的用户id,另一种就是通过WordPress函数查询用户所有数据,然后输出id字段。其实前者就是后者的封装,下面我们看看这两种方式的实现代码。

方式一,查数据库获得用户id

function get_user_id($user=''){
 $user="'".$user."'";
 global $wpdb;
 $user_ids = $wpdb->get_col("SELECT ID FROM $wpdb->users WHERE user_login = $user ORDER BY ID");
 foreach($user_ids as $user_id){
 return $user_id;
 }
}

将上面的代码放在functions.php文件中,使用<?php echo get_user_id($user); ?>输出用户id。

方式二,WordPress函数查询用户id

function get_user_id($user=''){
 $author_obj = get_user_by('login', $user);
return $author_obj->ID;
}

使用方式与方式一的一样,核心代码只有两句get_user_by与$author_obj->ID,与方式一相比,明显代码简洁很多,建议使用第二种方式获取用户id。

get_user_by使用说明

get_user_by( string $field, int|string $value )

按指定字段检索用户信息。

参数解释

$field

(字符串) (必须) 用户检索的字段. id | ID | slug | email | login.

$value

(整型|字符串) (必须) 检索字段的值.  user ID, slug, email address, or login name.

返回值

(WP_User|false) 成功返回WP_User对象,失败返回false。

简单使用

$user = get_user_by( 'email', 'user@example.com' );
echo 'User is ' . $user->first_name . ' ' . $user->last_name;
经验分享

在WordPress中开发API接口

2020-3-16 21:34:51

经验分享

wordpress 处理 ajax 请求

2020-3-17 21:35:43

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索