WordPress密码重置链接地址无效怎么办?无需更改源文件

人只需不取得标的目标,就不会取得自己。有没有人爱,我们也要努力做一个可爱的人。不埋怨谁,不嘲笑谁,也不羡慕谁,阳光下灿烂,风雨中奔跑,做自己的梦,走自己的路。

当用户注册或者忘记密码获取新密码时 WordPress 会自动向用户邮箱中发送一个验证链接地址,一般 QQ 邮箱用户打开这个密码重置链接地址却显示无效。这个问题的并不是 WordPress 的原因,正常 WordPress 设置密码的链接地址是没有超链接的,但是 QQ 邮箱自作聪明为个链接地址加上了超链接,并把本不是链接地址内容的<>符号也加了进去,结果造成链接错误。

解决这个 WordPress 密码重置链接无效的办法,网上大多数都是直接修改 WordPress 源文件,但是 WordPress 升级程序后,又需要再次修改。所以想要达到一劳永逸的效果,只需要将以下代码添加到当前主题的 functions.php 文件中即可(以 WordPress 5.3.2 为例)。

// 修正忘记密码获取新密码链接
add_filter('retrieve_password_message', 'zm_reset_password_message_amend', 99, 1);
function zm_reset_password_message_amend($string) {
return preg_replace('/<(' . preg_quote(network_site_url(), '/') . '[^>]*)>/', '\1', $string);
}

// 修正用户注册设置密码链接
add_filter( 'wp_new_user_notification_email' , 'zm_user_notification_email_amend', 10, 3 );
function zm_user_notification_email_amend( $wp_new_user_notification_email, $user, $user_email ) {
global $wpdb, $wp_hasher;
$key = wp_generate_password( 20, false );
do_action( 'retrieve_password_key', $user->user_login, $key );
if ( empty( $wp_hasher ) ) {
require_once ABSPATH . WPINC . '/class-phpass.php';
$wp_hasher = new PasswordHash( 8, true );
}
$hashed = time() . ':' . $wp_hasher->HashPassword( $key );
$wpdb->update( $wpdb->users, array( 'user_activation_key' => $hashed ), array( 'user_login' => $user->user_login ) );
$switched_locale = switch_to_locale( get_user_locale( $user ) );
$message = sprintf(__('Username: %s'), $user->display_name) . "\r\n\r\n";
$message .= __('To set your password, visit the following address:') . "\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";
$wp_new_user_notification_email['message'] = $message;
return $wp_new_user_notification_email;
}

内容整理自:知更鸟 - https://zmingcx.com/wordpress-password-link-correction.html

本文WordPress密码重置链接地址无效怎么办?无需更改源文件到此结束。我们不是没有遇上过奇迹,只是我们没有足够的好奇心。小编再次感谢大家对我们的支持!

标签: WordPress