网站模板库
  • 首页
  • web前端工具
    • HTML/JS转换工具
    • JS/HTML格式化工具
    • 字母/英文大小写转换工具
    • robots.txt文件生成工具
    • Js压缩/格式化工具
    • Css在线压缩工具_代码格式化
  • 关于我们
    • 免责声明
    • 联系我们
    • 广告服务
    • 服务项目
    • 关于我们
    • 网站轮播
    • 公告
    • 成都优优科技专用
    • 按行业分类
  • web学院
    • 服务器教程
    • 学习资料
      • 基础书籍
      • 交互书籍
      • 入门教程
      • 特效分类
    • 案例分享
    • web资讯
  • 网页特效
    • 图片特效
    • 导航特效
    • 滑动按钮
    • 表单特效
    • 文字特效
    • 弹窗特效
    • 其他特效
  • 织梦模板
    • 科技/电子/数码/通信
    • 文化/艺术/广告/传媒
    • 装修/设计/家居/家具
    • 基建/施工/地产/物业
    • 餐饮/酒店/旅游/票务
    • 食品/果蔬/饮料/日用
    • 服饰/珠宝/礼品/玩具
    • 摄影/婚庆/家政/生活
    • 运动/健身/体育/器材
    • 学校/教育/培训/科研
    • 美容/保健/医院/医疗
    • 金融/财税/咨询/法律
    • 政府/组织/集团/协会
    • 汽车/物流/交通/搬运
    • 机械/设备/制造/仪器
    • 化工/环保/能源/材料
    • 农业/畜牧/养殖/宠物
    • 其他模版
    • IT/软件/信息/互联网
  • 手机模板
    • 手机APP模板
    • 微信小程序模板
    • wap
  • 网站模板
    • joomla模板
    • Drupal模板
    • z-blog模板
    • EyouCms模板
    • Bootstrap模板
    • 帝国cms模板
    • CmsEasy模板
    • MetInfo模板
    • 购物商城模板
      • Shopify主题
      • PrestaShop主题
    • 后台模板
    • 纯HTML模板
    • ecshop模板
    • phpwind模板
    • pbootcms模板
    • phpcms模板
    • wordpress模板
    • discuz模板
  • 教程
    • 织梦教程
    • Discuz教程
    • WordPress教程
    • Phpcms教程
    • Phpwind教程
    • ECShop教程
    • Joomla教程
    • Drupal教程
    • zblog教程
    • EyouCMS教程
    • 帝国cms教程
    • MetInfo教程
    • CmsEasy教程
登录
当前位置:网站模板库 > web学院 > 案例分享 > wordpress怎么设置为邮箱登录
admin 案例分享 2020-08-22 9:11:56

wordpress怎么设置为邮箱登录

wordpress怎么设置为邮箱登录,第1张

WordPress注册账号都是英文字母组成。时间一久,可能很多用户都会忘记注册账号及密码。一个用户名就成为了绊脚石。

wordpress怎么设置为邮箱登录,第2张

但是我们如果换成邮箱登录就不一样了。很多用户就只有一两个邮箱账号,就很容易记起用户名及密码。
我们甚至可以为了安全,禁止使用用户名登录,而只使用email登录。如何实现呢?

在主题functions.php文件中,增加下面的代码:

// 修改WordPress用户名过滤机制,通过Email获取用户名 function utubon_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(__('<strong>ERROR</strong>: There is no user registered with that email address.'), '用户名不正确'); ??? else ????? return $user_data->user_login; ? }else { ??? return $username; ? } }  // 修改登录界面的文字,"用户名"改成"用户名或邮箱" function utubon_change_text() { ? echo '<script type="text/javascript"> ??????????????? var user_login_node = document.getElementById("user_login"); ??????????????? var old_username_text = user_login_node.parentNode.innerHTML; ??????????????? user_login_node.parentNode.innerHTML = old_username_text.replace(/用户名/, "用户名或邮箱"); ????? </script>'; }  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', 'utubon_allow_email_login', 10, 3); ? add_action('login_footer', 'utubon_change_text'); } 

