• Asp.Net_的传值跟存储值操作


    页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值、存储对象传值、ajax、类、model、表单等。但是一般来说,常用的较简单有QueryString,Session,Cookies,Application,Server.Transfer。

      一、QueryString

      QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中。如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法。但是对于传递数组或对象的话,就不能用这个方法了。

      这种方法的优点:1.使用简单,对于安全性要求不高时传递数字或是文本值非常有效。
      这种方法的缺点:1.缺乏安全性,由于它的值暴露在浏览器的URL地址中的。
              2.不能传递对象。

      使用方法:1.在源页面的代码中用需要传递的名称和值构造URL地址。
           2.在源页面的代码用Response.Redirect(URL);重定向到上面的URL地址中。
           3.在目的页面的代码使用Request.QueryString["name"];取出URL地址中传递的值。

      例子:(1)a.aspx

    复制代码
    private void Button1_Click(object sender, System.EventArgs e) 
    { 
      string s_url; 
      s_url = "b.aspx?name=" + Label1.Text; 
      Response.Redirect(s_url); 
    }
    复制代码

      (2)b.aspx

    private void Page_Load(object sender, EventArgs e) 
    { 
      Label2.Text = Request.QueryString["name"]; 
    }

      二、Session

      想必这个肯定是大家使用中最常见的用法了,其操作与Application类似,作用于用户个人,所以,过量的存储会导致服务器内存资源的耗尽。

      优点:1.使用简单,不仅能传递简单数据类型,还能传递对象。
         2.数据量大小是不限制的。

      缺点:1.在Session变量存储大量的数据会消耗较多的服务器资源。

         2.容易丢失。

      使用方法:1.在源页面的代码中创建你需要传递的名称和值构造Session变量:Session["Name"]="Value(Or Object)";

           2.在目的页面的代码使用Session变量取出传递的值。Result = Session["Nmae"]

      注意:session不用时可以销毁它,销毁的方法是:清除一个:Session.Remove("session名");

                             清除所有:Session.Clear();

      例子:(1)a.aspx

    private void Button1_Click(object sender, System.EventArgs e) 
    { 
      Session["name"] = Label.Text; 
    }

      (2)b.aspx

    private void Page_Load(object sender, EventArgs e) 
    { 
      string name; 
      name = Session["name"].ToString(); 
    }

      三、Cookie

      这个也是大家常使用的方法,Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用户的ID,用户的偏好等,用户下次访问就可以通过检索获得以前的信息。所以Cookie也可以在页面间传递值。Cookie通过HTTP头在浏览器和服务器之间来回传递的。Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式。

      与Session一样,其是什对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在服务器端的。而且Cookie的使用要配合ASP.NET内置对象Request来使用。

      优点:1.使用简单,是保持用户状态的一种非常常用的方法。比如在购物网站中用户跨多个页面表单时可以用它来保持用户状态。

      缺点:1.常常被人认为用来收集用户隐私而遭到批评。

         2.安全性不高,容易伪造。

      

      使用方法:1.在源页面的代码中创建你需要传递的名称和值构造Cookie对象:

    HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");
    Response.Cookies.Add(cookie); 

          2.在目的页面的代码使用Cookie对象取出传递的值:Result = Request.Cookies[ "myCookie" ].Value;

      例子:(1)a.aspx

    private void Button1_Click(object sender, System.EventArgs e)
    {
      HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");
      Response.Cookies.Add(objCookie); 
    }

      (2)b.aspx

    string myName1Value;
    myName1Value = Request.Cookies[ "myCookie" ].Value;

      四、Application

      Application对象的作用范围是整个全局,也就是说对所有用户都有效。它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中对它进行存取。它和Session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。

      可能有人会问,既然所有用户都可以使用application变量,那他可以用在什么场合呢?这里举个例子:网站访问数。多个请求访问时都可以对它进行操作。

      优点:1.使用简单,消耗较少的服务器资源。

         2.不仅能传递简单数据,还能传递对象。

         3.数据量大小是不限制的。

      缺点:1.作为全局变量容易被误操作。所以单个用户使用的变量一般不能用application。

      使用方法:1.在源页面的代码中创建你需要传递的名称和值构造Application变量:Application["Nmae"]="Value(Or Object)";

           2.在目的页面的代码使用Application变量取出传递的值。Result = Application["Nmae"]

      注意:常用lock和unlock方法用来锁定和解锁,为了防止并发修改。

      例子:(1)a.aspx

    private void Button1_Click(object sender, System.EventArgs e) 
    { 
      Application["name"] = Label1.Text; 
    }

      (2)b.aspx

    复制代码
    private void Page_Load(object sender, EventArgs e) 
    { 
      string name; 
      Application.Lock(); 
      name = Application["name"].ToString(); 
      Application.UnLock(); 
    }
    复制代码

      五、Server.Transfer

      这个才可以说是面象对象开发所使用的方法,其使用Server.Transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效。

      Server.Transfer是从当前的ASPX页面转到新的ASPX页面,服务器端执行新页并输出,在新页面中通过Context.Handler来获得前一个页面传递的各种数据类型的值、表单数据、QueryString.由于重定向完全在服务器端完成,所以客户端浏览器中的URL地址是不会改变的。调用Server.Transfer时,当前的ASPX页面终止执行,执行流程转入另一个ASPX页面,但新的ASPX页面仍使用前一ASPX页面创建的应答流。

      ps:比较Server.Transfer和Response.Redirect的区别。
        (1)Server.Transfer在服务器端完成,所以客户端浏览器中的URL地址是不会改变的;Response.Redirect是客户端完成,向服务器端提出新的页面处理请求,所以客户端浏览器中的URL地址是会改变的。
        (2)Server.Transfer在服务器端完成,不需要客户端提出请求,减少了客户端对服务器端提出请求。[2]
        (3)Server.Transfer只能够转跳到本地虚拟目录指定的页面,也就是工程项目中的页面,而Response.Redirect则十分灵活,可以跳转到任何URL地址。
        (4)Server.Transfer可以将前一个页面的各种类型的值传到新的页面;Response.Redirect则只能借助URL中带参数或是结合上面四种办法把各种类型的值传到新的页面。

      优点:1.直接在服务器端重定向,使用简单方便,减少了客户端对服务器端提出请求。

         2.可以传递各种数据类型的值和控件的值。

      缺点:1.客户端浏览器中的URL地址是不改变,会导致在新的页面可能出现一些意想不到的问题。比如如果源页面和目的页面不在同一个虚拟目录或其子目录下,那么使用相对路径的图片、超链接都会导致错误的指向。

      使用方法:1.在源页面的代码中,使用Page类的Server.Transfer跳到另一个页面传递页面数据:Server.Transfer("b.aspx","false")。

           2.在目的页面中,使用Context.Handler来接收数据:FormerPage formerPage = (FormerPage)Context.Handler; 然后用formerPage的属性和方法来获取前一个页面的值,或者直接用Context.Items["myParameter "]

      例子:(1)a.aspx

    复制代码
    public string Name 
    { 
      get{ return Label1.Text;} 
    } 
    private void Button1_Click(object sender, System.EventArgs e) 
    { 
      Server.Transfer("b.aspx"); 
    }
    复制代码

        (2)b.aspx

    复制代码
    private void Page_Load(object sender, EventArgs e) 
    { 
      a newWeb; //实例a窗体 
      newWeb = (source)Context.Handler; 
      string name; 
      name = newWeb.Name; 
    }
    复制代码

      以上就是常用的几种页面间传值的方法,我一般使用session和querystring来传值,少数情况会使用到cookie。本篇文章仅仅是介绍这几种方法的使用方法,内部原理没有过多的解释,关于session的存储方式:

    1、在web.config中配置Session

      Web.config文件中的Session配置信息:

    private void Page_Load(object sender, EventArgs e) 
    { 
      a newWeb; //实例a窗体 
      newWeb = (source)Context.Handler; 
      string name; 
      name = newWeb.Name; 
    }
    Code

    mode 设置将Session信息存储到哪里:

        — Off 设置为不使用Session功能;

        — InProc 设置为将Session存储在进程内,就是ASP中的存储方式,这是默认值;

        — StateServer 设置为将Session存储在独立的状态服务中;

        — SQLServer 设置将Session存储在SQL Server中。

      cookieless 设置客户端的Session信息存储到哪里:

        — ture 使用Cookieless模式;这时客户端的Session信息就不再使用Cookie存储了,而是将其通过URL存储。比如网址为http://localhost/MyTestApplication/(ulqsek45heu3ic2a5zgdl245)/default.aspx

        — false 使用Cookie模式,这是默认值。

      timeout 设置经过多少分钟后服务器自动放弃Session信息。默认为20分钟。

     stateConnectionString 设置将Session信息存储在状态服务中时使用的服务器名称和端口号,例如:"tcpip=127.0.0.1:42424”。当mode的值是StateServer是,这个属性是必需的。(42424是默认端口)。

      sqlConnectionString 设置与SQL Server连接时的连接字符串。例如"data source=localhost;Integrated Security=SSPI;Initial Catalog=northwind"。当mode的值是SQLServer时,这个属性是必需的。

      stateNetworkTimeout 设置当使用StateServer模式存储Session状态时,经过多少秒空闲后,断开Web服务器与存储状态信息的服务器的TCP/IP连接的。默认值是10秒钟。

    下面来说下用StateServer和SqlServer来存储Session的方法

      2.1 StateServer

      第1步是打开状态服务。依次打开“控制面板”→“管理工具”→“服务”命令,找到ASP.NET状态服务一项,右键单击服务选择启动。

      如果你正式决定使用状态服务存储Session前,别忘记修改服务为自启动(在操作系统重启后服务能自己启动)以免忘记启动服务而造成网站Session不能使用

      第2步,在system.web节点中加入:stateNetworkTimeout="20">  stateConnectionString表示状态服务器的通信地址(IP:服务端口号)。由于我们现在在本机进行测试,这里设置成本机地址127.0.0.1。状态服务默认的监听端口为42422。当然,您也可以通过修改注册表来修改状态服务的端口号。

      (修改注册表来修改状态服务的端口号的方法:在运行中输入regedit启动注册表编辑器—依次打开HKEY_LOCAL_MACHINESYSTEMCurrentControlSetServicesaspnet_stateParameters节点,双击Port选项—选择基数为十进制,然后输入一个端口号即可。)

     2.2 SqlServer

      在SQL Server中执行一个叫做InstallSqlState.sql的脚本文件。这个脚本文件将在SQL Server中创建一个用来专门存储Session信息的数据库,及一个维护Session信息数据库的SQL Server代理作业。我们可以在以下路径中找到那个文件:

    [system drive]winntMicrosoft.NETFramework[version] 

    然后打开查询分析器,连接到SQL Server服务器,打开刚才的那个文件并且执行。稍等片刻,数据库及作业就建立好了。这时,你可以打开企业管理器,看到新增了一个叫ASPState的数据库。

      修改mode的值改为SQLServer。注意,还要同时修改sqlConnectionString的值,格式为:sqlConnectionString="data source=localhost; Integrated Security=SSPI;"(这种是通过windows集成身份验证)

     2、遍历以及销毁Session

    4.1遍历:

    System.Collections.IEnumerator SessionEnum = Session.Keys.GetEnumerator();
    while (SessionEnum.MoveNext())
    {
    Response.Write(Session[SessionEnum.Current.ToString()].ToString() + " ");
    }

      4.2 销毁:Session.Abandon()。

  • 相关阅读:
    vector容器(一)
    螺旋数组实现
    zigzag数组实现
    HDU 1496
    HDU 1381 Crazy Search
    什么叫软核,固核,硬核?
    “杜拉拉思维模式”之六:小组面试提升术
    硬件工程师电路设计必须紧记的十大要点
    面试的“群殴”宝典
    三段式状态机 [CPLD/FPGA]
  • 原文地址:https://www.cnblogs.com/ingstyle/p/4081294.html
Copyright © 2020-2023  润新知