Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
Design
/
fileman
/
Fusion
/
PROD
:
forgot_password_reset.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php // https://github.com/suresh-pokharel/forgot-password/blob/master/forgot_password_reset.php require("config_DB.php"); $valide = ""; // on verifie que le lien contient les bonnes infos if(isset($_GET['key']) && isset($_GET['email'])) { $key=$_GET['key']; $email=$_GET['email']; $check=mysqli_query($connexion,"SELECT * FROM appli_table_forget_password WHERE email='$email' and temp_key='$key'"); //if key doesnt matches if (mysqli_num_rows($check)!=1) { echo "This url is invalid or already been used. Please verify and try again."; exit; } } else { header('location:index.php'); } //if($_SERVER["REQUEST_METHOD"] == "POST") if (isset($_POST["submit"])) { echo "Bingo..."; // eecc9097dbcad14513b080b96177d21d <=> $Un92pac // $Azerty007 // traitement à faire $password = mysqli_real_escape_string( $connexion , $_POST['new_password']); $message_success="New password has been set for ".$email; echo $message_success ."<br><br>"; $password_crypted=md5($password); echo " -----> " .$password ." " .$password_crypted; //destroy the key from table mysqli_query( $connexion ,"DELETE FROM appli_table_forget_password where email='$email' and temp_key='$key'"); //update password in database mysqli_query( $connexion ,"UPDATE appli_table_users set password='$password_crypted' where email='$email'"); // pour afficher le message $valide = "ok"; } /* CREATE TABLE forget_password ( id int(11) NOT NULL AUTO_INCREMENT, email varchar(200) NOT NULL, temp_key varchar(200) NOT NULL, created timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=latin1; */ ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> <title>Bootstrap Sign in Form with Icons</title> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/css/bootstrap.min.css"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css"> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.3.0/font/bootstrap-icons.css" /> <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js"></script> <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/js/bootstrap.min.js"></script> <style> .error{ display: none; margin-left: 10px; } .text-danger{ display: none; margin-left: 10px; } .error_show{ color: red; margin-left: 10px; } .help-block { display: none; } .form-group.has-error .help-block { display: block; } </style> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script> <script> $(document).ready(function() { const togglePassword = document.querySelector("#togglePassword"); const password = document.querySelector("#new_password"); togglePassword.addEventListener("click", function () { // toggle the type attribute const type = password.getAttribute("type") === "password" ? "text" : "password"; password.setAttribute("type", type); // toggle the eye icon this.classList.toggle('fa-eye'); this.classList.toggle('fa-eye-slash'); }); }); </script> <style> .login-form { width: 500px; margin: 50px auto; } .login-form form { margin-bottom: 15px; background: #f7f7f7; box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.3); padding: 30px; } .login-form h2 { margin: 0 0 15px; } .form-control, .btn { min-height: 38px; border-radius: 2px; } .input-group-addon .fa { font-size: 18px; } .btn { font-size: 15px; font-weight: bold; } .bottom-action { font-size: 14px; } .space { margin:0; padding:0; height:20px; } .erreur_utilisateur { display: none; color: red; } .erreur_password { display: none; color: red; } </style> </head> <body> <div class="login-form"> <form id="login_form" action="" method="post"> <header class="login--header login-1--header text-center"> <span class="fa fa-key" style='font-size:48px' ></span> <h3>Définir le nouveau mot de passe</h3> <span class="arrow-down login--header__arrow"></span> </header> <br> <br> <div class="form-group"> <label for="password" class="form-label">Mot de passe</label> <div class="input-group"> <div class="input-group-prepend"> <span class="input-group-text"> <i class="fa fa-lock"></i> </span> </div> <input type="password" class="form-control" name="new_password" id="new_password" placeholder="Mot de passe" autocomplete="nada" > <span class="input-group-text"> <i class="fa fa-eye" id="togglePassword" style="cursor: pointer"></i> </span> <p class="erreur_password"></p> <div class="row"> <div class="col-sm-6"> <div class="space"></div> <span id="8char" class="fa fa-times" style="color:#FF0004;"></span> 8 Charactéres mini<br></span> <span id="ucase" class="fa fa-times" style="color:#FF0004;"></span> Une majuscule mini<br></span> </div> <div class="col-sm-6"> <div class="space"></div> <span id="lcase" class="fa fa-times" style="color:#FF0004;"></span> Une lettre miniscule mini<br> <span id="num" class="fa fa-times" style="color:#FF0004;"></span> Au moins un chiffre </div> <div class="col-sm-6"> <span id="special" class="fa fa-times" style="color:#FF0004;"></span> Un caractére spécial mini </div> </div> </div> </div> <div class="form-group"> <label for="password" class="form-label">Confimer le mot de passe</label> <div class="input-group"> <div class="input-group-prepend"> <span class="input-group-text"> <i class="fa fa-lock"></i> </span> </div> <input type="password" class="form-control" title = "plouf" onpaste="return false" id = "confirm_password" name = "confirm_password" placeholder="Mot de passe" autocomplete="nada" > </div> <div class="space"></div> <span id="pwmatch" class="fa fa-times" style="color:#FF0004;"></span> Passwords Match <p class="erreur_confirme_password"></p> </div> <div class="form-group"> <div class='actions'> <input type="submit" id = "submit" name = "submit" value="Valider" disabled class="btn btn-primary btn-block" /> </div> </div> <?php if($valide == "ok") { ?> <div class="alert alert-success" role="alert"> Votre mot de passe vient d'être mise à jour dans la database. </div> <?php } ?> <!-- <div class="bottom-action clearfix"> <a href="#" class="float-center">Mot de passe oublié ?</a> </div> --> </form> <p class="text-center small"><a href="#">Retour ...</a>.</p> <br> <br> </div> <script> $("input[type=password]").keyup(function() { var ucase = new RegExp(/[A-Z]/); var lcase = new RegExp(/[a-z]/); var num = new RegExp(/[0-9]/); var special = new RegExp(/[^a-zA-Z0-9\-\/]/); if($("#new_password").val().length >= 8){ $("#8char").removeClass("fa fa-times"); $("#8char").addClass("fa fa-check"); $("#8char").css("color","#00A41E"); }else{ $("#8char").removeClass("fa fa-check"); $("#8char").addClass("fa fa-times"); $("#8char").css("color","#FF0004"); } /****/ if(ucase.test($("#new_password").val())){ $("#ucase").removeClass("fa fa-times"); $("#ucase").addClass("fa fa-check"); $("#ucase").css("color","#00A41E"); }else{ $("#ucase").removeClass("fa fa-check"); $("#ucase").addClass("fa fa-times"); $("#ucase").css("color","#FF0004"); } /****/ if(lcase.test($("#new_password").val())){ $("#lcase").removeClass("fa fa-times"); $("#lcase").addClass("fa fa-check"); $("#lcase").css("color","#00A41E"); }else{ $("#lcase").removeClass("fa fa-check"); $("#lcase").addClass("fa fa-times"); $("#lcase").css("color","#FF0004"); } /****/ if(num.test($("#new_password").val())){ $("#num").removeClass("fa fa-times"); $("#num").addClass("fa fa-check"); $("#num").css("color","#00A41E"); }else{ $("#num").removeClass("fa fa-check"); $("#num").addClass("fa fa-times"); $("#num").css("color","#FF0004"); } /****/ if(special.test($("#new_password").val())){ $("#special").removeClass("fa fa-times"); $("#special").addClass("fa fa-check"); $("#special").css("color","#00A41E"); }else{ $("#special").removeClass("fa fa-check"); $("#special").addClass("fa fa-times"); $("#special").css("color","#FF0004"); } /***/ if( $("#new_password").val() != "" && $("#confirm_password").val() != "" ) { if($("#new_password").val() == $("#confirm_password").val()) { $("#pwmatch").removeClass("fa fa-times"); $("#pwmatch").addClass("fa fa-check"); $("#pwmatch").css("color","#00A41E"); // Enable #x $( "#submit" ).prop( "disabled", false ); console.log("TRACE"); } else { $("#pwmatch").removeClass("fa fa-check"); $("#pwmatch").addClass("fa fa-times"); $("#pwmatch").css("color","#FF0004"); $( "#submit" ).prop( "disabled", true ); } } }); </script> </body> </html>