伦理片hd-伦理片 在线播放-伦理片 在线-伦理免费在线观看-综合图片区-综合婷婷

訂閱本欄目 RSS您所在的位置: 深山工作室 > asp.net > 正文

ASP.NET 2.0跨網(wǎng)頁(yè)提交的三法

博客網(wǎng) 2008/4/17 20:13:03 深山行者 字體: 瀏覽 28605

當(dāng)在一個(gè)ASP.NET Web頁(yè)面中進(jìn)行操作時(shí),在默認(rèn)情況下向當(dāng)前頁(yè)進(jìn)行提交。這種行為在ASP.NET出現(xiàn)之前并沒有什么關(guān)系,但在ASP.NET中當(dāng)我們想向另外一個(gè) Web頁(yè)提交一個(gè)Web Form時(shí)該如何做呢?在ASP.NET1.0中這個(gè)問題變得很難解決,但在ASP.NET2.0中為開發(fā)人員提供了更容易的解決的技術(shù):跨網(wǎng)頁(yè)提交。這種技術(shù)允許一個(gè)網(wǎng)頁(yè)在提交數(shù)據(jù)時(shí)提交給另外的一個(gè)頁(yè)面。在跨網(wǎng)頁(yè)提交中,用于初始化提交代碼的頁(yè)面叫源頁(yè)面,而客戶提交的頁(yè)面叫目標(biāo)頁(yè)面。

  為了方便起見,目標(biāo)頁(yè)面仍然獲得原頁(yè)面提交的所有數(shù)據(jù)。換名話說(shuō),從技術(shù)觀點(diǎn)出發(fā),我們可以用同樣的方式處理其他ASP.NET頁(yè)面提交的數(shù)據(jù)。

  這個(gè)新特性意味著ASP.NET2.0開發(fā)人員目前有三種可供選擇的技術(shù)來(lái)將數(shù)據(jù)從一個(gè)web頁(yè)面?zhèn)魉偷搅硗庖粋€(gè)頁(yè)面。這三種方法是:響應(yīng)重定向,服務(wù)端傳輸和新的跨網(wǎng)頁(yè)提交特性。我們可以已經(jīng)熟悉前兩種技術(shù)了,因此,我們只是簡(jiǎn)要地復(fù)習(xí)一下它們,然后我們會(huì)將主要精力放到學(xué)習(xí)如何使用跨網(wǎng)頁(yè)提交特性,以及闡述一下這種方法和響應(yīng)重定向以及服務(wù)傳輸方式有什么不同。

  一、響應(yīng)重定向方法

  響應(yīng)重定向方法是目前為止將一個(gè)網(wǎng)頁(yè)重定向到另一個(gè)網(wǎng)頁(yè)的最簡(jiǎn)單的方法的最簡(jiǎn)單的方法。當(dāng)Web服務(wù)器接到一個(gè)重定向請(qǐng)求后,它會(huì)將一個(gè)響應(yīng)頭送給客戶端,這將導(dǎo)致客戶端發(fā)送一個(gè)新的請(qǐng)求到服務(wù)器。按句話說(shuō),一個(gè)重定向請(qǐng)求實(shí)際上是兩個(gè)請(qǐng)求響應(yīng):一個(gè)是最初的請(qǐng)求響應(yīng),另一個(gè)是新的重定向請(qǐng)求響應(yīng)。

  在ASP.NET中實(shí)現(xiàn)重定向很容易。下面的代碼演示了如何使用Response.Redirect方法實(shí)現(xiàn)網(wǎng)頁(yè)重定向:

   protected void Redirect_Click(object sender, EventArgs e)
  {

  Response.Redirect("menu.aspx");

  }

  要注意的是重定向請(qǐng)求只是一個(gè)GET請(qǐng)求,這就意味著我們不能從源頁(yè)中通過(guò)重定向命令提交數(shù)據(jù)。但是我們可以在重定向中使用查詢字符串來(lái)傳遞數(shù)據(jù)。如下面代碼所示:

   protected void Redirect_Click(object sender, EventArgs e)
  {

  Response.Redirect("menu.aspx?userName=" + UserName.Text));

  }

  上面的例子將一個(gè)查詢字符串作為參數(shù)傳遞給了Response.Redirect方法的目標(biāo)URL。我們可以通過(guò)如下的代碼獲得源數(shù)據(jù)。  

