好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識(shí)庫 > php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法分析【當(dāng)其它地方登陸時(shí),當(dāng)前賬號(hào)失效】

php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法分析【當(dāng)其它地方登陸時(shí),當(dāng)前賬號(hào)失效】

熱門標(biāo)簽:咸陽電銷 嘟嘟云外呼系統(tǒng) 邢臺(tái)400電話辦理 南京3D地圖標(biāo)注 辦理400電話哪家好點(diǎn) 南寧電話外呼系統(tǒng)線路 濟(jì)源百應(yīng)電銷機(jī)器人聯(lián)系方式 重慶外呼電銷系統(tǒng)多少錢 正規(guī)電銷機(jī)器人系統(tǒng)

本文實(shí)例講述了php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法。分享給大家供大家參考,具體如下:

解決的思路是每當(dāng)用戶登陸時(shí)我們必需記錄當(dāng)前的用戶id和session_id,如果有人在其它地方用此賬號(hào)登陸時(shí),我們把此用戶id對(duì)應(yīng)的session_id的session文件刪除,并重新記錄當(dāng)前的session_id。那么之前的用戶就失效了。

login.php代碼如下:

?php
session_start();
 
require 'db.php';
 
if(!empty($_POST['submit'])) {
  $uname = !empty($_POST['uname']) ? trim($_POST['uname']) : '';
  $upwd = !empty($_POST['upwd']) ? trim($_POST['upwd']) : '';
 
  //這里只是演示,實(shí)際情況是在數(shù)據(jù)庫里查詢并判斷
  if($uname == 'test'  $upwd == 'test') {
    //這里假設(shè)test用戶id為1
    $uid = 1;
    $session_id = session_id();
     
    //判斷是否已有用戶登陸過
    $res = mysql_query("SELECT session_id FROM tb_login_state WHERE uid={$uid}");
    $data = mysql_fetch_assoc($res);
    if(!empty($data)) {
      $sessionId = $data['session_id'];
      $sessionFilePath = session_save_path() . DIRECTORY_SEPARATOR . 'sess_' . $sessionId;
 
      //刪除上次用戶登陸的session文件
      if(file_exists($sessionFilePath)  is_writable($sessionFilePath)) {
        @unlink($sessionFilePath);
      }
      //刪除用戶登陸信息
      mysql_query("DELETE FROM tb_login_state WHERE uid={$uid}");
    }
    //添加新的用戶登陸信息
    mysql_query("INSERT INTO tb_login_state VALUES({$uid}, '{$session_id}')");
 
    $_SESSION['userInfo'] = array(
      'name' => $uname
    );
    echo 'script type="text/javascript">alert("您已成功登陸,跳轉(zhuǎn)首頁");/script>';
    echo 'script type="text/javascript">location.href="index.php" rel="external nofollow" ;/script>';
  }
}
?>
!DOCTYPE HTML>
html lang="zh-CN">
head>
  meta charset="UTF-8">
  title>用戶登陸頁面/title>
/head>
body>
  form action="" method="post">
    用戶名:input type="text" name="uname" value="" />
    密碼:input type="password" name="upwd" value="" />
    input type="submit" name="submit" value="登陸" />
  /form>
/body>
/html>

index.php代碼如下:

?php
header('Content-Type:text/html;charset=utf-8');
session_start();
 
if(!empty($_SESSION['userInfo'])) {
  echo '您好:', $_SESSION['userInfo']['name'];
} else {
  header('Location:login.php');
}

db.php代碼如下:

?php
$db = mysql_connect('127.0.0.1','root','') or die('connect error');
mysql_select_db('test') or die('select db error');
mysql_query('set names utf8') or die('set names error');

tb_login_state表結(jié)構(gòu)如下:

CREATE TABLE `tb_login_state` (
`uid` int(11) unsigned NOT NULL COMMENT '用戶ID',
`session_id` varchar(32) NOT NULL DEFAULT '' COMMENT '存儲(chǔ)用戶的session_id'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用戶登陸狀態(tài)表';

如果是session存儲(chǔ)方式不是文件,而是存在mysql,memcache,redis中,思路其實(shí)是一樣的,都是把前一次的session_id保存。判斷用戶是否登陸過,如果登陸過就讓上一次的session失效(刪除session數(shù)據(jù))。

(*通過設(shè)置session的過期時(shí)間和cookie的過期時(shí)間來讓session失效是不嚴(yán)格的,最直接的方法是直接把session文件刪除。)

推薦閱讀:

http://www.laruence.com/2012/01/10/2469.html

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php緩存技術(shù)總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP錯(cuò)誤與異常處理方法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP實(shí)現(xiàn)會(huì)員賬號(hào)單唯一登錄的方法分析
  • php $_SESSION會(huì)員登錄實(shí)例分享
  • PHP+MYSQL會(huì)員系統(tǒng)的登陸即權(quán)限判斷實(shí)現(xiàn)代碼
  • 實(shí)用PHP會(huì)員權(quán)限控制實(shí)現(xiàn)原理分析
  • php+MySQL實(shí)現(xiàn)登錄時(shí)驗(yàn)證登錄名和密碼是否正確
  • php session應(yīng)用實(shí)例 登錄驗(yàn)證
  • php cookie 登錄驗(yàn)證示例代碼
  • PHP登錄驗(yàn)證碼的實(shí)現(xiàn)與使用方法
  • php自動(dòng)注冊(cè)登錄驗(yàn)證機(jī)制實(shí)現(xiàn)代碼
  • php面向?qū)ο蟮挠脩舻卿浬矸蒡?yàn)證

標(biāo)簽:黃山 通遼 河南 平頂山 隴南 南通 武漢 唐山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法分析【當(dāng)其它地方登陸時(shí),當(dāng)前賬號(hào)失效】》,本文關(guān)鍵詞  php,實(shí)現(xiàn),賬號(hào),不能,同時(shí),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法分析【當(dāng)其它地方登陸時(shí),當(dāng)前賬號(hào)失效】》相關(guān)的同類信息!
  • 本頁收集關(guān)于php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法分析【當(dāng)其它地方登陸時(shí),當(dāng)前賬號(hào)失效】的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 网站免费视频高清免费| 久久九九精品一区二区| 亚洲天堂2014| 久久久久精品免费A片喷水| 成人免费观看A片www动漫| 免费看一级黄色| 美女直播洗澡的软件下载| 美国1984忌讳第5| 91丨九色丨白浆秘?小青龙| 一级少妇自慰无码AV无码| 嫩草影院ncyy在线观看| 韩国福利在线观看| 人人澡人人爽| 野花韩国大全免费观看6| 婷婷狠狠色18禁久久| 综合久青草视频| 男女姓交大视频免费观看| 51国产黑色丝袜高跟鞋| a级理论片| 男女激烈XXOO无遮挡| 欧美日韩中文久久| 日本捏胸吃奶视频免费| 香港三级欧美国产精品| 日韩一区二区三区四区| 家有艳妻| 98国产精品综合一区二区三区 | 丁香六月激情综合| 女m被主人绑着调教1v1宠| 亚洲免费在线| a级人体片免费观看网站 | 又色又爽又黄gif动态视频| 年轻的保姆相亲完整版在线播放| 大尺度尤妮丝福利视频11| sao货妓女每天都挨cao视频| 免费看黄40分钟| 丝袜老师办公室里做好紧好爽| bl高h肉边走边做| 蘑菇视频成人网站??免费| 乡下村妇伦偷人A片| 欧美疯狂婬乱AAAA片免费| 星空无限传媒在线观看|