当前位置:Gxlcms > ASP > asp中设置session过期时间方法总结

asp中设置session过期时间方法总结

时间:2021-07-01 10:21:17 帮助过:78人阅读

如果程序中没有设置session的过期时间,那么session过期时间就会按照IIS设置的过期时间来执行,IIS中session默认过期时间为20分钟,IIS中session时间可以更改

时间设置要放在前面

例如
代码如下:
  1. <br>Session.Timeout=30 'SEESION有效时间为30分钟 <br>Session("ID")=Rs("id") <br>Session("Name")=Rs("Name") <br>Session("Pass")=Rs("Pass" <br> <br><br><strong>利用 Session.Timeout 属性设置超时时限</strong> <br><br>对于一个登录到 ASP 应用程序的用户,如果用户在系统默认的时间内未进行其它任何操作,当设置的时间一到便自动撤销这个用户的 Session,这样就可以防止系统的资源被浪费。Session 对象的 TimeOut 属性可以用来设置“过期时间”,已分钟为单位,其设置格式为: <br><br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>Session.TimeOut=MaxTime <br> <br>实例代码:(5.asp)页面,本实例说明如何控制会话的结束。 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br><%@ language="vbscript" %> <br><% session.timeout=60 %> <br><html> <br><head><title>控制会话的结束时间</title><head> <br><body> <br><% <br>who = Session.SessionID <br>CurrentPage=Request.ServerVariables("SCRIPT_NAME") <br>Response.AppendTolog who & ":" & CurrentPage <br>Response.write "<center>你的会话标识为:" & who & "<p>" <br>Response.write "你当前访问的页面路径为:" & CurrentPage & "<p>" <br>if Session("I")="" then <br>session("i")=1 <br>else <br>session("i")=session("i")+1 <br>end if <br>Session.Abandon <br>Response.write "本页面被你刷新了" & Session("i") & "次。</centr>" <br>%> <br> <br><br>Asp.net应用中,很多人会遇到Session过期设置有冲突。其中,可以有四处设置Session的过期时间: <br><br>一、全局网站(即服务器)级 <br><br>IIS-网站-属性-Asp.net-编辑配置-状态管理-会话超时(分钟)-设置为120,即为2小时,即120分钟后如果当前用户没有操作,那么Session就会自动过期。 <br><br>二、网站级 <br><br>IIS-网站-具体网站(如DemoSite)-属性-Asp.net,此时有两个选项,一个是“编辑全局配置”,一个是“编辑配置”。 <br>如果“编辑全局配置”,就和上个配置一样。 <br>如果“编辑配置”,则只对当前网站生效。因为一个服务器可能有很多独立网站。 <br>1、继续选择“状态管理”-会话超时(分钟)-设置为360,即360分钟。效果同上,只不过只对当前网站生效。 <br>2、身份认证-Forms-Cooke超时,选择"12:00:00",即12个小时。可选项共有以下八项: <br>00:15:00 <br>00:30:00 <br>01:00:00 <br>02:00:00 <br>04:00:00 <br>08:00:00 <br>12:00:00 <br>1:00:00:00 <br>即最长24小时,最小15分钟。这是默认的配置。在应用中可以自由定制。 <br><br><strong>三、应用程序级 <br></strong><br>同网站管理,只不过作用域仅限当前应用程序。 <br><br><strong>四、页面级 <br><br></strong>在某页面中,设置Session.Timeout = 30;即可临时修改某页面的会话过期时间。 <br>查看某个Session的过期时间,可以用 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>TimeSpan SessTimeOut = new TimeSpan(0, 0, System.Web.HttpContext.Current.Session.Timeout, 0, 0); <br>TimeSpan SessTimeOut = new TimeSpan(0, 0, System.Web.HttpContext.Current.Session.Timeout, 0, 0); <br> <br>其中,二和三的设置,体现在Web.config中即: <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>view plaincopy to clipboardprint? <br><?xml version="1.0"?> <br><configuration> <br><system.web> <br><authentication mode="Forms" > <br><forms name="AuthLogin" loginUrl="/Login.aspx" protection="All" timeout="360" slidingExpiration="true"/> <br></authentication> <br><sessionState mode="InProc" cookieless="false" timeout="20" /> <br></system.web> <br><location path="Login.aspx"> <br><system.web> <br><authorization> <br><allow users="*" /> <br></authorization> <br></system.web> <br></location> <br></configuration> <br><?xml version="1.0"?> <br><configuration> <br><system.web> <br><authentication mode="Forms" > <br><forms name="AuthLogin" loginUrl="/Login.aspx" protection="All" timeout="360" slidingExpiration="true"/> <br></authentication> <br><sessionState mode="InProc" cookieless="false" timeout="20" /> <br></system.web> <br><location path="Login.aspx"> <br><system.web> <br><authorization> <br><allow users="*" /> <br></authorization> <br></system.web> <br></location> <br></configuration> <br> <br>以上四处设置的优先级为页面级>应用程序级>网站级>服务器级。换句话说,如果页面设置为20分钟,网站设置为120分钟,那么,显然以20分钟为生效的过期时间。 <br><br>另外一个值得注意 的地方。 <br><br>在设置二处,设置会话超时(SessionState)120分钟,而同时用forms认证,设置为“00:15:00”,即15分钟,并且slidingExpirationo为false,则真正生效的Session过期时间是多少呢? <br><br>有效的结果是SessionState的设置,即120分钟。 <br><br>如果有设置Session过期时间没有生效的,请检查以上几处配置 <br><br><strong>网上找到的其它方法 <br><br></strong>1、操作系统:Widnows Server 2003 <br>  步骤:开始——〉管理工具——〉Internet信息服务(IIS)管理器——〉网站——〉默认网站——〉右键“属性”——〉主目录——〉配置——〉选项——〉启用会话状态——〉会话超时(在这儿设置你要的超时时间,单位分钟)。确定即可。 <br>  2、ASP.NET应用程序中Session过期时间的设置 <br>  在ASP.NET这样的Web应用中,Session是用来保存用户状态的常用手段,不过由于服务器内存空间是有限的,所以Session过期时间设置是很有必要的。在ASP.NET中如何设置Session的过期时间呢,很简单,修改web.config配置。 <br>  具体修改方法如下,在web.config中进行如下配置 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>  <system.web> <br>  <sessionState mode="InProc" timeout="30"/> <br>  </system.web> <br> <br>  在这里指的是Session过期时间为30分钟。也就是说30分钟后如果当前用户没有操作,那么Session就会自动过期了。 <br>  3、在调用Session的cs页中,Load事件里面写以下 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>  Session.Timeout = 30; <br> <br>  4、Store session in asp.net state service <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>  <sessionState cookieless="false" timeout="480" mode="StateServer" stateConnectionString="tcpip=127.0.0.1:42424" sqlConnectionString="data source=127.0.0.1;user id=sa;password=" /> <br></li><li> </li><li> </li></ol></pre></li></ol></pre></li></ol></pre></li></ol></pre></li></ol></pre></li></ol></pre></li></ol></pre>

人气教程排行