这个需求是来源一个会员制度的网站,网站模式还有点特殊,他本来就有个会员插件了,但是网站用户又不是会员制度…

开始是搜索插件的,但是试了几个,都是不是想要的功能,然后搜索到了其他网站有发过这种代码,就测试了下,还是可以用的。

把下面代码加到主题或者子主题的functions.php文件里面:

// WordPress 禁止指定用户登录 
//在资料页面添加选项
function jzzd_dl_admin_init(){ 
 // 编辑用户资料
 add_action( 'edit_user_profile', 'jzzd_dl_edit_user_profile' );
 add_action( 'edit_user_profile_update', 'jzzd_dl_edit_user_profile_update' ); 
}
add_action('admin_init', 'jzzd_dl_admin_init' );
 
//在个人资料页面添加一个复选框
function jzzd_dl_edit_user_profile() {
 if ( !current_user_can( 'edit_users' ) ) {
 return;
 } 
 global $user_id; 
 // 用户不能禁止自己
 $current_user = wp_get_current_user();
 $current_user_id = $current_user->ID;
 if ( $current_user_id == $user_id ) {
 return;
 }
 ?>
 <h3>权限设置</h3>
 <table class="form-table">
 <tr>
 <th scope="row">禁止用户登录</th>
 <td><label for="jzzd_dl_ban"><input name="jzzd_dl_ban" type="checkbox" id="jzzd_dl_ban" 
 <?php if (jzzd_dl_is_user_banned( $user_id )){echo 'checked="checked"';} ?> /> 请谨慎操作,选中则禁止!</label></td>
 </tr>
 </table>
 <?php
}
 
//添加一个函数来将这个选项的值保存到数据库中
function jzzd_dl_edit_user_profile_update() { 
 if ( !current_user_can( 'edit_users' ) ) {
 return;
 } 
 global $user_id; 
 // 用户不能禁止自己
 $current_user = wp_get_current_user();
 $current_user_id = $current_user->ID;
 if ( $current_user_id == $user_id ) {
 return;
 } 
 // 锁定
 if( isset( $_POST['jzzd_dl_ban'] ) && $_POST['jzzd_dl_ban'] = 'on' ) {
 jzzd_dl_ban_user( $user_id );
 } else { // 解锁
 jzzd_dl_unban_user( $user_id );
 } 
}
 
//禁止用户
function jzzd_dl_ban_user( $user_id ) { 
 $old_status = jzzd_dl_is_user_banned( $user_id ); 
 // 更新状态
 if ( !$old_status ) {
 update_user_option( $user_id, 'jzzd_dl_banned', true, false );
 }
}
 
//解禁用户
function jzzd_dl_unban_user( $user_id ) { 
 $old_status = jzzd_dl_is_user_banned( $user_id ); 
 // 更新状态
 if ( $old_status ) {
 update_user_option( $user_id, 'jzzd_dl_banned', false, false );
 }
}
 
//判断用户是否被禁止
function jzzd_dl_is_user_banned( $user_id ) {
 return get_user_option( 'jzzd_dl_banned', $user_id, false );
}
 
//阻止已禁止的用户登录
function jzzd_dl_authenticate_user( $user ) { 
 if ( is_wp_error( $user ) ) {
 return $user;
 } 
 // 如果用户被禁止,则返回错误提示
 $banned = get_user_option( 'jzzd_dl_banned', $user->ID, false );
 if ( $banned ) {
 return new WP_Error( 'jzzd_dl_banned', __('您已经被禁止登陆', 'dl') );
 } 
 return $user;
}
//将该函数挂载到 wp_authenticate_user 钩子
add_filter( 'wp_authenticate_user', 'jzzd_dl_authenticate_user', 1 );

然后去编辑用户哪里,就有个禁止用户登录的选项了。

标签为: