WordPress新用户注册时提示“您的密码重设链接无效”

在使用Wordpress密码找回功能及新用户注册邮件中的重置密码链接时,Wordpress提示“您的密码重设链接无效,请在下方请求新链接。”、“该key似乎无效”、“invalid key”。

这个其实不是wordpress的问题,邮箱收到邮件后,会将密码重置链接地址及其前后的“<>”一起当成链接地址生成超链接,点击此超链接后,由于传给wordpress的参数不对(多了个>),例如把鼠标移到下图的红色框的连接上,并看到浏览器左下角的URL提示连接,会发现多了一个“>”,所以wordpress提示密码重设链接无效。

  此问题主要影响忘记密码时的找回密码功能及新用户注册时,系统给新用户发送的密码设置功能。可通过以下两个步骤解决此问题:

  • 解决找回密码时提示“您的密码重设链接无效”:

  打开WP根目录下的 wp-login.php,找到如下代码(374行左右):

$message .= ‘<‘ . network_site_url("wp-login.php?action=rp&key=$key&login=" . rawurlencode($user_login), ‘login‘) . ">\r\n";

  修改为:

$message .= network_site_url("wp-login.php?action=rp&key=$key&login=" . rawurlencode($user_login), ‘login‘) . "\r\n";

  即去掉两个尖括号即可。

  • 解决新用户注册时,点击邮件中的重置密码链接提示“您的密码重设链接无效”:

  打开WP安装目录下的/wp-includes/pluggable.php,找到如下代码(1741行左右):

$message .= ‘<‘ . network_site_url("wp-login.php?action=rp&key=$key&login=" . rawurlencode($user->user_login), ‘login‘) . ">\r\n\r\n";

  修改为:

$message .= network_site_url("wp-login.php?action=rp&key=$key&login=" . rawurlencode($user->user_login), ‘login‘) . "\r\n\r\n";

  以上修改后,用户收到的密码重置及新用户收到的密码设置邮件将不会再包含“<>”,用户再邮箱中点击链接后即可正常重置或者设置密码。以上修改涉及到Wordpress源代码的修改,每次升级Wordpress后修改会被覆盖,必须重新进行以上修改。

  另一种解决方式:把下面的代码加入当前主题的functions.php里面就可以了。

/**
* 修复WordPress找回密码提示“抱歉,该key似乎无效”问题 */ function reset_password_message( $message, $key ) { if ( strpos($_POST[‘user_login‘], ‘@‘) ) { $user_data = get_user_by(‘email‘, trim($_POST[‘user_login‘]));
} else { $login = trim($_POST[‘user_login‘]); $user_data = get_user_by(‘login‘, $login);
} $user_login = $user_data->user_login; $msg = __(‘有人要求重设如下帐号的密码:‘). "\r\n\r\n"; $msg .= network_site_url() . "\r\n\r\n"; $msg .= sprintf(__(‘用户名:%s‘), $user_login) . "\r\n\r\n"; $msg .= __(‘若这不是您本人要求的,请忽略本邮件,一切如常。‘) . "\r\n\r\n"; $msg .= __(‘要重置您的密码,请打开下面的链接:‘). "\r\n\r\n"; $msg .= network_site_url("wp-login.php?action=rp&key=$key&login=" . rawurlencode($user_login), ‘login‘) ; return $msg;
}
add_filter(‘retrieve_password_message‘, reset_password_message, null, 2);

  这种办法的缺点是,每次换主题都要重新把代码添加到主题的function.php文件中。

原文地址:https://www.cnblogs.com/Dean0731/p/12341148.html

时间: 2024-10-07 02:03:25

WordPress新用户注册时提示“您的密码重设链接无效”的相关文章

EMS 动手实验2:用户自助密码重设&amp;条件访问策略强制用户使用MFA二次验证&amp;启用标识保护配置风险检测

前言: 本系列实验将引导用户完成O365 企业移动性和安全性(Enterprise Mobility Security)的常用操作和配置,本着实用性和安全性的原则,该系列实验会建议一些最佳实践.本系列实验主要分为以下几个阶段: 将Azure AD 登陆和审核日志发送到Azure Monitor 用户自助密码重设&条件访问策略强制用户使用MFA二次验证&启用标识保护配置风险检测 使用 Privileged Identity Management建立管理角色的审批和授权 使用Intune 管理

