session过期很快的解决方法(这个比较好)

转载 2012年03月27日 12:18:09

我是在租用的虚拟主机上发现,自己在本地测试时正常的代码,在虚拟主机上session仅保存了几秒钟就过期了,登陆信息被清空,要重新登陆。

在页面中设置session.timeout=20(IIS的默认值也是20分钟)不管用,和虚拟主机服务商沟通也是枉然,最后发现了一种可以强制设定过期时间的方法,在global.asa中设置:

<script   language=vbscript   runat=server>  
 sub Session_OnStart  
  session.timeout=60   '默认是20(分钟)你设置的大一些就好了  
 end sub  
</script>

问题就解决了。

另外,提供一些抄来的参考资料:

SessionState 的Timeout),其主要原因有三种。
一:有些杀病毒软件会去扫描您的Web.Config文件,那时Session肯定掉,这是微软的说法。
二:程序内部里有让Session掉失的代码,及服务器内存不足产生的。
三:程序有框架页面和跨域情况。
第一种解决办法是:使杀病毒软件屏蔽扫描Web.Config文件(程序运行时自己也不要去编辑它)
第二种是检查代码有无Session.Abandon()之类的。
第三种是在Window服务中将ASP.NET State Service 启动。
还有可能就是你在测试期间改动了,网站的文件。


我测试过没有问题!测试程序如下:
protected void Application_Start(Object sender, EventArgs e)
    {
      SqlConnection con = new SqlConnection("server=localhost;database=YourDatabase;uid=sa;pwd=;");
      SqlCommand cmd = new SqlCommand(string.Format("insert into table1 (c) values('{0}')","Application_Start"+DateTime.Now.ToLongTimeString()+"application id"+Application.ToString()),con);
      con.Open();
      cmd.ExecuteNonQuery();
      con.Close();

}
  
    protected void Session_Start(Object sender, EventArgs e)
    {
      SqlConnection con = new SqlConnection("server=localhost;database=YourDatabase;uid=sa;pwd=;");
      SqlCommand cmd = new SqlCommand(string.Format("insert into table1 (c) values('{0}')","Session_Start"+DateTime.Now.ToLongTimeString()+"SessionID="+Session.SessionID),con);
      con.Open();
      cmd.ExecuteNonQuery();
      con.Close(); 
    }

    protected void Application_BeginRequest(Object sender, EventArgs e)
    {
      SqlConnection con = new SqlConnection("server=localhost;database=YourDatabase;uid=sa;pwd=;");
      SqlCommand cmd = new SqlCommand(string.Format("insert into table1 (c) values('{0}')","Application_BeginRequest"+DateTime.Now.ToLongTimeString()),con);
      con.Open();
      cmd.ExecuteNonQuery();
      con.Close();

    }

    protected void Application_EndRequest(Object sender, EventArgs e)
    {
      SqlConnection con = new SqlConnection("server=localhost;database=YourDatabase;uid=sa;pwd=;");
      SqlCommand cmd = new SqlCommand(string.Format("insert into table1 (c) values('{0}')","Application_EndRequest"+DateTime.Now.ToLongTimeString()),con);
      con.Open();
      cmd.ExecuteNonQuery();
      con.Close();

    }

    protected void Application_AuthenticateRequest(Object sender, EventArgs e)
    {

    }

    protected void Application_Error(Object sender, EventArgs e)
    {

    }

    protected void Session_End(Object sender, EventArgs e)
    {
      SqlConnection con = new SqlConnection("server=localhost;database=YourDatabase;uid=sa;pwd=;");
      SqlCommand cmd = new SqlCommand(string.Format("insert into table1 (c) values('{0}')","Session_End"+DateTime.Now.ToLongTimeString()+"SessionID="+Session.SessionID),con);
      con.Open();
      cmd.ExecuteNonQuery();
      con.Close(); 
    }

    protected void Application_End(Object sender, EventArgs e)
    {
      SqlConnection con = new SqlConnection("server=localhost;database=YourDatabase;uid=sa;pwd=;");
      SqlCommand cmd = new SqlCommand(string.Format("insert into table1 (c) values('{0}')","Application_End"+DateTime.Now.ToLongTimeString()),con);
      con.Open();
      cmd.ExecuteNonQuery();
      con.Close(); 
    }

所有的代码都是Global里面的

.net下的配置如下:

sessionState节点的语法是这样的:

<   sessionState mode="Off|InProc|StateServer|SQLServer"
               cookieless
="true|false"
               timeout
="number of minutes"
               stateConnectionString
="tcpip=server:port"
               sqlConnectionString
="sql connection string"
               stateNetworkTimeout
="number of seconds"
/>

必须有的属性是

属性 选项 描述
mode   设置将Session信息存储到哪里
Off 设置为不使用Session功能
InProc 设置为将Session存储在进程内,就是ASP中的存储方式,这是默认值。
StateServer 设置为将Session存储在独立的状态服务中。
SQLServer 设置将Session存储在SQL Server中。

