有两种方法呢,
当然,我是肯定只说用代码的那种啦~
在'functions.php'里加入下面的代码
代码如下 |
复制代码 |
function email_address_login($username) {
$user = get_user_by_email($username);
if(!empty($user->user_login))
$username = $user->user_login;
return $username;
}
add_action('wp_authenticate','email_address_login');
|
这样就大功告成了
但是由于wp登陆页面中的提示文本是输入用户名
所以同时你总得让你网站的注册用户知道你现在支持邮箱登陆了吧
打开'wp-login.php'
搜索代码
大功告成啦。
只是唯一的缺点就是你一旦升级就会覆盖修改后的'wp-login.php'文件。
嘛。上面的做法其实可以用一段代码来代替
PHP
代码如下 |
复制代码 |
// 修改WordPress用户名过滤机制,通过Email获取用户名
function ludou_allow_email_login($username, $raw_username, $strict) {
if (filter_var($raw_username, FILTER_VALIDATE_EMAIL)) {
$user_data = get_user_by('email', $raw_username);
if (empty($user_data))
wp_die(__('ERROR: There is no user registered with that email address.'), '用户名不正确');
else
return $user_data->user_login;
}
else {
return $username;
}
}
// 修改登录界面的文字,"用户名"改成"用户名或邮箱"
function ludou_change_text() {
echo '';
}
if (in_array($GLOBALS['pagenow'], array('wp-login.php')) && strpos($_SERVER['REQUEST_URI'], '?action=register') === FALSE && strpos($_SERVER['REQUEST_URI'], '?action=lostpassword') === FALSE && strpos($_SERVER['REQUEST_URI'], '?action=rp') === FALSE ) {
add_filter('sanitize_user', 'ludou_allow_email_login', 10, 3);
add_action('login_footer', 'ludou_change_text');
}
|
同样,添加到functions.php内就可以了~
方法三 将下面的代码添加到当前主题的 functions.php 文件即可
代码如下 |
复制代码 |
//让WordPress支持用户名或邮箱登录
function dr_email_login_authenticate( $user, $username, $password ) {
if ( is_a( $user, 'WP_User' ) )
return $user;
if ( !empty( $username ) ) {
$username = str_replace( '&', '&', stripslashes( $username ) );
$user = get_user_by( 'email', $username );
if ( isset( $user, $user->user_login, $user->user_status ) && 0 == (int) $user->user_status )
$username = $user->user_login;
}
return wp_authenticate_username_password( null, $username, $password );
}
remove_filter( 'authenticate', 'wp_authenticate_username_password', 20, 3 );
add_filter( 'authenticate', 'dr_email_login_authenticate', 20, 3 );
//替换“用户名”为“用户名 / 邮箱”
function username_or_email_login() {
if ( 'wp-login.php' != basename( $_SERVER['SCRIPT_NAME'] ) )
return;
?>
}
add_action( 'login_form', 'username_or_email_login' );
|