如果要实现只能用邮箱登录,提供了下面的代码

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 ) { ?? ?// remove the default filter ?? ?remove_filter( 'authenticate', 'wp_authenticate_username_password', 20, 3 ); ?? ?// add custom filter ?? ?add_filter( 'authenticate', 'my_authenticate_username_password', 20, 3 ); ?? ?// 修改登录框提示为使用邮箱登录 ?? ?add_action('login_footer', 'change_login_text'); }  // Change login credentials function my_authenticate_username_password( $user, $username, $password ) {  ??? // If an email address is entered in the username box, ??? // then look up the matching username and authenticate as per normal, using that. ??? if ( ! empty( $username ) ) { ??????? //if the username is not email set username to blank string ??????? //causes authenticate to fail ?? ??? ?if(!filter_var($username,FILTER_VALIDATE_EMAIL)){ ??????????????? $username = time(); ??????????? } ??????? $user = get_user_by( 'email', $username ); ??????? } ??? if ( isset( $user->user_login, $user ) ) ??????? $username = $user->user_login;  ??? // using the username found when looking up via email ??? return wp_authenticate_username_password( NULL, $username, $password ); }  // 修改登录界面的文字,"用户名"改成"用户名或邮箱" function change_login_text() { ? echo '<script type="text/javascript"> ??????????????? var user_login_node = document.getElementById("user_login"); ??????????????? var old_username_text = user_login_node.parentNode.innerHTML; ??????????????? user_login_node.parentNode.innerHTML = old_username_text.replace(/用户名/, "用户邮箱"); ????? </script>'; }

 

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » wordpress怎么设置为邮箱登录

admin 钻石

分享到:
上一篇
wordpress文章中首图设置为缩略图
下一篇
Linux系统安装宝塔面板及配置运行环境

相关推荐

《捕蛇者说》18 期发布:竟然有人在前端做科学计算?

《捕蛇者说》18 期发布:竟然有人在前端做科学计算?

如何用 PHP 在 aaa.com 设置 bbb.com 的 cookie 呢?:doge:

如何用 PHP 在 aaa.com 设置 bbb.com 的 cookie 呢?:doge:

Pycoder's Weekly 中文翻译

Pycoder's Weekly 中文翻译

PhpStorm 8.0 Released

PhpStorm 8.0 Released

0条评论

发表评论 取消回复

要发表评论,您必须先登录。

提供最优质的资源集合

立即查看 了解详情
网站模板库

主题/付费下载/查看/余额管理/自定义积分,集成支付,卡密,推广奖励等。

本站导航
  • 链接标题
友情链接
  • 链接标题
快速搜索
本站由钛宇宙强力驱动
友情链接:
    商业源码网蜀ICP备2023005044号
    网站模板库
    • 登录
    • 注册
    网站模板库
    • 首页
    • web前端工具►
      • HTML/JS转换工具
      • JS/HTML格式化工具
      • 字母/英文大小写转换工具
      • robots.txt文件生成工具
      • Js压缩/格式化工具
      • Css在线压缩工具_代码格式化
    • 关于我们►
      • 免责声明
      • 联系我们
      • 广告服务
      • 服务项目
      • 关于我们
      • 网站轮播
      • 公告
      • 成都优优科技专用
      • 按行业分类
    • web学院►
      • 服务器教程
      • 学习资料►
        • 基础书籍
        • 交互书籍
        • 入门教程
        • 特效分类
      • 案例分享
      • web资讯
    • 网页特效►
      • 图片特效
      • 导航特效
      • 滑动按钮
      • 表单特效
      • 文字特效
      • 弹窗特效
      • 其他特效
    • 织梦模板►
      • 科技/电子/数码/通信
      • 文化/艺术/广告/传媒
      • 装修/设计/家居/家具
      • 基建/施工/地产/物业
      • 餐饮/酒店/旅游/票务
      • 食品/果蔬/饮料/日用
      • 服饰/珠宝/礼品/玩具
      • 摄影/婚庆/家政/生活
      • 运动/健身/体育/器材
      • 学校/教育/培训/科研
      • 美容/保健/医院/医疗
      • 金融/财税/咨询/法律
      • 政府/组织/集团/协会
      • 汽车/物流/交通/搬运
      • 机械/设备/制造/仪器
      • 化工/环保/能源/材料
      • 农业/畜牧/养殖/宠物
      • 其他模版
      • IT/软件/信息/互联网
    • 手机模板►
      • 手机APP模板
      • 微信小程序模板
      • wap
    • 网站模板►
      • joomla模板
      • Drupal模板
      • z-blog模板
      • EyouCms模板
      • Bootstrap模板
      • 帝国cms模板
      • CmsEasy模板
      • MetInfo模板
      • 购物商城模板►
        • Shopify主题
        • PrestaShop主题
      • 后台模板
      • 纯HTML模板
      • ecshop模板
      • phpwind模板
      • pbootcms模板
      • phpcms模板
      • wordpress模板
      • discuz模板
    • 教程►
      • 织梦教程
      • Discuz教程
      • WordPress教程
      • Phpcms教程
      • Phpwind教程
      • ECShop教程
      • Joomla教程
      • Drupal教程
      • zblog教程
      • EyouCMS教程
      • 帝国cms教程
      • MetInfo教程
      • CmsEasy教程

      弹窗标题

      这是一条网站公告,可在后台开启或关闭,可自定义背景颜色,标题,内容,用户首次打开关闭后不再重复弹出,此处可使用html标签...