<?php
class cls_session
{
    var $session_table  = '';

; // SESSION 过期时间

var $session_name   = '';
    var $session_id     = '';

var $session_expiry = '';
    var $session_md5    = '';

;

function __construct($session_table,$session_name){
        
       $this->cls_session($session_table,$session_name);
    }

function cls_session($session_table,$session_name){

$GLOBALS['_SESSION'] = array();
  
        $this->session_name       = $session_name;
        $this->session_table      = $session_table;
  
        if (!empty($_COOKIE[$this->session_name])){

$this->session_id = $_COOKIE[$this->session_name];
        }
        else{

$this->session_id = '';
        }

$this->_time = time();

if ($this->session_id){

$this->load_session();
        }
        else{
            $this->gen_session_id();

setcookie($this->session_name, $this->session_id);
        }

register_shutdown_function(array($this, 'update_session'));
    }

function gen_session_id(){

$this->session_id = md5(uniqid(mt_rand(), true));

return $this->insert_session();
    }

function insert_session(){

return mysql_query('INSERT INTO ' . $this->session_table . " (sesskey, expiry,data) VALUES ('" . $this->session_id . "', ". $this->_time .",'a:0:{}')");
    }

function load_session(){

$result = mysql_query('SELECT data, expiry FROM ' . $this->session_table . " WHERE sesskey = '" . $this->session_id . "'");
  
       $session = mysql_fetch_array($result);
  
       if (!empty($session['data']) && $this->_time - $session['expiry'] <= $this->max_life_time){

/***********************************************
               *   unserialize()还原已经序列化的SESSION变量              *
               *   保证了SESSION变量的页面间传值的作用               *
               ***********************************************/
                $GLOBALS['_SESSION']  = unserialize($session['data']);
            }
    }

;
        $userid  ;

/************************************************************************
       *  用serialize函数将所有你所赋值的SESSION变量转化为一个序列化的字符串。        *
       *  SESSION本质不会发生变换,存入数据库中,用于下次调用。                                   *
       ************************************************************************/
 
        $data        = serialize($GLOBALS['_SESSION']);
        $this->_time = time();
       
        return mysql_query('UPDATE ' . $this->session_table . " SET expiry = " . $this->_time . ", userid = '" . $userid . "', adminid = '" . $adminid . "', data = '$data' WHERE sesskey = '" . $this->session_id . "'");
    }
}

// database host
$db_host   = "localhost";

// database name
$db_name   = "ecshop";

// database username
$db_user   = "root";

// database password
$db_pass   = "dingran";

$link = mysql_connect($db_host, $db_user, $db_pass);

if ($link){

mysql_select_db($db_name);
}
else{

exit('mysql connection error:'.mysql_error());
}

/* 初始化session */
$sess = new cls_session('ecs_sessions','ECSCP_ID');

;
    
         header("Location: e.php");     //在e.php再加载一次cls_session类,输出session变量
}
?>

ECSHOP session的更多相关文章

  1. ecshop session机制

    ecshop session机制 2014-06-12    1455     懒人程序   ecshop的cls_session.php分析,主要是讲述ecshop中的session机制.我们都知道 ...

  2. ecshop session丢失问题

    ecshop session丢失问题 电子商务PHP 用ecshop搭建了一个电子商务的系统,本地测试一切正常.放到服务器上出现问题: 症状:      点着点着经常无故退出,感觉session被清空 ...

  3. php 的session机制 和ecshop session机制

    一.默认机制,用磁盘文件来实现PHP会话.php.ini配置:session.save_handler = files 1.session_start() A. session_start()是ses ...

  4. ecshop换用redis做缓存

    <?php /** * ecshop SESSION 保存类 * ================================================================ ...

  5. memory_limit session.cache_expire ecshop初始化注释说明

    memory_limit session.cache_expire ecshop初始化注释说明 memory_limit = 128M; 一个脚本所能够申请到的最大内存字节数(可以使用K和M作为单位) ...

  6. 将ecshop中的session机制重写,从DB移植到Memcache中去

    <?php if (!defined('IN_ECS')) { die('Hacking attempt'); } /*------------------------------------- ...

  7. ECshop中的session机制理解

    ECshop中的session机制理解     在网上找了发现都是来之一人之手,也没有用自己的话去解释,这里我就抛砖引玉,发表一下自己的意见,还希望能得到各界人士的指导批评! 此session机制不需 ...

  8. python 登录并获取session,使用session新增ecshop的草稿

    ,"consignee":"冬天","email":"12345@qq.com","address" ...

  9. php ecshop 二级域名切换跳转时session不同步,解决session无法共享同步导致无法登陆或者无法退出的问题

    echshop基础上做了单点登录的 一级域名与二级域名 退出时 清空session 都是一级域名的session 因为二级域名的session是设置在二级域名上的 echshop基础上没有做单点登录的 ...

随机推荐

  1. PAT (Advanced Level) 1111. Online Map (30)

    预处理出最短路再进行暴力dfs求答案会比较好.直接dfs效率太低. #include<cstdio> #include<cstring> #include<cmath&g ...

  2. access restriction

    一.既然存在访问规则,那么修改访问规则即可.打开项目的Build Path Configuration页面,打开报错的JAR包,选中Access rules条目,选择右侧的编辑按钮,添加一个访问规则即 ...

  3. 转 shell脚本学习指南

    shell脚本学习指南 以下八点不敢说就能成为你shell脚本学习指南de全部,至少可以让你编写出可靠的shell脚本. 1. 指定bashshell 脚本的第一行,#!之后应该是什么?如果拿这个问题 ...

  4. ftok函数的使用

    ftok函数的定义:系统建立IPC通讯 (消息队列.信号量和共享内存) 时必须指定一个ID值.通常情况下,该id值通过ftok函数得到. 头文件 #include <sys/types.h> ...

  5. Eclipse使用的小细节归档

    1. 控制台打印出来的语句不限制条数:Preference-> Run/Debug -> Control -> Limit Console Output 2.

  6. 打造最强Windows Server 2012 给你比Windows 8更好的体验

    每一代微软桌面操作系统推出的时候,都会同步推出相应核心的服务器操作系统,稳定性会更强哈 所以改造一下,让它保留兼容和专业的同时又有桌面操作系统的美观和便捷,多好 咳咳,让我们来看看怎么把Server ...

  7. java中堆和堆栈的区别

    java中堆和堆栈的区别(一) 1.栈(stack)与堆(heap)都是Java用来在Ram中存放数据的地方.与C++不同,Java自动管理栈和堆,程序员不能直接地设置栈或堆. 2. 栈的优势是,存取 ...

  8. linux下 mysql 学习(一)

    1.登录mysql [root@test1 local]# mysql  Welcome to the MySQL monitor. Commands end with ; or g. Your My ...

  9. LintCode 面试题 旋转字符串

    1.题目描述 题目链接:http://www.lintcode.com/zh-cn/problem/rotate-string/ 给定一个字符串和一个偏移量,根据偏移量旋转字符串(从左向右旋转) 2. ...

  10. 编写一个python脚本功能-备份

    版本一 解决方案当我们基本完成程序的设计,我们就可以编写代码了,它是对我们的解决方案的实施.版本一例10.1 备份脚本——版本一 #!/usr/bin/python # Filename: backu ...