PHP session

<?php
class SessionHandle
{
    public function open($savePath,$sessionName)
    {
        echo 'This is open </br>';
        return true;
    }

    public function close()
    {
        echo 'This is close </br>';
        return true;
    }

    public function read($id)
    {
        echo 'This is read </br>';
        echo $id;
        return 'sssxx';
    }

    public function write($id, $data)
    {
        echo 'This is write </br>';
        echo $id;
        var_dump('expression');
        echo $data;
        return true;
    }

    public function destroy($id)
    {
        echo 'This is des </br>';
        return true;
    }

    public function gc($maxLifetime)
    {
        echo 'This is gc </br>';
        //echo $maxLifetime;
        return false;
    }
}

ini_set('session.gc_probability',1);
ini_set('session.gc_divisor',100);
$session = new SessionHandle();
@session_set_save_handler(
  array(&$session, "open"),
       array(&$session, "close"),
       array(&$session, "read"),
       array(&$session, "write"),
       array(&$session, "destroy"),
       array(&$session, "gc")
    );
session_start();
$_SESSION['views']=1;
var_dump($_SESSION['views'] . 'abc');


总结:PHP session 每次request结束之后会把所有的session重新更新一遍。Session 每次都是先读取后存储!用户关闭浏览器并不会触发gc的执行,只会销毁没有指定保存时长的cookie。

### PHP Session 使用指南 #### 创建并启动会话 为了在 PHP 序列化环境中维持用户的交互状态,需调用 `session_start()` 函数来创建新的会话或恢复现有会话。此函数负责初始化会话数据,并将其与客户端通过 cookie 或 URL 参数关联起来[^1]。 ```php <?php // 启动会话前可以设置一些选项 ini_set('session.cookie_httponly', 1); ini_set('session.use_only_cookies', 1); // 开始会话 session_start(); ?> ``` #### 存储和检索会话变量 一旦建立了有效的会话连接,则可以通过超级全局数组 $_SESSION 来存取特定于该访客的信息。这些信息会在整个浏览期间持续存在直至显式删除或超时期满。 ```php <?php $_SESSION['username'] = "JohnDoe"; // 设置会话变量 echo $_SESSION['username']; // 获取会话变量 unset($_SESSION['username']); // 删除单个会话变量 session_destroy(); // 销毁全部会话数据 ?> ``` #### 安全实践建议 当涉及到敏感资料传输时,应当采取额外的安全措施以保护用户隐私及防止潜在攻击。这包括但不限于启用 HTTPS 协议、配置严格的 Cookie 属性以及采用第三方库增强安全性[^3]。 ```php <?php require_once 'vendor/autoload.php'; $config = [ 'lifetime' => 86400, // 设置会话生命周期为一天 'httponly' => true, 'secure' => isset($_SERVER["HTTPS"]), // 只允许通过 HTTPS 发送 Cookies ]; $sessionManager = new \Ezimuel\PhpSecureSession\Session($config); $sessionManager->start(); if ($userAuthenticated) { $segment = $sessionManager->getSegment('auth'); $segment->set('userId', $userId); } ?> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值