99热热热_国产成人自拍一区_欧美一级网站_99热在线播放_国产精品乱码一区二区三区_久久精品国产一区二区三区

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

ASP.NET 2.0跨網頁提交的三法

博客網 2008/4/17 20:13:03 深山行者 字體: 瀏覽 28934

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

  為了方便起見,目標頁面仍然獲得原頁面提交的所有數據。換名話說,從技術觀點出發,我們可以用同樣的方式處理其他ASP.NET頁面提交的數據。

  這個新特性意味著ASP.NET2.0開發人員目前有三種可供選擇的技術來將數據從一個web頁面傳送到另外一個頁面。這三種方法是:響應重定向,服務端傳輸和新的跨網頁提交特性。我們可以已經熟悉前兩種技術了,因此,我們只是簡要地復習一下它們,然后我們會將主要精力放到學習如何使用跨網頁提交特性,以及闡述一下這種方法和響應重定向以及服務傳輸方式有什么不同。

  一、響應重定向方法

  響應重定向方法是目前為止將一個網頁重定向到另一個網頁的最簡單的方法的最簡單的方法。當Web服務器接到一個重定向請求后,它會將一個響應頭送給客戶端,這將導致客戶端發送一個新的請求到服務器。按句話說,一個重定向請求實際上是兩個請求響應:一個是最初的請求響應,另一個是新的重定向請求響應。

  在ASP.NET中實現重定向很容易。下面的代碼演示了如何使用Response.Redirect方法實現網頁重定向:

   protected void Redirect_Click(object sender, EventArgs e)
  {

  Response.Redirect("menu.aspx");

  }

  要注意的是重定向請求只是一個GET請求,這就意味著我們不能從源頁中通過重定向命令提交數據。但是我們可以在重定向中使用查詢字符串來傳遞數據。如下面代碼所示:

   protected void Redirect_Click(object sender, EventArgs e)
  {

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

  }

  上面的例子將一個查詢字符串作為參數傳遞給了Response.Redirect方法的目標URL。我們可以通過如下的代碼獲得源數據。  

protected void Page_Load(object sender, EventArgs e)
  {

  string userName = Request["userName"];

  }

  二、服務器傳輸方法

  和依賴于客戶端向另一個新頁發請求不同,服務器傳輸是一種服務器重定向技術,這種技術通過簡單的改變Web服務器所處理的代碼來達到請求一個新頁的目的。當被請求頁和源頁面在同一個服務器時,服務器傳輸要比Response.Redirect方法更有效,這是由于這種技術可以避免額外的開銷,僅僅使用服務器的資源就可以進行重定向。要注意的這種技術有一個副作用,在頁面進行重定向時,客戶端的URL仍然會保持源頁面的URL,這可能會使客戶認為他們所獲得的數據是源頁面產生的。當然,在大多數情況下,這不是問題,但是這將使調試變得更困難。

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

   Server.Transfer("Menu.aspx",true);
  然后,我們在目標頁面中獲得一個叫txtUserName的Textbox控件的值的代碼如下:

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

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

  由于Response.Redirect方法要進行兩次請求響應操作,因此,我們應該在對性能要求高的網站盡量避免使用這種方法。然而,只從技術上說,使用redirect方式確實可以從一個網頁跳到另一個網頁。相比之下,Server.Transfer會更有效率,但是跳轉的范圍僅限于同一個Web服務器的不同網頁。從本質上說,我們可以使用Server.Transfer來消除不必要的請求響應操作。如果我們需要重定位到不同服務器的網頁,就需要使用Response.Redirect方法。

  四、跨頁提交概述

  在ASP.NET 2.0中,我們可以通過實現IbuttonControl接口提交給不同的WebForm,來實現跨網頁的提交。和Response.Redirect類似,跨網頁提交是一個基于客戶端的傳輸機制,但也有點象Server.Transfer,目標網頁也可以訪問源網頁的數據。為了使用跨網頁提交,我們需要在源網頁中的PostBackUrl屬性中指定目標URL。

  五、實現跨網頁提交

  這部分將討論一下如何在 ASP.NET2.0中實現跨網頁提交。為了開始我們的學習,假設有兩個Web頁,一個是源Web頁,另一個是目標Web頁。在源網頁中初始化了使用按鈕進行的跨網頁提交操作。我們首先必須設置目標網頁按鈕的PostBackUrl屬性,順便說一句,所有實現了 System.Web.UI.WebControls.IbuttonControl接口的Web控件都有跨網頁提交的特性。下面的代碼將演示這一過程。

   PostBackUrl="~/target.aspx" text = "Post to a target page"/>
  當我們設置PostBackUrl屬性時,ASP.NET框架將相應的控件綁定到一個新的叫WebForm_DoPostBackWithOptions的JavaScript函數,產生的Html代碼如下:

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

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

  對于上面的html代碼來說,當用戶單擊按鈕時,瀏覽器將提交目標URL(Target.aspx),而不是源URL。

