3 回答

TA貢獻(xiàn)1817條經(jīng)驗 獲得超6個贊
嘗試這個
<?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函數(shù)中,該函數(shù)在X秒后生成一個新的session_id。每個頁面都有一個session_id,如果session_id在進(jìn)行ajax調(diào)用之前過期,則該調(diào)用將失敗。
在/ application / libraries /中創(chuàng)建一個名稱為MY_Session(或您設(shè)置的前綴)的php文件,將此代碼粘貼在那里。該函數(shù)將覆蓋會話類中的sess_update函數(shù),檢查每個請求是否由ajax發(fā)出,跳過sess_update函數(shù)。
將sess_expiration設(shè)置為更高的值是一個壞主意。這是一項安全功能,可防止您受到會話干擾
PD:我的英語不太流利,如果您聽不懂,請告訴我。

TA貢獻(xiàn)1841條經(jīng)驗 獲得超3個贊
在將其合并到穩(wěn)定分支之前,解決方案(最終?。┦菍reson的提交245bef5與數(shù)據(jù)庫模式結(jié)合使用:
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`)
);
有關(guān)更多信息,請從上至下閱讀拉1283注釋。
- 3 回答
- 0 關(guān)注
- 535 瀏覽
添加回答
舉報