• 解决ecshop登陆自动退出的莫名现象


    最近在做ecshop的二次开发,程序发布后测试出现一个莫名的问题。点击几次页面后出现session丢失,需要重复登陆;本地怎么测试也都无法重现问题。一开始以为是修改程序的问题,可是怎么找都找不着问题所在。网上搜索了一下,说是ip发生了变化引起的。于是做了如下测试:

      1、www.ip.cn查询并记录下IP

      2、登陆

      3、随机点击网页,直到要求重新登陆

      4、www.ip.cn重新查下IP

      果然前后两个IP不一样。因而很有可能是由于IP发生变化导致session失效,于是查看了下ecshop的session机制。其中获取session key的函数是这样

      includes/cls_session.php(移动端的也类似:mobile/include/cls_session.php)

    function gen_session_key($session_id)
    {
      static $ip = '';
    
      if ($ip == '')
      {
        $ip = substr($this->_ip, 0, strrpos($this->_ip, '.'));
      }
    
      return sprintf('%08x', crc32(ROOT_PATH . $ip . $session_id));
    }

    当IP发生变化时:substr($this->_ip, 0, strrpos($this->_ip, '.'))获取到的IP段,只要不在同一个IP段内便无法获得相同的session key;进而也就无法获得session的具体信息,也就导致重复登陆。这也是为什么本地无法重现问题的原因。好吧,问题找到了。那么怎么解决呢?最简单的办法就是将获取IP段的部分去掉,于是修改后的函数也就成这样了。

    function gen_session_key($session_id)
    {
        static $ip = '';
    
      /*
        if ($ip == '')
        {
            $ip = substr($this->_ip, 0, strrpos($this->_ip, '.'));
        }
       */
    
        return sprintf('%08x', crc32(ROOT_PATH . $ip . $session_id));
    }

    这样便可解决重复登陆的问题。但这又涉及到程序的安全性问题,一旦session泄露IP这一步的判断也就失效了。这也进一步降低了网站的安全性,这中间怎么取舍也就见仁见智了。

    转:https://www.cnblogs.com/rwxwsblog/p/4677876.html

  • 相关阅读:
    解决“google快照无法打开”的简单而有效的方法~
    在Struts2里面嵌入Spring
    HDU
    设计模式大总结(二)
    Node.js入门笔记
    草图检索和识别[开源]
    2019-10-31-VisualStudio-断点调试详解
    2019-10-31-VisualStudio-断点调试详解
    2019-9-2-C#-设计模式-责任链
    2019-9-2-C#-设计模式-责任链
  • 原文地址:https://www.cnblogs.com/fps2tao/p/9633287.html
Copyright © 2020-2023  润新知