创建Windows10 密码重设盘

如果你忘记Windows10的用户密码,则可以通过创建的密码重设盘重新创建一个新的密码.(只能为本地账户创建密码重置盘.) 1.打开"控制面板--用户账户和家庭安全--用户账户",选择"创建密码重置盘": 2.打开忘记密码向导并选择"下一步": 3.选择创建密码重置的磁盘(需要可移动媒体,如:USB闪存驱动器或软盘):选择"下一步": 4.输入当前的用户密码,如果没有,则不需要输入,然后选择"下一步": 5

Web服务器管理系列:9、创建密码重设盘

互联网时代需要记录的密码实在太多了,一不小心可能会忘记,假如服务器的密码忘记了将会是件很麻烦的事. Windows Server 2008 为我们提供了创建密码重设盘的功能: 点击创建密码重设盘: 点击下一步: 选择U盘然后点击下一步: 输入当前用户的密码然后点下一步: 密码重设盘创建成功,下面我们看看Windows Server 2008在我们的U盘上写入了什么: 下面我给大家演示下如何使用密码重设盘: 我们在登录的时候输错一次密码就会出现"重设密码"按钮: 我们点击"重设

DedeCMS密码重设工具radminpass

本工具是用于新人忘记管理员密码重设所制作,只需要将radminpass.php文件拷贝到根目录,运行"http://yousite/radminpass.php(yousite为网站域名)",按照操作执行就可以.恢复完成后请及时删除这个文件! 1.针对GBK的文件 <?php /********************** DedeCMS 管理员帐号重设工具. http://bbs.dedecms.com/ ***********************/ //error_rep

android studio新项目时提示:Plugin is too old, please update to a more recent version

今天想写一个程序来测试一下android studo代码,但是创建好项目后,提示: Error:(1, 0) Plugin is too old, please update to a more recent version, or set ANDROID_DAILY_OVERRIDE environment variable to "8051cdccc746d532152541ee35015fd83699f14"<a href="fixGradleElements&q

《OpenGL编程指南第七版》学习——编译时提示“error C2381: “exit” : 重定义;__declspec(noreturn) 不同”错误的解决办法

解决办法一. #if defined(_WIN32) # ifndef GLUT_BUILDING_LIBextern _CRTIMP void __cdecl exit(int); 上面是glut.h中对exit的使用,意思是如果没有定义宏?GLUT_BUILDING_LIB,就使用它的exit,那我们就在项目的属性--预处理器 里定义这个宏,这样就不执行glut.h中的exit了,而只执行stdlib.h中的exit.这样也就不会冲突了.对了,还要在附加依赖项里手动加上?glut32.lib

MySQL方法总结--密码重设问题

root用户密码设置及忘记密码的解决方法 root用户密码不能为空,需要设置一个密码,看下面设置密码的三种方法: 方法1: 用SET PASSWORD命令  首先登录MySQL,使用mysql自带的那个客户端连接上mysql. 格式:mysql> set password for 用户名@localhost = password('新密码'); 例子:mysql> set password for [email protected] = password('123'); 方法2:用mysqla

Ubuntu忘记MySQL密码重设方法

====================忘了mysql密码,从网上找到的解决方案记录在这里==================== 结束当前正在运行的mysql进程 # /etc/init.d/mysql stop 用mysql安全模式运行并跳过权限验证 # mysqld_safe --user=mysql --skip-grant-tables --skip-networking & 用空密码方式使用root用户登录 MySQL #  mysql -u root mysql 更新密码 # up

Ubuntu下忘记MySQL密码重设方法

http://www.cnblogs.com/yuxc/archive/2012/07/25/2607587.html 1.结束当前正在运行的mysql进程.# /etc/init.d/mysql stop 2.用mysql安全模式运行并跳过权限验证.# /usr/bin/mysqld_safe --skip-grant-tables 3.重开一个终端以root身份登录mysql.# mysql -u root 4.修改root用户口令.mysql> use mysql;Reading tabl