session跨页面失效

    一般出现跨页面session失效的情况,基本都跟php的配置有关:

    1、session.save_path访问权限不够,或者路径有问题;

    2、session.use_trans_sid和session.use_only_cookies的设置问题。


    查看php.ini:

    

    发现路径正常,而且文件中也准确记录着session值,因此session.save_path没问题。


    接着查看session.use_trans_sid,发现:

    

    解释一下,session的传递有两种方式,一种是基于cookie传递,另一种是基于URL传递。

    cookie传递即通过cookie将session信息保存在客户端,之后在向服务器发送请求时会自动带上cookie信息,以便服务器读取。这是常用的方式。

    URL传递是在点击跳转的链接后自动添加session信息,如a.php?sessid=...,之后在新页面自动$_GET['sessid']来读取。这个过程是自动且隐藏的,跟用cookie传递一样不知不觉。

    而session.use_trans_sid表示是否使用URL方式传递session,所以如果session.use_trans_sid值为0,而用户浏览器又禁用了cookie,就会出现session跨页面失效的情况。

    

    但将session.use_trans_sid设为1后,session还是失效,就要检查session.use_only_cookies,发现:

    

    session.use_only_cookies表示是否只用cookie传递session,所以如果设置为1,即使session.use_trans_sid=1,也还是不会用到URL传递。

    因此要将session.use_trans_sid=1,session.use_only_cookies=0,才能开启URL传递方式。

你可能感兴趣的:(网页)