六、從目標頁面中獲得源頁面控件的值

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

  因此,我們要避免由于不小心進行誤操作,所以最好通過IsCrossPostBack屬性來確認是否為一個跨網頁提交發生,如果這個屬性值為true,那么目標網頁就是通過一個跨網頁提交動作而調用的。如果是通過另外一種方式調用的(如一般的請求、Response.Redirect或是一個Server.Transfer),這個屬性的值為false。下面的例子演示了如何使用這個屬性。

   if ( PreviousPage.IsCrossPagePostBack)
  {

  //執行代碼

  }

  這個PreviousPage屬性在Server.Transfer和跨網頁提交中都可以使用。在ASP.NET2.0中,我們可以在調用Server.Transfer操作后使用PreviousPage屬性在目標頁面中來獲得源頁面的數據,代碼如下:

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

  }

  protected void Redirect_Click(object sender, EventArgs e)

  在這個接收面中我們現在可以獲得Web頁面的數據,代碼如下:

   protected void Page_Load(object sender, EventArgs e)
  {

  if (PreviousPage != null)

  {

  TextBox txtBox = (TextBox)

  PreviousPage.FindControl("txtUserName");

  if (textBox != null)

  string userName = textBox.Text;

  //其他可執行的代碼

  }

  }

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

七、使用PreviousPageType

  PreviousPageType屬性提供了在跨網頁操作中訪問源頁面的強類型能力,下面讓我們演示一下如何不通過任何類型轉換來從源頁面中獲得控件值。代碼如下:

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

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

  八、保存視圖狀態

  對于跨網頁提交來說,ASP.NET2.0 內嵌了一個叫__POSTBACK的隱藏字段,這個字段包含了關于源頁面的視圖信息 -- 也就是由源頁面提供了,包含了一個帶有一個非空PostBackUrl屬性值的服務端控件。目標頁可以使用__POSTBACK中的信息來獲得源頁面的視圖狀態信息。代碼如下:

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

  {

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

  Response.Write(txtBox.Text);

  }

  在上面的代碼中核對了用于確保PreviousPage屬性不為null的檢查代碼。順便提一下,如果目標頁和源頁面不在同一個應用程序中,這個 PreviousPage屬性的值為null。只有在進行跨網頁提交操作時,IsCrossPagePostBack屬性才為true。

  這個跨網頁提交的特性,是ASP.NET2.0中最強有力的特性之一,這種技術將允許在一個頁面中提交到另外一個頁面,并且可以在目標頁面地無縫地操作源頁面中的數據。

相關閱讀
asp截取字符串:根據右邊第一個點(.)去掉擴展名
初期入門地接旅行社建站解決方案
深山旅行社管理系統免費版 V2.3
發出億萬中國人的心聲,釣魚島事件以來最愛國的視頻
深山留言板(9.10教師節模板)
短信郵件
許愿墻開始重新設計。
珍惜每一個你遇到過的人 放開你心靈之約的視頻
共有0條關于《ASP.NET 2.0跨網頁提交的三法》的評論
發表評論
正在加載評論......
返回頂部發表評論
呢 稱:
表 情:
內 容:
評論內容:不能超過 1000 字,需審核,請自覺遵守互聯網相關政策法規。
驗證碼: 驗證碼 
網友評論聲明,請自覺遵守互聯網相關政策法規。

