web状态管理机制

引入:b/s(浏览器/服务器模式)区别于winform的是winform中只加载一次页面构造函数,而b/s中只要点击按钮或者其他涉及后台的操作都会调用后台代码。一般情况下为了防止服务器过载,b/s不会采用常连接,这样可以保持服务器的高性能。但b/s的缺点是连接断开之后会清除服务器资源。 

问题:b/s中如果页面提交,那么重新提交(页面刷新)的时候,前面一个页面中的对象会被销毁,就会造成上一个页面中定义的对象不可用的情况。比如下面的代码。

public partial class Bs : System.Web.UI.Page
    {
        Unit ow ;//unit是长度单位
        Unit oh ;
        protected void Page_Load(object sender, EventArgs e)
        {
            
        }
        protected void Button1_Click(object sender, EventArgs e)//放大
        {
            ow = Panel1.Width;
            oh = Panel1.Height;
            Panel1.Width = 300;
            Panel1.Height = 300;
        }
        protected void Button2_Click(object sender, EventArgs e)//还原
        {
            Panel1.Width = ow;
            Panel1.Height = oh;
        }
    }

放大操作可以实现,但是当点击还原的时候,整个蓝色面板消失。因为此时点击还原按钮,重新提交给服务器,所以服务器把前面一个页面释放了(当然如果是winform程序不会出现这种情况)这是就无法调用前一个页面的ow,oh。

解决方法:

1.静止释放(服务器容易崩溃)

2.使用静态变量

static Unit ow;
static Unit oh;

点击还原按钮可以做到还原,因为实例变量存在于对象中,静态变量存在于类中,释放的是对象。

新问题是当几个用户同时操作此网页的时候会让静态数据紊乱,所以静态数据一般用于统计访问人数,在线人数等。

3.利用状态管理机制(重要)

a:应用程序状态:随网站启动而启动,随网站关闭而关闭。用法如下:

protected void Button1_Click(object sender, EventArgs e)//放大
        {
            Application["ow"] = Panel1.Width;
            Application["oh"] = Panel1.Height;
            Panel1.Width = 300;
            Panel1.Height = 300;
        }

        protected void Button2_Click(object sender, EventArgs e)//还原
        {
            Panel1.Width =(Unit)Application["ow"];
            Panel1.Height = (Unit)Application["oh"];
        }

可以解决,但是属于全局的,和使用static一个道理。

b.会话状态(基本上是所有web(asp,javaweb,jsp)都要用到的一种状态管理机制):先引入连接的概念,连接是客户机一关闭连接就终止,比如学校的英语考试系统如果是webform则用的是连接,而网上在线测试(没有webform程序)用的是会话。而会话是第一次请求就表示会话开始,不管你操作或者是不操作,更甚至是关闭浏览器,你的会话都会在服务器上存在。当你在同一网站下的页面下浏览也是同一个会话,会话是通过session断断续续的进行交流。而一个会话结束的标志就是当本次请求的下次的请求超过20分钟(默认)那么则关闭会话。

session详细信息:https://www.cnblogs.com/ljq2622/p/10910201.html

(同一进程一个浏览器中其他table页都属于一个会话,除了IE不通进程不同会话,但是好像最多3个会话。)刘继光老师调试经验。

protected void Button1_Click(object sender, EventArgs e)//放大
        {
            Session["ow"] = Panel1.Width;
            Session["oh"] = Panel1.Height;
            Panel1.Width = 300;
            Panel1.Height = 300;
        }

        protected void Button2_Click(object sender, EventArgs e)//还原
        {
            Panel1.Width = (Unit)Session["ow"];
            Panel1.Height = (Unit)Session["oh"];
        }

 注:Javaweb中session用法不同,为setattribute和getattribute。

c.视图状态(不怎么用)

protected void Button1_Click(object sender, EventArgs e)
        {
            ViewState["ow"] = Panel1.Width;
            ViewState["oh"] = Panel1.Height;
            Panel1.Width = 400;
            Panel1.Height = 400;
            
        }

        protected void Button2_Click(object sender, EventArgs e)
        {
            Panel1.Width = (Unit)ViewState["ow"];
            Panel1.Height = (Unit)ViewState["oh"];
        }

d,缓存状态(和应用程序状态基本相同)

e,cookie(客户端状态机制,所以cookie保存在浏览器中,一般在浏览器文件夹下是可以找到)

