3 回答

TA貢獻1830條經驗 獲得超9個贊
嘗試這個
<?php
/**
* ------------------------------------------------------------------------
* CI Session Class Extension for AJAX calls.
* ------------------------------------------------------------------------
*
* ====- Save as application/libraries/MY_Session.php -====
*/
class MY_Session extends CI_Session {
// --------------------------------------------------------------------
/**
* sess_update()
*
* Do not update an existing session on ajax or xajax calls
*
* @access public
* @return void
*/
public function sess_update()
{
$CI = get_instance();
if ( ! $CI->input->is_ajax_request())
{
parent::sess_update();
}
}
}
// ------------------------------------------------------------------------
/* End of file MY_Session.php */
/* Location: ./application/libraries/MY_Session.php */
問題出在會話類的sess_update函數中,該函數在X秒后生成一個新的session_id。每個頁面都有一個session_id,如果session_id在進行ajax調用之前過期,則該調用將失敗。
在/ application / libraries /中創(chuàng)建一個名稱為MY_Session(或您設置的前綴)的php文件,將此代碼粘貼在那里。該函數將覆蓋會話類中的sess_update函數,檢查每個請求是否由ajax發(fā)出,跳過sess_update函數。
將sess_expiration設置為更高的值是一個壞主意。這是一項安全功能,可防止您受到會話干擾
PD:我的英語不太流利,如果您聽不懂,請告訴我。

TA貢獻1828條經驗 獲得超3個贊
在將其合并到穩(wěn)定分支之前,解決方案(最終?。┦菍reson的提交245bef5與數據庫模式結合使用:
CREATE TABLE IF NOT EXISTS `ci_sessions` (
session_id varchar(40) DEFAULT '0' NOT NULL,
ip_address varchar(45) DEFAULT '0' NOT NULL,
user_agent varchar(120) NOT NULL,
last_activity int(10) unsigned DEFAULT 0 NOT NULL,
user_data text NOT NULL,
prevent_update int(10) DEFAULT NULL,
PRIMARY KEY (session_id),
KEY `last_activity_idx` (`last_activity`)
);
有關更多信息,請從上至下閱讀拉1283注釋。
- 3 回答
- 0 關注
- 404 瀏覽
添加回答
舉報