ecshop源码分析:会话类cls_session

当在init.php里new一个cls_session对象时,执行构造
摘要由CSDN通过智能技术生成

我们先来看一下cls_seesion类是如何被调用的:一个最简单的例子是通过admin/index.php进入到admin/includes/init.php,在init.php我们可以找到如下代码:

require(ROOT_PATH . 'includes/cls_session.php');
/*
$db 数据库对象
$ecs->table('sessions')=>`ecshop`.`ecs_sessions`//数据库名.数据表名
$ecs->table('sessions_data')=>`ecshop`.`ecs_sessions_data`
'ECSCP_ID'=>session名称
*/
$sess = new cls_session($db, $ecs->table('sessions'), $ecs->table('sessions_data'), 'ECSCP_ID');
所以,cls_session类是完成初始化工作的一部分。它的功能主要是在客户端生成cookie,进行session的验证,并把一些会话数据插入到数据库中。下面我们来研究每段代码的执行流程以及实现的功能:
//下面的判断语句是为了防止通过地址直接访问该页面
if (!defined('IN_ECS'))
{
    die('Hacking attempt');
}

class cls_session
{
    var $db             = NULL;//数据库连接资源句柄
    var $session_table  = '';//会话表名:ecs_session

    var $max_life_time  = 1800; // SESSION 生命周期

    var $session_name   = '';//会话名:在客户端表示为ESCCP_ID
    var $session_id     = '';//会话ID

    var $session_expiry = '';//会话过期时间戳
    var $session_md5    = '';
	//下面的三个参数都为setcookie中的参数
    var $session_cookie_path   = '/';
    var $session_cookie_domain = '';
    var $session_cookie_secure = false;

    var $_ip   = '';//客户端真实IP
    var $_time = 0;//当前时间

    function __construct(&$db, $session_table, $session_data_table, $session_name = 'ECS_ID', $session_id = '')
    {
        $this->cls_session($db, $session_table, $session_data_table, $session_name, $session_id);
    }
	//构造方法
    function cls_session(&$db, $session_table, $session_data_table, $session_name = 'ECS_ID', $session_id = '')
    {
        $GLOBALS['_SESSION'] = array();//定义一个全局的_SESSION数组变量

		//下面的三个条件语句都是为了给setcookie函数的三个参数做初始化工作
		//cookie在服务器端的有效路径如果该参数设为"/",则它在整个
		//domain(域)内有效,若设为"/11",它就在domain下的/11目录及其子目录内有效,默认为当前目录
        if (!empty($GLOBALS['cookie_path']))//$GLOBALS['cookie_path']='/'
        {
            $this->session_cookie_path = $GLOBALS['cookie_path'];
        }
        else
        {
            $this->session_cookie_path = '/';
        }
		//cookie的有效域名
        if (!empty($GLOBALS['cookie_domain']))//$GLOBALS['cookie_domain']=''
        {
            $this->session_cookie_domain = $GLOBALS['cookie_domain'];
        }
        else
        {
            $this->session_cookie_domain = '';
        }
		//cookie的安全传输方式,1为https,0为http或https
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值