0

我正在尝试使用 php 和 mysql 设置用户登录/注销系统。我在这里找到了一些关于这个主题的文档:http: //phpmaster.com/writing-custom-session-handlers/。我正在尝试跟随它(我也一直在从其他来源中提取信息 - 但这是主要来源)。

这是我的一些来自“my_session_handler.php”的代码:

class MySessionHandler implements SessionHandlerInterface {

    private $path = session_save_path();
    private $name = session_name();
    private $sessionId = session_id();

    function open($path, $name) {
        $db = new PDO("mysql:host=localhost;dbname=itit", "root", "bonjour3");

        $sql = "INSERT INTO session SET session_id =" . $db->quote($sessionId) . ", session_data = '' ON DUPLICATE KEY UPDATE session_lastaccesstime = NOW()";
        $db->query($sql);    


    ...

我的问题是,我上面引用的示例中的“$path”和“$name”变量来自哪里?我将它们声明为私有变量,并使用一些函数来做我认为需要做的事情。但是在我关注的网站上 - 这些变量都没有被声明 - 以及 $sessionId。我看到读取函数返回 $data。所以我在“写”函数中使用它,如下所示:

function write($sessionId, this.read($sessionId)) { 
    $db = new PDO("mysql:host=localhost;dbname=itit", "root", "bonjour3");

    $sql = "INSERT INTO session SET session_id =" . $db->quote($sessionId) . ", session_data =" . $db->quote($data) . " ON DUPLICATE KEY UPDATE session_data =" . $db->quote($data);
    $db->query($sql)
}

我这样做对吗?

4

1 回答 1

1

这些参数由默认会话保存处理程序使用,它将会话数据保存在文件中。它们来自php.ini文件,用于形成文件名。open()当 PHP 调用该方法时,它们会提供给您的处理程序。

如果您正在编写自定义处理程序,则可以忽略它们,就像该网页上的代码一样。

于 2013-06-08T16:12:22.337 回答