麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 網站 > 建站經驗 > 正文

PHP結合jQuery實現找回密碼

2024-04-25 20:39:46
字體:
來源:轉載
供稿:網友

通常所說的密碼找回功能不是真的能把忘記的密碼找回,因為我們的密碼是加密保存的,一般開發者會在驗證用戶信息后通過程序生成一個新密碼或者生成一個特定的鏈接并發送郵件到用戶郵箱,用戶從郵箱鏈接到網站的重置密碼模塊重新設置新密碼。

當然現在有的網站也有手機短信的方式找回密碼,原理就是通過發送驗證碼來驗明正身,和發送郵件驗證一樣,最終還是要通過重置密碼來完成找回密碼的流程。

一般步驟是:

1.表單輸入注冊時的郵箱;

2.驗證用戶郵箱是否正確,如果用戶郵箱不存在網站的用戶表中,則提示用戶郵箱未注冊;

3.發送郵件,如果用戶郵箱確實存在用戶表中,則組合用于驗證用戶信息的字符串,并構造URL發送到用戶郵箱中;

4.用戶登錄郵箱收取郵件,點擊URL鏈接到網站驗證程序;

5.網站程序通過用戶請求的字符串查詢本地用戶表,比對用戶信息是否正確;

6.如果正確則轉到重置密碼頁面重新設置新密碼,反之則提示用戶驗證無效。

HTML

我們在找回密碼的頁面上放置一個要求用戶輸入注冊時所用的郵箱,然后提交前臺js來處理交互。

<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

當用戶輸入完郵箱并點擊提交后,jQuery先驗證郵箱格式是否正確,如果正確則通過向后臺sendmail.php發送Ajax請求,sendmail.php負責驗證郵箱是否存在和發送郵件,并會返回相應的處理結果給前臺頁面,請看jQuery代碼:

$(function(){

$("#sub_btn").click(function(){

var email = $("#email").val();

var preg = /^/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*/; //匹配Email

if(email=='' || !preg.test(email)){

$("#chkmsg").html("請填寫正確的郵箱!");

}else{

$("#sub_btn").attr("disabled","disabled").val('提交中..').css("cursor","default");

$.post("sendmail.php",{mail:email},function(msg){

if(msg=="noreg"){

$("#chkmsg").html("該郵箱尚未注冊!");

$("#sub_btn").removeAttr("disabled").val('提 交').css("cursor","pointer");

}else{

$(".demo").html("<h3>"+msg+"</h3>");

}

});

}

});

})

以上使用的jQuery代碼很方便簡潔的完成了前端交互操作,如果您有一定的jQuery基礎,那上面的代碼一目了然,不多解釋。

當然別忘了在頁面中加載jQuery庫文件,有的同學經常問我說從jb51.net下載了demo怎么用不了,那80%是jquery或者其他文件加載路徑錯了導致沒加載必要的文件。

PHP

sendmail.php需要驗證Email是否存在系統用戶表中,如果有,則讀取用戶信息,將用戶id、用戶名和密碼驚醒md5加密生成一個特別的字符串作為找回密碼的驗證碼,然后構造URL。同時我們為了控制URL鏈接的時效性,將記錄用戶提交找回密碼動作的操作時間,最后調用郵件發送類發送郵件到用戶郵箱,發送郵件類smtp.class.php已經打包好,請下載。

include_once("connect.php");//連接數據庫

$email = stripslashes(trim($_POST['mail']));

$sql = "select id,username,password from `t_user` where `email`='$email'";

$query = mysql_query($sql);

$num = mysql_num_rows($query);

if($num==0){//該郵箱尚未注冊!

echo 'noreg';

exit;

}else{

$row = mysql_fetch_array($query);

$getpasstime = time();

$uid = $row['id'];

$token = md5($uid.$row['username'].$row['password']);//組合驗證碼

$url = "http://www.jb51.net/demo/resetpass/reset.php?email=".$email."

&token=".$token;//構造URL

$time = date('Y-m-d H:i');

$result = sendmail($time,$email,$url);

if($result==1){//郵件發送成功

$msg = '系統已向您的郵箱發送了一封郵件<br/>請登錄到您的郵箱及時重置您的密碼!';

//更新數據發送時間

mysql_query("update `t_user` set `getpasstime`='$getpasstime' where id='$uid '");

}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 = "jb51.net - 找回密碼";

$emailbody = "親愛的".$email.":<br/>您在".$time."提交了找回密碼請求。請點擊下面的鏈接重置密碼

(按鈕24小時內有效)。<br/><a href='".$url."'target='_blank'>".$url."</a>";

$rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype);

return $rs;

}

好了,這個時候你的郵箱將會收到一封來自helloweba的密碼找回郵件,郵件內容中有一個URL鏈接,點擊該鏈接到jb51.net的reset.php來驗證郵箱。

include_once("connect.php");//連接數據庫

$token = stripslashes(trim($_GET['token']));

$email = stripslashes(trim($_GET['email']));

$sql = "select * from `t_user` where email='$email'";

$query = mysql_query($sql);

$row = mysql_fetch_array($query);

if($row){

$mt = md5($row['id'].$row['username'].$row['password']);

if($mt==$token){

if(time()-$row['getpasstime']>24*60*60){

$msg = '該鏈接已過期!';

}else{

//重置密碼...

$msg = '請重新設置密碼,顯示重置密碼表單,<br/>這里只是演示,略過。';

}

}else{

$msg = '無效的鏈接';

}

}else{

$msg = '錯誤的鏈接!';

}

echo $msg;

reset.php首先接受參數email和token,然后根據email查詢數據表t_user中是否存在該Email,如果存在則獲取該用戶的信息,并且和sendmail.php中的token組合方式一樣構建token值,然后與url傳過來的token進行對比,如果當前時間與發送郵件時的時間相差超過24小時的,則提示“該鏈接已過期!”,反之,則說明鏈接有效,并且調轉到重置密碼頁面,最后就是用戶自己設置新密碼了。

小結:通過注冊郵箱驗證與本文郵件找回密碼,我們知道發送郵件在網站開發中的應用以及它的重要性,當然,現在也流行短信驗證應用,這個需要相關的短信接口對接就可以了。

最后,附上數據表t_user結構:

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;

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 免费午夜网站 | 国产精品一区在线看 | 国产一级毛片国语版 | 亚州综合 | 青青草成人免费视频在线 | 国产影院在线观看 | 亚洲网在线观看 | 色淫视频 | 斗破苍穹在线免费 | 国产成人精品自拍视频 | 久国久产久精永久网页 | 中国hdxxxx护士爽在线观看 | 国产超碰人人做人人爱ⅴa 国产精品久久久久久久hd | 91美女视频在线观看 | 奶子吧naiziba.cc免费午夜片在线观看 | 久久国产一二三 | 欧美不卡 | 视频一区二区三区免费观看 | 亚洲视频成人 | 国产麻豆交换夫妇 | 美女视频黄a视频免费全过程 | 久久96国产精品久久久 | 男女无遮挡羞羞视频 | 欧美精品一区二区三区在线播放 | 九一传媒在线观看 | 亚洲精品欧美在线 | 久久久入口 | 一级一级一级一级毛片 | 激情综合网俺也去 | 九色在线78m | 91久久在线观看 | 日本在线播放一区二区三区 | 毛片在线免费视频 | 91成人天堂久久成人 | 男女羞羞视频在线观看免费 | 国产1区在线观看 | 国产一国产一级毛片视频 | 国产成人在线观看网站 | 国产91久久精品一区二区 | 人与xxxxhdxxxhdxx 日韩黄a | 国产精品99久久99久久久二 |