it-swarm.com.de

Überprüfen Sie, ob der Schlüssel zum Zurücksetzen des Kennworts nicht funktioniert

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

1
bilimokur

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 );
?>
2
bilimokur