php中實(shí)現(xiàn)記住密碼自動登錄的代碼
更新時間:2011年03月02日 20:33:46 作者:
記得登錄QQ的時候,我們可以選記住密碼自動登錄,這個功能確實(shí)很方便、實(shí)用。其實(shí)在我們登錄網(wǎng)站后臺的時候,瀏覽器就會有提示是否記住登錄狀態(tài)。
php實(shí)現(xiàn)記住密碼自動登錄方法不止一個,下面出現(xiàn)有二個emptyempty,其實(shí)是一個,那是因?yàn)榇a高亮有bug。希望對大家有幫助。
一,用戶登錄的check
//檢查用戶是否登錄
function checklogin(){
if(emptyempty($_SESSION['user_info'])){ //檢查一下session是不是為空
if(emptyempty($_COOKIE['username']) || emptyempty($_COOKIE['password'])){ //如果session為空,并且用戶沒有選擇記錄登錄狀
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']); //轉(zhuǎn)到登錄頁面,記錄請求的url,登錄后跳轉(zhuǎn)過去,用戶體驗(yàn)好。
}else{ //用戶選擇了記住登錄狀態(tài)
$user = getUserInfo($_COOKIE['username'],$_COOKIE['password']); //去取用戶的個人資料
if(emptyempty($user)){ //用戶名密碼不對沒到取到信息,轉(zhuǎn)到登錄頁面
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']);
}else{
$_SESSION['user_info'] = $user; //用戶名和密碼對了,把用戶的個人資料放到session里面
}
}
}
}
//檢查用戶是否登錄
function checklogin(){
if(empty($_SESSION['user_info'])){ //檢查一下session是不是為空
if(empty($_COOKIE['username']) || empty($_COOKIE['password'])){ //如果session為空,并且用戶沒有選擇記錄登錄狀
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']); //轉(zhuǎn)到登錄頁面,記錄請求的url,登錄后跳轉(zhuǎn)過去,用戶體驗(yàn)好。
}else{ //用戶選擇了記住登錄狀態(tài)
$user = getUserInfo($_COOKIE['username'],$_COOKIE['password']); //去取用戶的個人資料
if(empty($user)){ //用戶名密碼不對沒到取到信息,轉(zhuǎn)到登錄頁面
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']);
}else{
$_SESSION['user_info'] = $user; //用戶名和密碼對了,把用戶的個人資料放到session里面
}
}
}
}
在訪問后臺的每個頁面時,都要先進(jìn)行上面的檢查
二,用戶提交登錄信息
當(dāng)用戶填寫用戶名和密碼后就提交到這兒來,
$username = trim($_POST['username']);
$password = md5(trim($_POST['password']));
$validatecode = $_POST['validateCode'];
$ref_url = $_GET['req_url'];
$remember = $_POST['remember'];
$err_msg = ”;
if($validatecode!=$_SESSION['checksum']){
$err_msg = “驗(yàn)證碼不正確”;
}elseif($username==” || $password==”){
$err_msg = “用戶名和密碼都不能為空”;
}else{
$row = getUserInfo($username,$password);
if(emptyempty($row)){
$err_msg = “用戶名和密碼都不正確”;
}else{
$_SESSION['user_info'] = $row;
if(!emptyempty($remember)){ //如果用戶選擇了,記錄登錄狀態(tài)就把用戶名和加了密的密碼放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}
$username = trim($_POST['username']);
$password = md5(trim($_POST['password']));
$validatecode = $_POST['validateCode'];
$ref_url = $_GET['req_url'];
$remember = $_POST['remember'];
$err_msg = ”;
if($validatecode!=$_SESSION['checksum']){
$err_msg = “驗(yàn)證碼不正確”;
}elseif($username==” || $password==”){
$err_msg = “用戶名和密碼都不能為空”;
}else{
$row = getUserInfo($username,$password);
if(empty($row)){
$err_msg = “用戶名和密碼都不正確”;
}else{
$_SESSION['user_info'] = $row;
if(!empty($remember)){ //如果用戶選擇了,記錄登錄狀態(tài)就把用戶名和加了密的密碼放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}
關(guān)于$ref_url簡單解釋一下,假如:用戶A訪問b.php,但是A用戶沒有登錄,跳轉(zhuǎn)到登錄頁面login.php,在登錄頁面填完用戶和密碼后,確定后又跳轉(zhuǎn)到b.php這個頁面,而不是跳轉(zhuǎn)一個默認(rèn)的頁面main_user.php。因?yàn)閎.php是用戶A想去的那個頁面,所以用戶體驗(yàn)會好一點(diǎn)。
三,當(dāng)用戶點(diǎn)退出時,清出記錄登錄狀態(tài)
為什么要這樣做呢,因?yàn)槿绻袆e人用你的電腦的話,他們有可能會瀏覽到你的個人隱私,所以當(dāng)用戶特意點(diǎn)了退出時,最好是把記錄登錄狀態(tài)取消掉。
//退出登錄
function logout(){
unset($_SESSION['user_info']);
if(!emptyempty($_COOKIE['username']) || emptyempty($_COOKIE['password'])){
setcookie(”username”, null, time()-3600*24*365);
setcookie(”password”, null, time()-3600*24*365);
}
}
一,用戶登錄的check
復(fù)制代碼 代碼如下:
//檢查用戶是否登錄
function checklogin(){
if(emptyempty($_SESSION['user_info'])){ //檢查一下session是不是為空
if(emptyempty($_COOKIE['username']) || emptyempty($_COOKIE['password'])){ //如果session為空,并且用戶沒有選擇記錄登錄狀
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']); //轉(zhuǎn)到登錄頁面,記錄請求的url,登錄后跳轉(zhuǎn)過去,用戶體驗(yàn)好。
}else{ //用戶選擇了記住登錄狀態(tài)
$user = getUserInfo($_COOKIE['username'],$_COOKIE['password']); //去取用戶的個人資料
if(emptyempty($user)){ //用戶名密碼不對沒到取到信息,轉(zhuǎn)到登錄頁面
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']);
}else{
$_SESSION['user_info'] = $user; //用戶名和密碼對了,把用戶的個人資料放到session里面
}
}
}
}
//檢查用戶是否登錄
function checklogin(){
if(empty($_SESSION['user_info'])){ //檢查一下session是不是為空
if(empty($_COOKIE['username']) || empty($_COOKIE['password'])){ //如果session為空,并且用戶沒有選擇記錄登錄狀
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']); //轉(zhuǎn)到登錄頁面,記錄請求的url,登錄后跳轉(zhuǎn)過去,用戶體驗(yàn)好。
}else{ //用戶選擇了記住登錄狀態(tài)
$user = getUserInfo($_COOKIE['username'],$_COOKIE['password']); //去取用戶的個人資料
if(empty($user)){ //用戶名密碼不對沒到取到信息,轉(zhuǎn)到登錄頁面
header(”location:login.php?req_url=”.$_SERVER['REQUEST_URI']);
}else{
$_SESSION['user_info'] = $user; //用戶名和密碼對了,把用戶的個人資料放到session里面
}
}
}
}
在訪問后臺的每個頁面時,都要先進(jìn)行上面的檢查
二,用戶提交登錄信息
當(dāng)用戶填寫用戶名和密碼后就提交到這兒來,
復(fù)制代碼 代碼如下:
$username = trim($_POST['username']);
$password = md5(trim($_POST['password']));
$validatecode = $_POST['validateCode'];
$ref_url = $_GET['req_url'];
$remember = $_POST['remember'];
$err_msg = ”;
if($validatecode!=$_SESSION['checksum']){
$err_msg = “驗(yàn)證碼不正確”;
}elseif($username==” || $password==”){
$err_msg = “用戶名和密碼都不能為空”;
}else{
$row = getUserInfo($username,$password);
if(emptyempty($row)){
$err_msg = “用戶名和密碼都不正確”;
}else{
$_SESSION['user_info'] = $row;
if(!emptyempty($remember)){ //如果用戶選擇了,記錄登錄狀態(tài)就把用戶名和加了密的密碼放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}
$username = trim($_POST['username']);
$password = md5(trim($_POST['password']));
$validatecode = $_POST['validateCode'];
$ref_url = $_GET['req_url'];
$remember = $_POST['remember'];
$err_msg = ”;
if($validatecode!=$_SESSION['checksum']){
$err_msg = “驗(yàn)證碼不正確”;
}elseif($username==” || $password==”){
$err_msg = “用戶名和密碼都不能為空”;
}else{
$row = getUserInfo($username,$password);
if(empty($row)){
$err_msg = “用戶名和密碼都不正確”;
}else{
$_SESSION['user_info'] = $row;
if(!empty($remember)){ //如果用戶選擇了,記錄登錄狀態(tài)就把用戶名和加了密的密碼放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}
關(guān)于$ref_url簡單解釋一下,假如:用戶A訪問b.php,但是A用戶沒有登錄,跳轉(zhuǎn)到登錄頁面login.php,在登錄頁面填完用戶和密碼后,確定后又跳轉(zhuǎn)到b.php這個頁面,而不是跳轉(zhuǎn)一個默認(rèn)的頁面main_user.php。因?yàn)閎.php是用戶A想去的那個頁面,所以用戶體驗(yàn)會好一點(diǎn)。
三,當(dāng)用戶點(diǎn)退出時,清出記錄登錄狀態(tài)
為什么要這樣做呢,因?yàn)槿绻袆e人用你的電腦的話,他們有可能會瀏覽到你的個人隱私,所以當(dāng)用戶特意點(diǎn)了退出時,最好是把記錄登錄狀態(tài)取消掉。
復(fù)制代碼 代碼如下:
//退出登錄
function logout(){
unset($_SESSION['user_info']);
if(!emptyempty($_COOKIE['username']) || emptyempty($_COOKIE['password'])){
setcookie(”username”, null, time()-3600*24*365);
setcookie(”password”, null, time()-3600*24*365);
}
}
您可能感興趣的文章:
- 利用php實(shí)現(xiàn)一周之內(nèi)自動登錄存儲機(jī)制(cookie、session、localStorage)
- php中實(shí)現(xiàn)記住密碼下次自動登錄的例子
- phpMyAdmin自動登錄和取消自動登錄的配置方法
- php利用cookie實(shí)現(xiàn)自動登錄的方法
- php版微信自動登錄并獲取昵稱的方法
- PHP登錄驗(yàn)證功能示例【用戶名、密碼、驗(yàn)證碼、數(shù)據(jù)庫、已登陸驗(yàn)證、自動登錄和注銷登錄等】
- PHP基于cookie與session統(tǒng)計網(wǎng)站訪問量并輸出顯示的方法
- php頁面跳轉(zhuǎn)session cookie丟失導(dǎo)致不能登錄等問題的解決方法
- PHP中cookie和session的區(qū)別實(shí)例分析
- PHP根據(jù)session與cookie用戶登錄狀態(tài)操作類的代碼
- php同時使用session和cookie來保存用戶登錄信息的實(shí)現(xiàn)代碼
- PHP cookie,session的使用與用戶自動登錄功能實(shí)現(xiàn)方法分析
相關(guān)文章
php實(shí)現(xiàn)判斷訪問來路是否為搜索引擎機(jī)器人的方法
這篇文章主要介紹了php實(shí)現(xiàn)判斷訪問來路是否為搜索引擎機(jī)器人的方法,主要通過過濾$_SERVER['HTTP_USER_AGENT'] 參數(shù)來實(shí)現(xiàn)這一功能,非常簡單實(shí)用,需要的朋友可以參考下2015-04-04
基于php中echo用逗號和用點(diǎn)號的區(qū)別詳解
下面小編就為大家分享一篇基于php中echo用逗號和用點(diǎn)號的區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
php mb_substr()函數(shù)截取中文字符串應(yīng)用示例
substr()函數(shù)用來截取字符串,但是對于中文字符會出現(xiàn)問題,而mb_substr()和mb_strcut這兩個函數(shù)可以,下面為大家介紹其具體用法2014-07-07
利用Dockerfile文件部署php項(xiàng)目的全過程
環(huán)境部署一直是一個很大的問題,無論是開發(fā)環(huán)境還是生產(chǎn)環(huán)境,但是Docker將開發(fā)環(huán)境和生產(chǎn)環(huán)境以輕量級方式打包,提供了一致的環(huán)境,下面這篇文章主要給大家介紹了關(guān)于利用Dockerfile文件部署php項(xiàng)目的相關(guān)資料,需要的朋友可以參考下2022-07-07
深入解析WordPress中加載模板的get_template_part函數(shù)
這篇文章主要介紹了WordPress中加載模板的get_template_part函數(shù),其中重點(diǎn)講解了其函數(shù)鉤子的使用,需要的朋友可以參考下2016-01-01