protected void Page_Load(object sender, EventArgs e)
  {

  string userName = Request["userName"];

  }

  二、服務(wù)器傳輸方法

  和依賴于客戶端向另一個(gè)新頁(yè)發(fā)請(qǐng)求不同,服務(wù)器傳輸是一種服務(wù)器重定向技術(shù),這種技術(shù)通過(guò)簡(jiǎn)單的改變Web服務(wù)器所處理的代碼來(lái)達(dá)到請(qǐng)求一個(gè)新頁(yè)的目的。當(dāng)被請(qǐng)求頁(yè)和源頁(yè)面在同一個(gè)服務(wù)器時(shí),服務(wù)器傳輸要比Response.Redirect方法更有效,這是由于這種技術(shù)可以避免額外的開銷,僅僅使用服務(wù)器的資源就可以進(jìn)行重定向。要注意的這種技術(shù)有一個(gè)副作用,在頁(yè)面進(jìn)行重定向時(shí),客戶端的URL仍然會(huì)保持源頁(yè)面的URL,這可能會(huì)使客戶認(rèn)為他們所獲得的數(shù)據(jù)是源頁(yè)面產(chǎn)生的。當(dāng)然,在大多數(shù)情況下,這不是問題,但是這將使調(diào)試變得更困難。

  Server.Transfer方法還可以保存初始頁(yè)的HttpContext。因此,目標(biāo)頁(yè)可以訪問源頁(yè)面的值。我們可以使用FormsCollection屬性來(lái)從目標(biāo)頁(yè)面中獲得源頁(yè)面的值。首先,要確定我們使用了被重載的方法,這個(gè)方法有兩個(gè)參數(shù):目標(biāo)URL和一個(gè)Boolean類型的值,告訴服務(wù)器是否保存用于描述源頁(yè)面值的 Form。如下面的代碼所示:

   Server.Transfer("Menu.aspx",true);
  然后,我們?cè)谀繕?biāo)頁(yè)面中獲得一個(gè)叫txtUserName的Textbox控件的值的代碼如下:

   object obj = Request.Form["txtUserName"];

  三、Response.Redirect和Server.Transfer的比較

  由于Response.Redirect方法要進(jìn)行兩次請(qǐng)求響應(yīng)操作,因此,我們應(yīng)該在對(duì)性能要求高的網(wǎng)站盡量避免使用這種方法。然而,只從技術(shù)上說(shuō),使用redirect方式確實(shí)可以從一個(gè)網(wǎng)頁(yè)跳到另一個(gè)網(wǎng)頁(yè)。相比之下,Server.Transfer會(huì)更有效率,但是跳轉(zhuǎn)的范圍僅限于同一個(gè)Web服務(wù)器的不同網(wǎng)頁(yè)。從本質(zhì)上說(shuō),我們可以使用Server.Transfer來(lái)消除不必要的請(qǐng)求響應(yīng)操作。如果我們需要重定位到不同服務(wù)器的網(wǎng)頁(yè),就需要使用Response.Redirect方法。

  四、跨頁(yè)提交概述

  在ASP.NET 2.0中,我們可以通過(guò)實(shí)現(xiàn)IbuttonControl接口提交給不同的WebForm,來(lái)實(shí)現(xiàn)跨網(wǎng)頁(yè)的提交。和Response.Redirect類似,跨網(wǎng)頁(yè)提交是一個(gè)基于客戶端的傳輸機(jī)制,但也有點(diǎn)象Server.Transfer,目標(biāo)網(wǎng)頁(yè)也可以訪問源網(wǎng)頁(yè)的數(shù)據(jù)。為了使用跨網(wǎng)頁(yè)提交,我們需要在源網(wǎng)頁(yè)中的PostBackUrl屬性中指定目標(biāo)URL。

  五、實(shí)現(xiàn)跨網(wǎng)頁(yè)提交

  這部分將討論一下如何在 ASP.NET2.0中實(shí)現(xiàn)跨網(wǎng)頁(yè)提交。為了開始我們的學(xué)習(xí),假設(shè)有兩個(gè)Web頁(yè),一個(gè)是源Web頁(yè),另一個(gè)是目標(biāo)Web頁(yè)。在源網(wǎng)頁(yè)中初始化了使用按鈕進(jìn)行的跨網(wǎng)頁(yè)提交操作。我們首先必須設(shè)置目標(biāo)網(wǎng)頁(yè)按鈕的PostBackUrl屬性,順便說(shuō)一句,所有實(shí)現(xiàn)了 System.Web.UI.WebControls.IbuttonControl接口的Web控件都有跨網(wǎng)頁(yè)提交的特性。下面的代碼將演示這一過(guò)程。

   PostBackUrl="~/target.aspx" text = "Post to a target page"/>
  當(dāng)我們?cè)O(shè)置PostBackUrl屬性時(shí),ASP.NET框架將相應(yīng)的控件綁定到一個(gè)新的叫WebForm_DoPostBackWithOptions的JavaScript函數(shù),產(chǎn)生的Html代碼如下:

   onclick="javascript:WebForm_DoPostBackWithOptions(
  new WebForm_PostBackOptions("btnSubmit", "", false, "",

  "Target.aspx", false, false))" id="btnSubmit" />

  對(duì)于上面的html代碼來(lái)說(shuō),當(dāng)用戶單擊按鈕時(shí),瀏覽器將提交目標(biāo)URL(Target.aspx),而不是源URL。