可选的属性是:

属性 选项 描述
cookieless   设置客户端的Session信息存储到哪里
ture 使用Cookieless模式
false 使用Cookie模式,这是默认值。
timeout   设置经过多少分钟后服务器自动放弃Session信息。默认为20分钟
stateConnectionString   设置将Session信息存储在状态服务中时使用的服务器名称和端口号,例如:"tcpip=127.0.0.1:42424”。当mode的值是StateServer是,这个属性是必需的。
sqlConnectionString   设置与SQL Server连接时的连接字符串。例如"data source=localhost;Integrated Security=SSPI;Initial Catalog=northwind"。当mode的值是SQLServer时,这个属性是必需的。
stateNetworkTimeout   设置当使用StateServer模式存储Session状态时,经过多少秒空闲后,断开Web服务器与存储状态信息的服务器的TCP/IP连接的。默认值是10秒钟。 

打开某个应用程序的配置文件Web.config后,我们会发现以下这段:

<   sessionState
  
mode="InProc"
  stateConnectionString
="tcpip=127.0.0.1:42424"
  sqlConnectionString
="data source=127.0.0.1;Trusted_Connection=yes"
  cookieless
="false"
  timeout
="20"  
/>

 



session过期很快的解决方法(这个比较好)

http://www.cnblogs.com/qiantuwuliang/archive/2009/05/18/1459489.html  我是在租用的虚拟主机上发现,自己在本地测试时正常的代码,在虚...
  • Sky_666
  • Sky_666
  • 2010年02月05日 18:34
  • 449

session过期很快的解决方法

我是在租用的虚拟主机上发现,自己在本地测试时正常的代码,在虚拟主机上session仅保存了几秒钟就过期了,登陆信息被清空,要重新登陆。在页面中设置session.timeout=20(IIS的默认值也...
  • YnSky
  • YnSky
  • 2010年04月19日 18:51
  • 544

session过期很快的解决方法

 session过期很快的解决方法(这个比较好) 我是在租用的虚拟主机上发现,自己在本地测试时正常的代码,在虚拟主机上session仅保存了几秒钟就过期了,登陆信息被清空,要重新登陆。在页面中设置se...
  • liuhuan2099
  • liuhuan2099
  • 2009年08月31日 13:52
  • 6104

主动式session过期提示

主动式session过期提示 什么是 “主动式session过期提示”?恩,这是偶给命的名。来源于一个同事问我,js如何实现当session过期的时候弹层提示:您的session已经过期,请...
  • gbtyy
  • gbtyy
  • 2013年01月09日 22:55
  • 4120

走近传说中的天才,拨开神话面纱,学习解决问题的方法

在知乎上看到一个问题的回答,是陶哲轩的博士生匿名回答的。这个解答有助于提高自信,同时能帮助改进学习和解决相关问题的方法。 面对难题,陶大神也不是什么都能解决的; 学习人家碰到搞不定的问题时所...
  • stereohomology
  • stereohomology
  • 2017年07月21日 22:50
  • 244

启发式算法简谈

引言:解 决实际的问题,要建模型,再求解。求解要选择算法,只有我们对各种算法的优缺点都很熟悉后才能根据实际问题选出有效的算法。但是对各种算法都了如指掌是不 现实的,但多知道一些,会使你的选择集更大...
  • metasearch
  • metasearch
  • 2011年04月13日 22:26
  • 958

NEUQ 1431:快速幂入门

1431: 快速幂入门 时间限制: 1 Sec  内存限制: 128 MB 题目描述 快速幂为我们的幂运算提供了一个很快的方法。这道题要求你练习刚刚学会的快速幂。即计算a^n...
  • Han_kin
  • Han_kin
  • 2015年03月22日 17:10
  • 996

这个故事很温暖

1. 她很胖,胖到所有人都觉得不会有人娶她。他很瘦,却鬼使神差般娶了她。结婚那夜,她在他面前宽衣,随着衣服脱落的,还有一层肉皮。其实她是个美人,只因厌倦人们对外貌的严苛,于是费尽心机想找个能容忍她丑陋...
  • hanjianshenqing
  • hanjianshenqing
  • 2010年12月14日 19:54
  • 143

java并发基础(五)--- 线程池的配置与定制ThreadPoolExecutor

原Blog:http://www.cnblogs.com/HectorHou/p/6037987.html 对应原书第八章 一、在任务和执行策略之间隐性耦合 Executor...
  • u013547284
  • u013547284
  • 2017年10月13日 22:26
  • 45

这个世界很残酷

当我从恐惧的壳子里,从我一直关注的事情中挣脱出来。我发现世界的确变了,没有变的是——这个世界残酷。 不会自己,就为别人。 人与人之间,本身就有利益关系——生存关系。这是无法改变的事实。 ...
  • maqingqing1992
  • maqingqing1992
  • 2015年07月15日 10:36
  • 177
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:session过期很快的解决方法(这个比较好)
举报原因:
原因补充:

(最多只允许输入30个字)