Cum să permiti utilizatorului să-și seteze parola la înregistrare

9 sept. 2012, 03:43:27
Vizualizări: 14.7K
Voturi: 5

Lucrez la un formular de înregistrare în front-end și am reușit să fac să funcționeze formularul standard de înregistrare, dar... aș dori să adaug posibilitatea ca utilizatorul să-și aleagă propria parolă.

Sunt începător în acest domeniu și aș aprecia orice ajutor. :)

Iată codul meu până acum:

<?php if(!is_user_logged_in()) { ?>


<?php
if(get_option('users_can_register')) {
//Verifică dacă înregistrarea utilizatorilor este activată de administrator
?>

<?php

if($_POST){
    //Escapăm toate input-urile pentru SQL
    $username = $wpdb->escape($_REQUEST['username']);
    if(empty($username)) {
        echo "<span style='color:#FF0000'><strong>Eroare..</strong></span><br /><br />Trebuie să completezi numele de utilizator.";
        exit();
    }
    $email = $wpdb->escape($_REQUEST['email']);
    if(!preg_match("/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,4})$/", $email)) {
        echo "<span style='color:#FF0000'><strong>Eroare..</strong></span><br /><br />Te rugăm să folosești o adresă de e-mail validă.";
        exit();
    }

    $random_password = wp_generate_password( 12, false );
    $status = wp_create_user( $username, $random_password, $email );
    if ( is_wp_error($status) )
        echo "<span style='color:#FF0000'><strong>Eroare..</strong></span><br /><br />Numele de utilizator există deja. Te rugăm să încerci altul.";
    else {
        $from = get_option('admin_email');
        $headers = 'From: '.$from . "\r\n";
        $subject = "Înregistrare reușită!";
        $msg = "Bine ai venit, acum ești înregistrat. Iată datele tale de autentificare.\nInformații:\nNume utilizator: $username\nParolă: $random_password";
        wp_mail( $email, $subject, $msg, $headers );
        echo "<strong>Ești acum înregistrat. Un e-mail cu numele tău de utilizator și parolă a fost trimis.";
    }

    exit();

}
 else
{
//Încorporăm formularul de înregistrare și javascript aici

?>


<div id="result"></div>
<div style="padding-top:5px; padding-bottom:10px;">Completează informațiile tale pentru înregistrare.</div>

<form id="wp_signup_form" action="" method="post">
<input type="text" name="username" style="width:250px; margin-bottom:3px;" placeholder="Nume utilizator"><br />
<input type="text" name="email" placeholder="E-mail" style="width:250px; margin-bottom:3px;"><br />
<input type="submit" id="submitbtn" name="submit" value="Înregistrare" class="knapp" style="padding:8px;">
</form>
<script type="text/javascript">                         
$("#submitbtn").click(function() {
$('#result').html('<img src="<?php bloginfo('template_url'); ?>/images/loader.gif" class="loader" />').fadeIn();
var input_data = $('#wp_signup_form').serialize();
$.ajax({
type: "POST",
url:  "<?php echo "http://" . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; ?>",
data: input_data,
success: function(msg){
$('.loader').remove();
$('
<div>').html(msg).appendTo('div#result').hide().fadeIn('slow');
}
});
return false;

});
</script>
<?php
// încorporat

}
?>

<?php
    }

else 
?>

<!-- sfârșit formular înregistrare -->
<br />
Deja înregistrat? Autentifică-te în contul tău folosind formularul din bara laterală.
<?php } else { ?>
Ești deja autentificat...
<?php } ?>
0
Toate răspunsurile la întrebare 2
4
11

Nu este atât de greu pe cât crezi :)

Adaugă câmpurile pentru parolă în formularul tău:

password: <input type="password" name="pass1" style="width:250px; margin-bottom:3px;"><br />
repeat password: <input type="password" name="pass2" style="width:250px; margin-bottom:3px;"><br />

apoi în secțiunea if($_POST){ înlocuiește această linie:

$random_password = wp_generate_password( 12, false );

cu aceasta:

$pass1 = $wpdb->escape($_REQUEST['pass1']);
$pass2 = $wpdb->escape($_REQUEST['pass2']);
if ($pass1 != $pass2){
    echo "<span style='color:#FF0000'><strong>Eroare..</strong></span><br /><br />Parolele introduse nu coincid.";
        exit();

}
$random_password = $pass1;
9 sept. 2012 11:34:18
Comentarii

funcționează perfect!

Demilio Demilio
9 sept. 2012 15:14:49

Și la mine a funcționat, deci +1.

Ciprian Ciprian
10 mar. 2013 14:02:18

Care este acest fișier?

Mugen Mugen
26 iul. 2020 13:07:21

De asemenea, ai vreo idee dacă aceste modificări ar fi pierdute odată ce actualizăm WordPress?

Mugen Mugen
26 iul. 2020 13:13:16
0

Rețineți că puteți utiliza funcția internă WordPress pentru a verifica câmpul de email. verificați acest link is_email

$email = $wpdb->escape($_REQUEST['email']);
if( !is_email($email) ) {
    echo "<span style='color:#FF0000'><strong>Eroare..</strong></span><br /><br />vă rugăm să folosiți o adresă de email validă.";
    exit();
}

Postat ca răspuns din cauza reputației reduse.

9 nov. 2015 12:28:16