六、從目標(biāo)頁(yè)面中獲得源頁(yè)面控件的值

  ASP.NET2.0提供了一個(gè)叫PreviousPage的新的屬性,這個(gè)屬性無(wú)論在何時(shí)當(dāng)前頁(yè)面進(jìn)行跨網(wǎng)頁(yè)提交操作時(shí)都會(huì)指向源頁(yè)面。要注意的是,當(dāng)源頁(yè)面和目標(biāo)頁(yè)面在不同的應(yīng)用程序中時(shí),這個(gè)屬性包含null(這個(gè)null并不是未初始化的意思)。還有要注意的是當(dāng)目標(biāo)網(wǎng)頁(yè)訪問 PreviousPage屬性時(shí)可以獲得源頁(yè)面的數(shù)據(jù),ASP.NET運(yùn)行時(shí)裝載并執(zhí)行了源頁(yè)面。這將引發(fā)ProcessChildRequest事件的發(fā)生。而且,它還會(huì)引發(fā)Page_Init事件、Page_Load和任何其他的源頁(yè)面按鈕單擊事件。

  因此,我們要避免由于不小心進(jìn)行誤操作,所以最好通過(guò)IsCrossPostBack屬性來(lái)確認(rèn)是否為一個(gè)跨網(wǎng)頁(yè)提交發(fā)生,如果這個(gè)屬性值為true,那么目標(biāo)網(wǎng)頁(yè)就是通過(guò)一個(gè)跨網(wǎng)頁(yè)提交動(dòng)作而調(diào)用的。如果是通過(guò)另外一種方式調(diào)用的(如一般的請(qǐng)求、Response.Redirect或是一個(gè)Server.Transfer),這個(gè)屬性的值為false。下面的例子演示了如何使用這個(gè)屬性。

   if ( PreviousPage.IsCrossPagePostBack)
  {

  //執(zhí)行代碼

  }

  這個(gè)PreviousPage屬性在Server.Transfer和跨網(wǎng)頁(yè)提交中都可以使用。在ASP.NET2.0中,我們可以在調(diào)用Server.Transfer操作后使用PreviousPage屬性在目標(biāo)頁(yè)面中來(lái)獲得源頁(yè)面的數(shù)據(jù),代碼如下:

   {
  Server.Transfer("menu.aspx");

  }

  protected void Redirect_Click(object sender, EventArgs e)

  在這個(gè)接收面中我們現(xiàn)在可以獲得Web頁(yè)面的數(shù)據(jù),代碼如下:

   protected void Page_Load(object sender, EventArgs e)
  {

  if (PreviousPage != null)

  {

  TextBox txtBox = (TextBox)

  PreviousPage.FindControl("txtUserName");

  if (textBox != null)

  string userName = textBox.Text;

  //其他可執(zhí)行的代碼

  }

  }

  要注意的是上面的代碼必須將txtUserName控件轉(zhuǎn)換為TextBox類型,以便可以訪問其中的值。

七、使用PreviousPageType

  PreviousPageType屬性提供了在跨網(wǎng)頁(yè)操作中訪問源頁(yè)面的強(qiáng)類型能力,下面讓我們演示一下如何不通過(guò)任何類型轉(zhuǎn)換來(lái)從源頁(yè)面中獲得控件值。代碼如下:

   < asp:Textbox ID="txtUserName" Runat="server" />   < asp:Textbox ID="txtPassword" Runat="server" />   < asp:Button ID="Submit" Runat="server" Text="Login"   PostBackUrl="Menu.aspx" />

  要注意的是單擊按鈕可以重定向到一個(gè)叫“Menu.asp”的目標(biāo)頁(yè)。這個(gè)目標(biāo)頁(yè)可以使用如下的代碼獲得用戶名和密碼:

  八、保存視圖狀態(tài)

  對(duì)于跨網(wǎng)頁(yè)提交來(lái)說(shuō),ASP.NET2.0 內(nèi)嵌了一個(gè)叫__POSTBACK的隱藏字段,這個(gè)字段包含了關(guān)于源頁(yè)面的視圖信息 -- 也就是由源頁(yè)面提供了,包含了一個(gè)帶有一個(gè)非空PostBackUrl屬性值的服務(wù)端控件。目標(biāo)頁(yè)可以使用__POSTBACK中的信息來(lái)獲得源頁(yè)面的視圖狀態(tài)信息。代碼如下:

   if(PreviousPage!=null && PreviousPage.IsCrossPagePostBack &&
  PreviousPage.IsValid)

  {

  TextBox txtBox = PreviousPage.FindControl("txtUserName");

  Response.Write(txtBox.Text);

  }

  在上面的代碼中核對(duì)了用于確保PreviousPage屬性不為null的檢查代碼。順便提一下,如果目標(biāo)頁(yè)和源頁(yè)面不在同一個(gè)應(yīng)用程序中,這個(gè) PreviousPage屬性的值為null。只有在進(jìn)行跨網(wǎng)頁(yè)提交操作時(shí),IsCrossPagePostBack屬性才為true。

  這個(gè)跨網(wǎng)頁(yè)提交的特性,是ASP.NET2.0中最強(qiáng)有力的特性之一,這種技術(shù)將允許在一個(gè)頁(yè)面中提交到另外一個(gè)頁(yè)面,并且可以在目標(biāo)頁(yè)面地?zé)o縫地操作源頁(yè)面中的數(shù)據(jù)。

相關(guān)閱讀
利用javascript靜態(tài)改變表單指向與提交方式
python中 f 用法
深山留言板(激情圣誕集合五套模板)v4.4
windows2003的IIS文件上傳大小限制的解決方案
asp利用函數(shù)生成指定位數(shù)的隨機(jī)數(shù)字符串
旅行社管理系統(tǒng)商業(yè)版3.0發(fā)布
點(diǎn)擊復(fù)選框自動(dòng)寫入textarea,去掉自動(dòng)刪掉,適合做(網(wǎng)站來(lái)源,網(wǎng)站作者)
旅行社手機(jī)網(wǎng)站模板7
共有0條關(guān)于《ASP.NET 2.0跨網(wǎng)頁(yè)提交的三法》的評(píng)論
發(fā)表評(píng)論
正在加載評(píng)論......
返回頂部發(fā)表評(píng)論
呢 稱:
表 情:
內(nèi) 容:
評(píng)論內(nèi)容:不能超過(guò) 1000 字,需審核,請(qǐng)自覺遵守互聯(lián)網(wǎng)相關(guān)政策法規(guī)。
驗(yàn)證碼: 驗(yàn)證碼 
網(wǎng)友評(píng)論聲明,請(qǐng)自覺遵守互聯(lián)網(wǎng)相關(guān)政策法規(guī)。

