0

我不确定这里出了什么问题,但我已经尝试了一切来解决一个非常烦人的问题,这个问题现在一直困扰着我的网站,那就是 PHP 为每个用户生成多个会话。

目前,我是唯一使用该站点的人,所以我完全知道其他人不可能创建会话,但是,可以肯定的是,我在会话类中启动 session_start() 后立即存储了 IP 地址..低头看,这是我的IP地址不断生成。登录后,数据库中又添加了 5 或 6 条记录,每条记录都包含我的 IP 地址,只有一条包含会话信息。

现在,该网站运行良好,但我知道这是不正常的行为。我只调用 session_start() 一次,除了登录之外,我没有在站点上的任何地方调用 regenerate_id,但是即使在登录之前,只要我访问该站点,就会添加三个记录。

我想知道这是否是一个已知问题,以及是否有人可以梳理我的代码,看看他们是否能看到任何可能导致这种奇怪行为的东西,因为不幸的是,谷歌上的一个小时左右和搜索 SO 没有裁剪大部分结果(除了保存问题的未回答问题)

class Sessions {

private $life_time, $database;

public function __construct()
{
    $this->life_time = DatabaseConfig::read('SESSION_MAX_LIFETIME'); // Set within a config file, returns 1440
    $this->database = DatabaseCore::getInstance(); // Basically allows me to create only one instance of the database to avoid overhead from multiple persistent connections.

    session_set_save_handler( 
        array( &$this, "NewSession" ), 
        array( &$this, "CloseSession" ),
        array( &$this, "ReadSession" ),
        array( &$this, "WriteSession"),
        array( &$this, "DestroySession"),
        array( &$this, "CleanSessions" )
    );

    session_name("SESSION_GEEK_PANEL"); 
    session_start();
}

public function NewSession( $save_path, $session_name ) {

    $sess_save_path = $save_path;

    return true;

}

public function ReadSession( $id ) {

    $sth = $this->database->dbh->prepare("SELECT `session_data` FROM `sessions` WHERE `session_id` = :session_id ");
    $sth->execute(array(
        ':session_id'    => $id
    ));

    if( $sth->rowCount() > 0 )
    {
        $row = $sth->fetch();
        $data = $row['session_data'];
    }

    return $data;

}

public function WriteSession( $id, $data ) {

    $sth = $this->database->dbh->prepare("REPLACE `sessions` (`session_id`, `session_data`, `expires`) VALUES( :id, :data, :expires )");

    $sth->execute(array(
        ':id'    => $id,
        ':data' => $data,
        ':expires' => time() + $this->life_time
    ));

    return true;

}

public function DestroySession( $id ) {

    $params = session_get_cookie_params();
    setcookie(session_name(), '', time() - 42000,
        $params["path"], $params["domain"],
        $params["secure"], $params["httponly"]
    );

    $sth = $this->database->dbh->prepare("DELETE FROM `sessions` WHERE `session_id` = :id");
    $sth->execute(array(
        ':id' => $id
    ));

    return true;

}

public function CleanSessions() {

    $sth = $this->database->dbh->prepare("DELETE FROM `sessions` WHERE `expires` < :time");
    $sth->execute(array(
        ':time' => time()
    ));

    return true;

}

public function CloseSession() {

    return true;

}
}
DatabaseConfig::write('SESSION_MAX_LIFETIME', MAX_SESSION_LIFE);

非常感谢所有帮助,最后..这可能是主机或 PHP INI 文件的错误吗?谢谢 :)

4

1 回答 1

0

你检查过 PHP INI 中的 session.auto_start 吗?

于 2013-04-09T22:08:26.883 回答