浅析ASP.NET的状态保持

ASP.NET的状态保持:
1.viewstate:隐藏域,记录服务器端控件的状态,适用于页面不关闭的情况下多次与服务器交互,页面自己给自己传值;文本框的改变事件、IspostBack也依赖viewstate。

2.cookie:一小段文本,存储在客户端(浏览器)中,当请求某个网页的时候,浏览器会将与这个网页相关的cookie取出,一并发送到服务端;存放在浏览器内存(会话cookie,无过期时间 ;浏览器关闭cookie即过期)和磁盘(域cookie,可以设置过期时间)中。注意,如果不给cookie设置过期时间,则此cookie存储在浏览器中,浏览器关闭的时候,cookie即失效;如果设置过期时间,则为域cookie,存储在磁盘中,直到过期时间到来才会失效。(cookie是与域相关的,不同域的cookie不相互使用,主域的cookie子域都可以访问,子域的cookie主域是访问不到的 )

-> cookie的使用:
1.Response.cookie["Name"].value;

2.HttpCookie cookie=new HttpCookie("name","value");
cookie.Expires=DateTime.Now.AddHours(1);
Response.Cookies.Add(cookie);

Cookie限制总的大小是4kb 一个网站总数不超过20个,最多300个左右。也就是Cookie是有很多限制的一般放少量的数据。Cookie的适用场景:记住我!

 

3.Session:会话!持续的一段时间。Session存储在服务器端,使用场景用于页面间传值。

Session.Abandon(); //销毁服务器端的Session对象
Session.Clear();//清空服务端的Session对象里的键值对,
Session对象并没有从Session池里销毁

一般处理程序使用Session的话:要实现接口(IRequiresSessionState)
只是读取Session的话,不需要实现接口,此接口就是一个标志

Session机制并不是Http协议规定

滑动窗口机制,在第一次向服务器发送请求的时候,服务器解析发现没有SessionID就会在响应的时候加入SessionID,那么在会话时间范围内再次向服务器发送请求,服务器解析请
求报文,发现有SessionID,就会认同第二次请求和上一次请求在同一次会话当中,同时将会话时间再向后延迟一段时间;如果超过Session规定的时间再访问则服务器不认为和上一次会话是
同一次会话,则会在响应报文重新给一个SessionID来维持会话。

Session:缺陷(问题):当前服务器重启,Session就会丢失。
注意,禁用Cookie后,Session的id是通过URL进行传递的。

 

4.Application,类似于全局变量,通过在Global文件中的Session_Start和Session_End事件对Application["key"]设置值可以实现“在线人数统计”的功能。

你可能感兴趣的:(asp.net)