首頁  >  文章  >  後端開發  >  ASP.NET頁面之間傳遞值的幾種方式

ASP.NET頁面之間傳遞值的幾種方式

PHPz
PHPz原創
2017-03-05 12:27:361565瀏覽

頁面傳值是學習asp.net初期都會面臨的一個問題,總的來說有頁面傳值、儲存物件傳值、ajax、類別、model、表單等。但一般來說,常用的較簡單有QueryString,Session,Cookies,Application,Server.Transfer。在面試的時候,常常會遇到這樣的問題,其實我們會對其中的幾種方法比較熟悉,因為專案中經常使用。但是要全面的回答ASP.NET中頁面傳值的方式,估計往往很難全面。

  一、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名");

                                                    都會清除所有:S        

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; 
}


 

  以上就是ASP.NET常用的幾種頁間傳值的方法,我通常使用session和querystring來傳值,少數情況會使用到cookie。本篇文章只是介紹這幾種方法的使用方法,內部原理沒有過多的解釋,關於session的存儲方式請參見:session的存儲方式和配置文件


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn