Maison >développement back-end >Problème PHP >Comment implémenter la fonction de récupération d'un mot de passe oublié en php

Comment implémenter la fonction de récupération d'un mot de passe oublié en php

藏色散人
藏色散人original
2020-11-24 10:07:503642parcourir

PHP implémente la méthode fonctionnelle d'oubli du mot de passe : entrez d'abord l'adresse e-mail lors de l'inscription via le formulaire ; puis vérifiez si l'adresse e-mail de l'utilisateur est correcte, puis vérifiez la chaîne d'informations utilisateur, construisez une URL et envoyez ; à l'adresse e-mail de l'utilisateur ; enfin, implémentez l'utilisateur Connectez-vous à votre boîte aux lettres pour recevoir des e-mails et accédez à la page de réinitialisation du mot de passe pour réinitialiser un nouveau mot de passe.

Comment implémenter la fonction de récupération d'un mot de passe oublié en php

Recommandé : "Tutoriel vidéo PHP"

L'environnement d'exploitation de ce tutoriel : système Windows 7, version PHP 5.6, Cette méthode fonctionne pour toutes les marques d'ordinateurs.

PHP+Mysql+jQuery implémente une fonction de récupération de mot de passe

Bien entendu, certains sites Web proposent désormais également une récupération de mot de passe via des SMS sur téléphone portable. Le principe est d'envoyer un message. code de vérification. Pour vérifier votre identité, tout comme pour envoyer un e-mail de vérification, vous devez toujours réinitialiser votre mot de passe pour terminer le processus de récupération de votre mot de passe.

Cet article utilisera PHP+Mysql+jQuery pour implémenter une fonction de récupération de mot de passe. Les étapes générales sont :

1. Saisissez l'adresse e-mail lors de l'inscription dans le formulaire ; >2. Vérifiez que l'e-mail de l'utilisateur est correct. Si l'e-mail de l'utilisateur n'existe pas dans la table des utilisateurs du site Web, il vous sera demandé que l'e-mail de l'utilisateur n'est pas enregistré

3. l'e-mail de l'utilisateur existe dans la table utilisateur, la combinaison est utilisée pour vérifier la chaîne d'informations de l'utilisateur et construit une URL à envoyer à la boîte aux lettres de l'utilisateur

4. recevoir le courrier et cliquer sur le lien URL vers le programme de vérification du site Web ;

5. Le programme du site Web transmet la demande de l'utilisateur. La chaîne interroge la table des utilisateurs locaux et compare si les informations de l'utilisateur sont correctes ; 🎜> 6. S'il est correct, accédez à la page de réinitialisation du mot de passe pour réinitialiser un nouveau mot de passe, sinon cela indiquera à l'utilisateur que la vérification n'est pas valide.

HTML

Nous plaçons une page sur la page de récupération du mot de passe qui demande à l'utilisateur de saisir l'adresse e-mail utilisée pour l'inscription, puis de soumettre le js frontal pour gérer l'interaction.

<p><strong>输入您注册的电子邮箱,找回密码:</strong></p>
<p><input type="text" class="input" name="email" id="email"><span id="chkmsg"></span></p>
<p><input type="button" class="btn" id="sub_btn" value="提 交"></p>

jQuery

Une fois que l'utilisateur a saisi son adresse e-mail et cliqué sur Soumettre, jQuery vérifie d'abord si le format de l'e-mail est correct. S'il est correct, il envoie une requête Ajax au sendmail en arrière-plan. php, qui est responsable de la vérification. Vérifiez si la boîte aux lettres existe et envoyez l'e-mail, et renverra les résultats du traitement correspondant à la page d'accueil. Veuillez consulter le code jQuery :