Cookie实际上是一小段的文本信息。客户端请求服务器,如果服务器需要记录该用户状态,就使用response向客户端浏览器颁发一个Cookie。客户端浏览器会把Cookie保存起来。当浏览器再请求该网站时,浏览器把请求的网址连同该Cookie一同提交给服务器。服务器检查该Cookie,以此来辨认用户状态。服务器还可以根据需要修改Cookie的内容。一般cookie关闭浏览器就过期,可以设置过期时间,由于cookie存在本地,所以cookie设置过期时间长短不影响服务器性能。

cookie详细信息:https://www.cnblogs.com/ljq2622/p/10910201.html

常用于记录用户登录账户等:(如下)

protected void Page_Load(object sender, EventArgs e)//从浏览器中传过来的cookie中请求
        {
            if (!IsPostBack)
            {
                if (Request.Cookies["name"] != null && Request.Cookies["password"] != null)
                {

                    TextBox1.Text = Request.Cookies["name"].Value;
                    TextBox2.Text = Request.Cookies["password"].Value;
                }
            }
        }

        protected void btnLogin_Click(object sender, EventArgs e)
        {
            if(!string.IsNullOrEmpty(TextBox1.Text.Trim()))//传给浏览器并且存在本地文件中
            {
                HttpCookie hcName = new HttpCookie("name", TextBox1.Text);
                hcName.Expires = DateTime.Now.AddDays(1);
                Response.Cookies.Add(hcName);
            }
            if (!string.IsNullOrEmpty(TextBox2.Text.Trim()))
            {
                HttpCookie hcPwd = new HttpCookie("password", TextBox2.Text);
                hcPwd.Expires = DateTime.Now.AddDays(1);
                Response.Cookies.Add(hcPwd);
            }
        }

java用法:

  

 1. 创建Cookie对象,绑定数据
            * new Cookie(String name, String value) 
        2. 发送Cookie对象
            * response.addCookie(Cookie cookie) 
        3. 获取Cookie,拿到数据
            * Cookie[]  request.getCookies()

扩展用处:cookies有什么作用呢?现在上许多网站都用新用户注册这一项,有时注册了一下,等到下次再访问该站点时,会自动识别到你,并且向你问好,是不是觉得很亲切?当然这种作用只是表面现象,更重要的是,网站可以利用cookies跟踪统计用户访问该网站的习惯,比如什么时间访问,访问了哪些页面,在每个网页的停留时间等。利用这些信息,一方面是可以为用户提供个性化的服务,另一方面,也可以作为了解所有用户行为的工具,对于网站经营策略的改进有一定参考价值。

cookie除了保存用户信息之外,也是实现session的一种方式:

 (1). 由于HTTP协议是无状态的协议,所以服务端需要记录用户的状态时,就需要用某种机制来识具体的用户,这个机制就是Session.典型的场景比如购物车,当你点击下单按钮时,由于HTTP协议无状态,所以并不知道是哪个用户操作的,所以服务端要为特定的用户创建了特定的Session,用用于标识这个用户,并且跟踪用户,这样才知道购物车里面有几本书。这个Session是保存在服务端的,有一个唯一标识。在服务端保存Session的方法很多,内存、数据库、文件都有。集群的时候也要考虑Session的转移,在大型的网站,一般会有专门的Session服务器集群,用来保存用户会话,这个时候 Session 信息都是放在内存的,使用一些缓存服务比如Memcached之类的来放 Session。
(2). 思考一下服务端如何识别特定的客户?这个时候Cookie就登场了。每次HTTP请求的时候,客户端都会发送相应的Cookie信息到服务端。实际上大多数的应用都是用 Cookie 来实现Session跟踪的,第一次创建Session的时候,服务端会在HTTP协议中告诉客户端,需要在 Cookie 里面记录一个Session ID,以后每次请求把这个会话ID发送到服务器,我就知道你是谁了。有人问,如果客户端的浏览器禁用了 Cookie 怎么办?一般这种情况下,会使用一种叫做URL重写的技术来进行会话跟踪,即每次HTTP交互,URL后面都会被附加上一个诸如 sid=xxxxx 这样的参数,服务端据此来识别用户。
f,查询字符串(客户端状态管理机制)????????????????
 
 
原文地址:https://www.cnblogs.com/ljq2622/p/9997571.html