wp_signon () não autentica a orientação do usuário necessária

4

Eu uso o formulário para enviar uma solicitação POST para uma página e para fazer login do usuário com wp_signon() para autenticar o usuário na instalação do meu wordpress, conforme descrito na documentação do WP:

$creds = array();
$creds['user_login'] = $_POST["user-login"];
$creds['user_password'] = $_POST["user-password"];
$creds['remember'] = true;

$user = wp_signon( $creds, false );

Depois desse pequeno código, estou verificando se o usuário estava logado:

if ( is_user_logged_in() ) { echo "SUCCESS"; } else { echo "FAIL!"; }

Mas eu tenho FAIL! o tempo todo. Então, depois de farejar, encontrei este pequeno truque:

wp_set_current_user( $user );
if ( is_user_logged_in() ) { echo "SUCCESS"; } else { echo "FAIL!"; }

Eu tenho SUCCESS neste, mas quando deixo esta página, tenho FAIL de novo e de novo.

Alguém pode me explicar como fazer o login do usuário com wp_signon() sem desconectá-la depois que a página for alterada ou recarregada ou o que for.

Eu tenho um resultado desejável quando vou para /wp_admin e faço login com o formulário de login padrão do WP. Eu posso navegar por todas as páginas do meu site WP permanecendo logado o tempo todo. Mas quando tento fazer isso fora do formulário padrão, eu FAIL .

Me guie! POR FAVOR!

    
por LoomyBear 24.09.2013 / 19:40

1 resposta

4

finalmente, isso está funcionando para mim na instalação do WP local depois de substituir - com _ do nome do atributo de entrada e usando tags de início completo do php <?php em vez de <? o código final está aqui copie e cole no seu modelo. / p>

<?php if ( isset($_POST["user_email"]) && isset($_POST["user_password"]) ) {

$user_login     = esc_attr($_POST["user_email"]);
$user_password  = esc_attr($_POST["user_password"]);
$user_email     = esc_attr($_POST["user_email"]);

$user_data = array(
    'user_login'    =>      $user_login,
    'user_pass'     =>      $user_password,
    'user_email'    =>      $user_email,
    'role'          =>      'student'
);

// Inserting new user to the db
//wp_insert_user( $user_data );

$creds = array();
$creds['user_login'] = $user_login;
$creds['user_password'] = $user_password;
$creds['remember'] = true;

$user = wp_signon( $creds, false );

$userID = $user->ID;

wp_set_current_user( $userID, $user_login );
wp_set_auth_cookie( $userID, true, false );
do_action( 'wp_login', $user_login );

}

if ( is_user_logged_in() ) : echo 'SUCCESS'; ?>
<h1>Html for logged in user </h1>
<?php else : echo 'FAIL!'; ?>
<form id="user-credentials" method="post" action="<?php the_permalink(); ?>">
    <p><input name="user_email" type="text" placeholder="Email" /></p>
    <p><input name="user_password" type="password" placeholder="Password" /></p>
    <p><input type="submit" class="button blue size-s" value="Submit" /></p>
</form>
<?php endif; ?>
    
por Anjum 24.09.2013 / 21:52

Tags