Ich versuche, ein passowrd Rücksetzformular zu erstellen. Hier ist meine Funktion:
<?php
$user_data = get_user_by( 'email', '[email protected]' ) );
$key = get_password_reset_key( $user_data );
$user_login = $user_data->user_login;
$message = esc_url( get_permalink( '1' ) . "?action=rp&key=$key&login=" . rawurlencode($user_login) ) . "\r\n";
wp_mail( $user_email, "Title", $message );
?>
Es sendet einen Reset-Link mit $ key und $ login an meine Mail. Es ist okay.
Jetzt muss ich den Reset-Schlüssel überprüfen. Hier ist mein Code:
<?php
$errors = new WP_Error();
$user = check_password_reset_key($_GET['key'], $_GET['login']);
if ( is_wp_error( $user ) ) {
if ( $user->get_error_code() === 'expired_key' )
echo "Key is expired";
else
echo "Key is not valid";
}
?>
Aber es steht immer Schlüssel ist nicht gültig . Wo ist falsch
Ich habe es repariert. Wir müssen die URL mit esc_url_raw dekodieren. Hier ist die Lösung.
<?php
$user_data = get_user_by( 'email', '[email protected]' ) );
$key = get_password_reset_key( $user_data );
$user_login = $user_data->user_login;
$url = esc_url_raw( get_permalink( '1' ) . "?action=rp&key=$key&login=" . rawurlencode($user_login) ) . "\r\n";
$message = $url;
wp_mail( $user_email, "Title", $message );
?>