您發布的評論即表示同意遵守以下條款:
一、不得利用本站危害國家安全、泄露國家秘密,不得侵犯國家、社會、集體和公民的合法權益;
二、不得發布國家法律、法規明令禁止的內容;互相尊重,對自己在本站的言論和行為負責;
三、本站對您所發布內容擁有處置權。

更多信息>>欄目類別選擇
百度小程序開發
微信小程序開發
微信公眾號開發
uni-app
asp函數庫
ASP
DIV+CSS
HTML
python
更多>>同類信息
ASP.NET中Cookie編程的基礎知識
ASP.NET 2.0跨網頁提交的三法
ASP.NET 2和IIS 7.0發生不兼容變化
ASP.NET中文亂碼問題的解決。
ASP.Net 2.0中的5個數據控件
根據頁面模板動態生成html頁面
更多>>最新添加文章
dw里面查找替換使用正則刪除sqlserver里面的CONSTRAINT
Android移動端自動化測試:使用UIAutomatorViewer與Selenium定位元素
抖音直播音掛載小雪花 懂車帝小程序
javascript獲取瀏覽器指紋可以用來做投票
火狐Mozilla Firefox出現:無法載入您的Firefox配置文件 它可能已經丟失 或是無法訪問 問題解決集合處理辦法
在Android、iOS、Windows、MacOS中微信小程序的文件存放路徑
python通過代碼修改pip下載源讓下載庫飛起
python里面requests.post返回的res.text還有其它的嗎
更多>>隨機抽取信息
JS+CSS實現圖片放大預覽效果(購物時放在產品上面預覽圖片)
四川省中國青年旅行社有限公司總部
利用CSS讓網頁里的提交按鈕變得更漂亮
一些常見的網頁設計小技巧
uni-app跨端開發微信小程序時頁面棧超過10層時小程序像卡死一樣假性不能點擊無法跳轉的解決方案
利用position把div放在flash上
99热热热_国产成人自拍一区_欧美一级网站_99热在线播放_国产精品乱码一区二区三区_久久精品国产一区二区三区
  • <li id="6qmi0"></li>
  • <li id="6qmi0"><source id="6qmi0"></source></li>
    天天人人精品| 97欧洲一区二区精品免费| 久久久久se| 成人动漫视频在线观看完整版| 国精品一区二区| 日韩精品不卡| 久久99久久99精品蜜柚传媒| 久久国产欧美精品| 99国内精品| 亚洲午夜伦理| 欧美日韩一区二区高清| 婷婷久久伊人| 日韩性感在线| 日韩资源av在线| 日本一区二区三区免费看| 精品国产一二| 久久久一本精品99久久精品| 国产精品久久久对白| 久久久天天操| 成人18视频| 97碰碰视频| 国内一区在线| 精品国产乱码久久久久久久软件| 国产66精品久久久久999小说| 久久精品动漫| 成人蜜桃视频| 国产三区精品| 久久天堂国产精品| 欧美一级日本a级v片| 日韩一区二区三区资源| 一区二区三区四区欧美日韩| 一区二区在线观看网站| 欧美婷婷久久| 国产欧美亚洲一区| 亚洲中午字幕| 99r国产精品视频| 精品国产免费久久久久久尖叫 | 91久久黄色| 国产欧美日韩一区二区三区| 一本一本久久| 97人人模人人爽人人喊38tv| 国产伦精品一区二区三区视频孕妇| 精品国产免费一区二区三区| 色一情一区二区三区四区| 自拍另类欧美| 一区二区三区国产在线| 成人欧美一区二区| 日本一区免费在线观看| 狠狠色综合一区二区| 亚洲中字在线| 青娱乐一区二区| 欧美影视一区| 欧美亚洲视频| 日本三级中国三级99人妇网站| 欧美在线网址| 97伦理在线四区| 亚洲欧美精品| 久久精品日产第一区二区三区 | 牛牛国产精品| 亚洲制服av| 日韩欧美一区二区在线观看| 亚洲精品欧美| 久久综合一区二区三区| 国内在线观看一区二区三区| 久久久www| 一区二区三区偷拍| 国产精品尤物| 先锋影音欧美| 91九色视频在线观看| 亚洲精品中字| 91麻豆精品秘密入口| 在线免费观看成人| 成人三级视频在线观看一区二区| 亚洲欧洲免费无码| 97夜夜澡人人双人人人喊| 一区二区欧美日韩| 国产精品乱码视频| 91久久夜色精品国产九色| 久久综合中文色婷婷| 国产区二精品视| 亚洲欧洲国产精品久久| 国产精品99久久久久久久| 尹人成人综合网| 日本亚洲自拍| 91成人在线看| 在线综合视频| 欧美久久影院| 日本电影一区二区三区| 久久久久一区二区| 亚洲日本成人| 欧美一区91| 日本一区二区三区视频在线播放| 亚洲一区日韩| 亚洲高清视频一区| 一本色道久久99精品综合| 国产精品久久久久久久天堂第1集| 99xxxx成人网| 国产综合亚洲精品一区二| 亚洲精品乱码视频| 免费看污久久久| 国产精品国产精品国产专区不卡| 国产婷婷精品| 亚洲精品裸体| 在线成人亚洲| 亚洲午夜激情在线| 欧美精品国产一区二区| 天堂资源在线亚洲资源| 蜜桃导航-精品导航| 精品一区二区三区视频日产| 97超碰在线播放| 美女久久一区| 91九色极品视频| 久久精品麻豆| 久久婷婷一区| av免费观看久久| 97久久人人超碰caoprom欧美| 久久电影一区| 91黄色精品| 精品国产乱码一区二区三区四区 | 亚洲激情偷拍| 在线视频一区观看| 午夜在线精品| 91久久国产自产拍夜夜嗨| 99国精产品一二二线| 91免费在线观看网站| 高清av免费一区中文字幕| 国产日韩欧美亚洲一区| 九色91视频| 五月天亚洲综合情| 欧美91福利在线观看| 黄色国产精品一区二区三区| 亚洲看片一区| 999国内精品视频在线| 国产精品久久精品国产| 欧美日韩亚洲免费| 一区二区精品国产| 亚洲精品国产精品国自产观看| 一区二区三区三区在线| 91久久爱成人| 日韩精彩视频| 亚洲无吗在线| 久久先锋资源| 欧美一区二区三区四区五区六区 | 欧美一区观看| 欧美激情日韩| 欧美中文字幕| 鲁丝片一区二区三区| 性欧美精品一区二区三区在线播放 | 欧美日韩精品免费观看| 国产欧美韩日| 九色一区二区| 欧美私人啪啪vps| 久久av最新网址| 久久久久综合一区二区三区| 欧美日韩一区二| 91九色在线观看| 亚洲7777| 久久久久99| 中文一区一区三区免费| 国产精品亚洲产品| 久久国产精品99久久久久久丝袜| 欧美1级日本1级| dy888夜精品国产专区| 亚洲精品久久久久久一区二区| 亚洲视频大全| 日本一区二区三区四区在线观看 | 亚欧精品在线| 欧美专区18| 视频在线99| 久久精品导航| 中文字幕一区综合| 99久久99久久| 亚洲一级影院| 欧美一区1区三区3区公司| 在线亚洲一区| 自拍偷拍一区二区三区| 国产99视频精品免费视频36| 欧美日韩精品免费观看| 免费观看成人高| 亚洲一区二区三区高清| 正在播放亚洲| 成人一区二区三区四区| 亚洲第一毛片| 亚洲精品欧洲精品| 国产传媒一区| 久久av一区| 99精品视频免费观看| 亚洲国内在线| 黑人另类av| 国产精品午夜av在线| 欧美精品网站| 神马影院我不卡午夜| 国产一区二区在线网站| 亚洲综合国产| 亚洲国产精品第一区二区三区| 午夜久久资源| 日韩精品第一页| 精品久久久久久综合日本| 久久久蜜桃一区二区人| 国产一区二区高清视频|