Aggiungi un messaggio di errore nella pagina protetta da password


9

Ho protetto una pagina con password. Vorrei aggiungere un breve messaggio di errore quando la password inserita non è corretta.

Come posso fare questo?

Aggiungo questo codice per mostrare e personalizzare il modulo sulla mia pagina.

Mio functions.php

add_filter( 'the_password_form', 'custom_password_form' );
function custom_password_form() {
global $post;
$label = 'pwbox-'.( empty( $post->ID ) ? rand() : $post->ID );
$o = '<form class="protected-post-form" action="' . get_option('siteurl') . '/wp-pass.php" method="post">' . 
'<p class="glossar-form-p">Alle weiteren Glossarbeiträge sind durch ein Passwort geschützt. </p>' . 
' <label for="' . $label . '">' . ' </label><input name="post_password" id="' . $label . '" type="password" size="20" />
<input type="submit" name="Submit" value="' . esc_attr__( "Login" ) . '" />
</form>
';
return $o;
}

Risposte:


10

L'ultima password inserita viene memorizzata come hash sicuro in un cookie denominato 'wp-postpass_' . COOKIEHASH.

Quando viene chiamato il modulo della password, quel cookie è già stato convalidato da WordPress. Quindi devi solo controllare se quel cookie esiste : in caso affermativo e viene visualizzato il modulo password, la password era errata.

add_filter( 'the_password_form', 'wpse_71284_custom_post_password_msg' );

/**
 * Add a message to the password form.
 *
 * @wp-hook the_password_form
 * @param   string $form
 * @return  string
 */
function wpse_71284_custom_post_password_msg( $form )
{
    // No cookie, the user has not sent anything until now.
    if ( ! isset ( $_COOKIE[ 'wp-postpass_' . COOKIEHASH ] ) )
        return $form;

    // Translate and escape.
    $msg = esc_html__( 'Sorry, your password is wrong.', 'your_text_domain' );

    // We have a cookie, but it doesn’t match the password.
    $msg = "<p class='custom-password-message'>$msg</p>";

    return $msg . $form;
}

3
Un problema che ho riscontrato con questo approccio è che se inserisci la password errata il messaggio di errore persiste anche se ti allontani dalla pagina e poi ritorni, il modo più semplice che ho trovato in questo senso è mostrare solo il messaggio if(wp_get_referer() == get_permalink())
Javier Villanueva,

0

Forse è davvero molto tardi per rispondere. Qualcosa che devi fare come segue. Poiché non esiste un modo predefinito per la convalida, è necessario seguire alcuni passaggi. Qui userò la variabile di sessione per verificare la corrispondenza dei cookie generati. per prima cosa devi iniziare la sessione.

add_action('init', 'myStartSession', 1);
add_action('wp_logout', 'myEndSession');
add_action('wp_login', 'myEndSession');
function myStartSession() {
    if(!session_id()) {
        session_start();
    }
}
function myEndSession() {
    session_destroy ();
}

Quindi utilizzare il seguente codice in cui si desidera mostrare l'errore msg.

if ( post_password_required() ) {
       $session_id = 'wp-postpass_' . get_the_ID();
       //onload
       $current_cookie = wp_unslash($_COOKIE[ 'wp-postpass_' . COOKIEHASH ]);
       //get old cookie 
       $old_cookie = isset( $_SESSION[ $session_id ] ) ? $_SESSION[ $session_id ] : '';
       //set new session
       $_SESSION[ $session_id ] = $current_cookie;
       if ( $current_cookie != $old_cookie && !empty( $old_cookie ) ){
           error_notification('<b>Error!</b> Authentication failed!');
       }
   }

Questo è tutto!!

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.