• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    asp之让Session永不过期
    又有人说设session.timeout=99999。这种同样不行,session有最大时间限制。我经过测试发现最大值为24小时,也就是说你最大可以session.timeout=1440,1441都是不可以有,呵呵。本人测试环境:win2003+IIS6.0+ASP3.0。

    所以想通过设session.timeout的过期时间让session永不过期是不可能的。写到Cookies里是比较好的方法,网上也有很多这样的教程,这里就不再说了!还有就是用在要保持session的页里设隐藏iframe每隔一段时间(这个时间小于session.timeout的时间)把刷新一次frame里的空页面!实现方法如下:
    在要保持session页里加上:
    复制代码 代码如下:

    iframe width=0 height=0 src="/blog/SessionKeeper.asp">/iframe>

    同目录下建一下SessionKeeper.asp的文件。 XML/HTML复制代码
    复制代码 代码如下:

    html>
    head>
    meta http-equiv="Refresh" content="900000;url=sessionKeeper.asp">
    !--每隔900秒刷新一下自己,为了和服务器通讯一下,保持session不会丢-->
    /head>
    /html>

    这种方法还是比较长见的,另外还有一种和上面类似的方法,不过他不是用meta自动刷新嵌套的iframe的方法。他是用javascript:window.setTimeout("functionname()",10000);第隔一段时间时间自动调用一个函数的方法,当然函数里还是要去连接一个空的文件。具体方法如下:
    在要保持session面里加上: JavaScript复制代码
    复制代码 代码如下:

    script id=Back language=javascript>/script>
    script language=javascript>
    function keepsession(){
    document.all["Back"].src="/blog/SessionKeeper.asp?RandStr="+Math.random();
    //这里的RandStr=Math.random只是为了让每次back.src的值不同,防止同一地址刷新无效的情况
    window.setTimeout("keepsession()",900000); //每隔900秒调用一下本身
    }
    keepsession();
    /script>
    这样同一目录下建一个空内容的sessionKeeper.asp就文件就可以了!

    问题没有解决:通过以上的方法Session保持应该没有问题了,IIS默认无请求的清除session的值为20分钟,我设的每次交互服务的时间都远远小于这个值,可是我大概过个一天多的时间,session还是无缘无故的没了!郁闷。

    后来在网上多方查找终于找到答案:原来IIS为了保护服务器,有一个“回收”的概念!测试了半天终于有了点大体了解(不要笑我菜^-^)。先来看看这个“回收”在哪设置。

    启动IIS管理器->应用程序池->右键->属性->回收选项卡,有一项是默认就起作用的,就是第一项:“回收工作进程(分钟)”默认值1740分钟,大约29个小时。他是什么意思呢?我个人理解:在session.timeout之后再过1740分钟自动把所有仍在保持的session清除。这个值最大可设为4000000,大概是2700多天!我直接取消了,不用他自动回收!问题终于解决。

    另外这个属性对话框中还有其它几项:
    第二项应该是连接的用户超过了一定数目回收。
    第三项是到某一个时间就自动回收。

    在“性能”选项卡中“在空闲此时间段后关闭工作进程”,这里就是设置IIS默认session.timeout时间的地方了。默认值20分钟,这里同样最大值可设为4000000,和在ASP页中设置session.timeout最大值为1440不同。在这里设置超过大于1440的值是否起作用,我没作测试,我想应该是可以的。那为什么在ASP页中session.timeout的值最大只能是1440在IIS的属性中却能设的那么大呢?应该是属于一种保护机制:ASP页的session.timeout的值哪个用户都可以设,IIS里却只有管理员可以设,两者的权限不同,所以设置的范围就不同了。
    您可能感兴趣的文章:
    • 解析PHP的session过期设置
    • ajax实现session不过期(避免页面过期的现象)
    • 几种判断asp.net中session过期方法的比较
    • jsp中session过期设置及web.xml配置学习
    • 在ASP.NET中,设置Session的过期时间的方法
    • asp中设置session过期时间方法总结
    • ASP中Session技巧 默认过期时间为20分钟
    • PHP中的session永不过期的解决思路及实现方法分享
    • ajax session过期问题的几个解决方案
    • 判断Session的过期时间 采用JavaScript实时显示剩余多少秒
    • 如何设置一个严格30分钟过期的Session示例介绍
    上一篇:在ASP编程中nothing代表什么意思?
    下一篇:ASP获取ACCESS数据库表名及结构的代码
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    asp之让Session永不过期 asp,之让,Session,永不,过期,