$(function(){
$("#sub_btn").click(function(){
var email = $("#email").val();
var preg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/; //匹配Email
if(email==&#39;&#39; || !preg.test(email)){
$("#chkmsg").html("请填写正确的邮箱!");
}else{
$("#sub_btn").attr("disabled","disabled").val(&#39;提交中..&#39;).css("cursor","default");
$.post("sendmail.php",{mail:email},function(msg){
if(msg=="noreg"){
$("#chkmsg").html("该邮箱尚未注册!");
$("#sub_btn").removeAttr("disabled").val(&#39;提 交&#39;).css("cursor","pointer");
}else{
$(".demo").html("<h3>"+msg+"</h3>");
}
});
}
});
})

Le code jQuery utilisé ci-dessus est très. pratique et concis pour terminer l'opération interactive frontale. Si vous avez certaines compétences de base en jQuery, le code ci-dessus est clair en un coup d'œil, aucune explication n'est requise.

Bien sûr, n'oubliez pas de charger le fichier de la bibliothèque jQuery sur la page. Certains étudiants me demandent souvent pourquoi ils ne peuvent pas utiliser la démo téléchargée sur helloweba.net, c'est à cause de 80% du temps. Le chemin de chargement de jquery ou d’autres fichiers est incorrect. Chargez les fichiers nécessaires.

PHP

sendmail.php doit vérifier si l'e-mail existe dans la table des utilisateurs du système. Si tel est le cas, lisez les informations de l'utilisateur, utilisez le cryptage md5 pour générer un caractère spécial pour l'identifiant de l'utilisateur, nom d'utilisateur et mot de passe. La chaîne est utilisée comme code de vérification pour récupérer le mot de passe, puis l'URL est construite. Dans le même temps, afin de contrôler l'actualité du lien URL, nous enregistrerons l'heure de l'opération lorsque l'utilisateur soumet l'action de récupération du mot de passe, et enfin appellerons la classe d'envoi d'e-mail pour envoyer l'e-mail à la boîte aux lettres de l'utilisateur. la classe smtp.class.php a été empaquetée, veuillez la télécharger.

include_once("connect.php");//连接数据库
$email = stripslashes(trim($_POST[&#39;mail&#39;]));
$sql = "select id,username,password from `t_user` where `email`=&#39;$email&#39;";
$query = mysql_query($sql);
$num = mysql_num_rows($query);
if($num==0){//该邮箱尚未注册!
echo &#39;noreg&#39;;
exit;
}else{
$row = mysql_fetch_array($query);
$getpasstime = time();
$uid = $row[&#39;id&#39;];
$token = md5($uid.$row[&#39;username&#39;].$row[&#39;password&#39;]);//组合验证码
$url = "http://www.helloweba.net/demo/resetpass/reset.php?email=".$email."
&token=".$token;//构造URL
$time = date(&#39;Y-m-d H:i&#39;);
$result = sendmail($time,$email,$url);
if($result==1){//邮件发送成功
$msg = &#39;系统已向您的邮箱发送了一封邮件<br/>请登录到您的邮箱及时重置您的密码!&#39;;
//更新数据发送时间
mysql_query("update `t_user` set `getpasstime`=&#39;$getpasstime&#39; where id=&#39;$uid &#39;");
}else{
$msg = $result;
}
echo $msg;
}
//发送邮件
function sendmail($time,$email,$url){
include_once("smtp.class.php");
$smtpserver = ""; //SMTP服务器,如smtp.163.com
    $smtpserverport = 25; //SMTP服务器端口
    $smtpusermail = ""; //SMTP服务器的用户邮箱
    $smtpuser = ""; //SMTP服务器的用户帐号
    $smtppass = ""; //SMTP服务器的用户密码
    $smtp = new Smtp($smtpserver, $smtpserverport, true, $smtpuser, $smtppass); 
    //这里面的一个true是表示使用身份验证,否则不使用身份验证.
    $emailtype = "HTML"; //信件类型,文本:text;网页:HTML
    $smtpemailto = $email;
    $smtpemailfrom = $smtpusermail;
    $emailsubject = "Helloweba.com - 找回密码";
    $emailbody = "亲爱的".$email.":<br/>您在".$time."提交了找回密码请求。请点击下面的链接重置密码
(按钮24小时内有效)。<br/><a href=&#39;".$url."&#39;target=&#39;_blank&#39;>".$url."</a>";
    $rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype);
return $rs;
}

D'accord, à ce moment-là, vous recevrez un e-mail de récupération de mot de passe de helloweba.net pour vérifier Mail. .

include_once("connect.php");//连接数据库
$token = stripslashes(trim($_GET[&#39;token&#39;]));
$email = stripslashes(trim($_GET[&#39;email&#39;]));
$sql = "select * from `t_user` where email=&#39;$email&#39;";
$query = mysql_query($sql);
$row = mysql_fetch_array($query);
if($row){
$mt = md5($row[&#39;id&#39;].$row[&#39;username&#39;].$row[&#39;password&#39;]);
if($mt==$token){
if(time()-$row[&#39;getpasstime&#39;]>24*60*60){
$msg = &#39;该链接已过期!&#39;;
}else{
//重置密码...
$msg = &#39;请重新设置密码,显示重置密码表单,<br/>这里只是演示,略过。&#39;;
}
}else{
$msg =  &#39;无效的链接&#39;;
}
}else{
$msg =  &#39;错误的链接!&#39;;
}
echo $msg;

reset.php accepte d'abord les paramètres email et token, puis vérifie si l'e-mail existe dans la table de données t_user en fonction de l'e-mail. S'il existe, les informations de l'utilisateur sont obtenues, ainsi que la méthode de combinaison de jetons. dans sendmail.php est le même. Construisez la valeur du jeton, puis comparez-la avec le jeton transmis par l'URL. Si la différence entre l'heure actuelle et l'heure à laquelle l'e-mail est envoyé est supérieure à 24 heures, le message " Le lien a expiré!". Sinon, cela signifie que le lien est valide et qu'il sera redirigé. Page de définition du mot de passe, et enfin l'utilisateur définit lui-même un nouveau mot de passe.

Résumé : Grâce à la vérification des e-mails enregistrés et à la récupération du mot de passe par e-mail dans cet article, nous connaissons l'application de l'envoi d'e-mails dans le développement de sites Web et son importance. Bien sûr, les applications de vérification par SMS sont également populaires désormais, qui nécessitent des SMS associés. interfaces Connectez-vous simplement.

Enfin, attachez la structure t_user de la table de données :

CREATE TABLE `t_user` (
  `id` int(11) NOT NULL auto_increment,
  `username` varchar(30) NOT NULL,
  `password` varchar(32) NOT NULL,
  `email` varchar(50) NOT NULL,
  `getpasstime` int(10) NOT NULL,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8;

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn