.net Session 超时控制

webconfig里明明设置了timeout是很大的数值了,可是session的有效性仍然无法维持一小时。

查了一下,主要是说 mode="InProc" 的话,session是放在进程里的,这样最容易丢失。如果放在 服务和数据库,会稳定一些。  很多人都放 服务里吗?

cookieless设置成true有必要吗?

http://blog.csdn.net/kaifa123/article/details/6890106

==============================================================

http://blog.csdn.net/freeman127/article/details/8633449

发现直接在web.config文件里添加<sessionState mode="InProc" timeout="300"></sessionState> 后,session还是很快就会超时,网上查到资料后试了下,加入如下代码可以对session超时时长进行有效控制:

<sessionState mode="StateServer" stateConnectionString="tcpip=127.0.0.1:42424" cookieless ="false" timeout="240" stateNetworkTimeout="14400"></sessionState>

加上之后,还需在网站所在服务器上打开"服务"——ASP.NET State Service 设置为启动,并自动后即可。

属性      选项      说明 
mode     指定在哪里存储会话状态。 
          Off       指示会话状态未启用。 
          InProc    指示在本地存储会话状态。 
          StateServer 指示在远程计算机上存储会话状态。 
          SQLServer 指示在 SQL Server 上存储会话状态。

========================================================================

http://wenwen.sogou.com/z/q209179334.htm

session默认的超时时间是20分钟,页面20分钟没有动作就会超时了。可以再webconfig里面进行修改。
追问:

我已经设置成60分钟,就算是默认20分钟,有时没几分钟也超时了。

回答:

asp.net session超时的解决办法 收藏  第一个办法:

我有好办法。并且一直用,感觉很爽。

1、在web.config里面加入:<sessionState mode="StateServer" stateConnectionString="tcpip=127.0.0.1:42424" cookieless ="false" timeout="240" stateNetworkTimeout="14400"></sessionState>

2、点击电脑左下角 开始->运行->输入 services.msc 回车 找到ASP.NET State Service,双击,改成自动,并启用。

其中 stateNetworkTimeout 为 在客户端与服务器之间 多长时间没有传送信息则断开他们之间的连接。我设置的是14400,即:14400/60/60=4小时

缺点:在服务器中用ASP.NET State Service服务存储session。会造成服务器资源的紧张。如果有money的话最好买一台服务器专门做session服务。当然,对于小应用无所谓。做过一个小的日志系统,日志,顾名思意,就是网页长期打开,有事的话就往上面录,运行了一年,没有因为session出过问题。

第二个办法(推荐使用):

1)创建一个文件savesession.js(xhbmj:js最好重写一下以支持更多浏览器,用jquery最好) function createXmlHttpRequest() {      var xmlhttp;          try{          xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); //IE 5.0版本      }      catch(e){          try{              xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); //IE 5.5版本          }          catch(e){              try{                  xmlhttp = new XMLHttpRequest(); //不支持ActiveX空间的浏览器              }              catch(e){}          }      }      return xmlhttp; }

function Reconnect() {     var url=‘reconnect.aspx‘     xmlHttp=createXmlHttpRequest()     xmlHttp.open(‘GET‘, url , true)     xmlHttp.send(null) //只要求与服务器联系,不要求返回数据,因此,不进行返回处理 }

function refreshme() {  setInterval("Reconnect();", 60000); //此时间根据实际情况调整 }

2)在需要维持session的页面加上  <script language="javascript" src="savesession.js"></script>,在<body>里面加上 3)创建reconnect.aspx页面,可以没有内容的任何.aspx页面。

第三个办法:自创

建立一个空页面,设置页面自动刷新,可使用html的定时刷新,cs文件里随便写些东西如:

string str = Session["LoginID"].ToString();//最好加个判断null的判断

把这个页面作为iframe嵌入需要长时间操作的页面,设置iframe的宽高都为0

追问:

第一种方法是可以,自己有服务器一般都这样配置。

=====================================================================

http://bbs.csdn.net/topics/60464405

http://bbs.csdn.net/topics/40269870

时间: 2024-10-22 12:30:59

.net Session 超时控制的相关文章

ExtJS4.2.1与Spring MVC实现Session超时控制

如果你的项目使用ExtJS作为表现层,你会发现,SESSION超时控制将是一个问题. 本文将就自己的经验,来解决这一问题,当然,解决问题并非只有一种方法,我只是提出我的方法. 首先,做超时控制,必需使用过滤器,而我们既然使用了Spring MVC,那就用拦截器取代吧,写一个拦截器,用来拦截用户请求,当然,这个拦截器还需要可以配置哪些请求是不需要拦截的. /** * */ package net.bioslink.business.intercepter; import java.io.Print

Extjs springmvc session 超时 处理

如果你的项目使用ExtJS作为表现层,你会发现,SESSION超时控制将是一个问题.本文将就自己的经验,来解决这一问题,当然,解决问题并非只有一种方法,我只是提出我的方法.首先,做超时控制,必需使用过滤器,而我们既然使用了Spring MVC,那就用拦截器取代吧,写一个拦截器,用来拦截用户请求,当然,这个拦截器还需要可以配置哪些请求是不需要拦截的.[java] view plaincopy/** * */ package net.bioslink.business.intercepter; im

基于Redis实现分布式Session

1.概述 我们可以自己实现类似Session的机制,采用 Redis 等分布式缓存中间件来实现. Redis是独立于应用服务器的,基于Redis实现的Session机制自动具备了分布式属性. Redis可以很方便地做集群配置,则Session避免了单点故障. 2.实现 实现代码极其简单,如下所示. /** * @author liuhailong2008#foxmail */ public class ApiSession implements Serializable { private st

COOKIE+SESSION

cookie的缺点: 因为cookie保存在浏览器上,所以安全性低可控性比较差,只能存放字符串大多数的浏览器对cookie有4K的限制. 下面是cookie在浏览器和服务器中请求与响应的过程: 1.    COOKIE的工作原理 cookie过程描述 网站为了辨别用户身份.进行 session 跟踪而储存在用户本地终端上的数据(通常经过加密) 用户第一次访问你的网站->在服务器端会将用户的信息设置为cookie(可以理解为制造饼干过程)->通过http协议发送给用户(浏览器),在用户端,coo

Nginx做负载均衡时session共享问题详解

用nginx做负载均衡时,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说最常见的登录状态. 再者Nginx连接Memcached集群时,Nignx的请求从memcached服务器中根据key获得了value则直接返回value,如果没有获得到value则去MySQL中查询再返回. location / { set $memcached_key "$request_uri"; #设置请求memcached服务器的key memca

会话技术Session&amp;Cookie

一.会话技术简介 1.存储客户端的状态 由一个问题引出今天的内容,例如网站的购物系统,用户将购买的商品信息存储到哪     里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器   记住客户端状态(区分客户端) 举例购物过程: 2.会话技术 从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话.会话技术就是记录这次会话中客户端的状态与数据的. 会话技术分为Cookie和Sessio

Hibernate session缓存

一级缓存(执行代码时查看console台上的sql语句)  清空缓存 @Test public void demo03(){ //清空缓存 Session session=factory.openSession(); session.beginTransaction(); //1.查询 User user = (User)session.get(User.class, 1); System.out.println(user); //session.evitc(user) //将执行对象从一级缓存

JavaWeb基础—会话管理之Session

一.什么是session session类似于客户端在服务器端的账户.使用Map存放 一个会话锁定一个用户(一般情况下是一个客户端,即一个浏览器独占一个session对象),即使使用浏览器访问其他程序资源,也可以共享这个session (如何确定是同一个用户?创建session时把sessionID以cookie的形式传给客户端,客户端访问时再把此sessionID传过去进行校验 JSESSIONID ) 二.session和cookie的区别 cookie 把用户的数据保存到浏览器端,sess

session和cookie的区别

原作者:施杨(施杨's Think out)出处:http://shiyangxt.cnblogs.com 二者的定义: 当你在浏览网站的时候,WEB 服务器会先送一小小资料放在你的计算机上,Cookie 会帮你在网站上所打的文字或是一些选择, 都纪录下来.当下次你再光临同一个网站,WEB 服务器会先看看有没有它上次留下的 Cookie 资料,有的话,就会依据 Cookie 里的内容来判断使用者,送出特定的网页内容给你. Cookie 的使用很普遍,许多有提供个人化服务的网站,都是利用 Cook