CI框架解决jsonp跨域的问题

现象:

       如果js端用了jsonp跨域的请求方式,并且CI配置文件设置了$config['sess_time_to_update'] = xxx;

那么,在xxx秒后点击页面发送请求,帐号会被退出;


原因:

     在文件:system/libraries/Session/Session.php构造函数中有这样一段:


if ((empty($_SERVER['HTTP_X_REQUESTED_WITH']) OR strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) !== 'xmlhttprequest')
			&& ($regenerate_time = config_item('sess_time_to_update')) > 0
		)
		{
			if ( ! isset($_SESSION['__ci_last_regenerate']))
			{
		$_SESSION['__ci_last_regenerate'] = time();
			}
			elseif ($_SESSION['__ci_last_regenerate'] < (time() - $regenerate_time)){
				$this->sess_regenerate((bool) config_item('sess_regenerate_destroy'));
			}
		}
     如果不是ajax请求,超过xxx秒CI会重新生成session_id;


解决:

     对jsonp请求特殊处理 $_SERVER['HTTP_X_REQUESTED_WITH']) = 'xmlhttprequest';


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值