您發(fā)布的評(píng)論即表示同意遵守以下條款:
一、不得利用本站危害國(guó)家安全、泄露國(guó)家秘密,不得侵犯國(guó)家、社會(huì)、集體和公民的合法權(quán)益;
二、不得發(fā)布國(guó)家法律、法規(guī)明令禁止的內(nèi)容;互相尊重,對(duì)自己在本站的言論和行為負(fù)責(zé);
三、本站對(duì)您所發(fā)布內(nèi)容擁有處置權(quán)。

更多信息>>欄目類別選擇
百度小程序開發(fā)
微信小程序開發(fā)
微信公眾號(hào)開發(fā)
uni-app
asp函數(shù)庫(kù)
ASP
DIV+CSS
HTML
python
更多>>同類信息
ASP.NET中Cookie編程的基礎(chǔ)知識(shí)
ASP.NET 2.0跨網(wǎng)頁(yè)提交的三法
ASP.NET 2和IIS 7.0發(fā)生不兼容變化
ASP.NET中文亂碼問題的解決。
ASP.Net 2.0中的5個(gè)數(shù)據(jù)控件
根據(jù)頁(yè)面模板動(dòng)態(tài)生成html頁(yè)面
更多>>最新添加文章
dw里面查找替換使用正則刪除sqlserver里面的CONSTRAINT
Android移動(dòng)端自動(dòng)化測(cè)試:使用UIAutomatorViewer與Selenium定位元素
抖音直播音掛載小雪花 懂車帝小程序
javascript獲取瀏覽器指紋可以用來(lái)做投票
火狐Mozilla Firefox出現(xiàn):無(wú)法載入您的Firefox配置文件 它可能已經(jīng)丟失 或是無(wú)法訪問 問題解決集合處理辦法
在Android、iOS、Windows、MacOS中微信小程序的文件存放路徑
python通過(guò)代碼修改pip下載源讓下載庫(kù)飛起
python里面requests.post返回的res.text還有其它的嗎
更多>>隨機(jī)抽取信息
一個(gè)非常不錯(cuò)的文字的提示
asp中利用split,instr組合去除二維數(shù)組中重復(fù)項(xiàng)
用javascript美化Select,并獲取相應(yīng)的值
uni-app實(shí)現(xiàn)上拉加載,下拉刷新(下拉帶動(dòng)畫)
阿里云短信驗(yàn)證碼簽名不合法isv.SMS_SIGNATURE_ILLEGAL
黑色精靈留言板模板
主站蜘蛛池模板: 国产手机精品自拍视频 | eeuss影院在线奇兵区1页 | 亚洲aⅴ久久久噜噜噜噜 | 91小视频在线观看 | 久久男人的天堂 | 最好韩国日本高清 | 77色视频在线 | 香蕉网在线观看 | 国产美女在线看 | 香蕉视频亚洲 | 中文一区二区 | 国产盗摄精品一区二区三区 | 一区二区三区欧美 | 男女做视频网站免费观看 | 日日爱夜夜爱 | 在线看精品 | 亚洲2020天天堂在线观看 | 久久久综合香蕉尹人综合网 | 色视频在线| 妈妈的朋友3在线完整视频 妈妈的朋友3线完整视频免费观看 | 最新国产一区二区精品久久 | 欧美乱妇高清视频免欢看关 | 91黄视频在线观看 | 免费在线日韩 | 亚洲一区二区免费在线观看 | 毛片视频网站 | 国产亚洲成在线播放va | 久久综合色之久久综合 | 国产成人综合亚洲欧美在 | 国产大片线上免费看 | 99热国产在线观看 | 久久精品国产福利国产秒 | 久久99免费 | 色偷偷久久 | 日韩在线观看免费 | 国产午夜不卡在线观看视频666 | 手机成人免费视频 | 四虎网站在线观看 | 黄页视频免费观看 | 成年黄色片 | 亚洲欧美综合日韩字幕v在线 |