摘要:基於web的動態網頁設計必會涉及到頁面間的資料傳遞,文章探討了asp設計中常用的web頁面間的資料傳遞方式,分析各種資料傳遞方式的使用方法、使用場合及優缺點,其都是設計階段選擇資料傳遞方式考慮的關鍵。
關鍵詞 資料傳遞變數瀏覽器端網頁
往往使用動態網頁技術製作asp應用程式時一般至少擁有二個或二個以上的web頁面,這時就得考慮在多個web頁面間傳遞資料的處理工作。而asp應用程式的各個頁面類似於windows應用程式的form表單,windows應用程式各form間資料傳遞可以通過定義全域變數等方法來實現。網頁間的資料傳遞有多種不同的可使用方式,而web頁面間的資料傳遞方式選擇是否恰當對系統設計及啟動並執行合理性與安全性起到舉足輕重的作用。
1、url方式
url方式是實現web間資料傳遞最基本的方法,操作簡單,可很方便地實現不同web頁面間的資料傳遞,但其安全性比較差。將要傳遞的資料附加在網頁地址(url)後面進行傳遞。如:http://www.cstvu.com/testweb?username=liming,其中?後面所跟著的字串便是傳遞的資料,=前的是變數名,=後面是數值,可以使用request對象來擷取傳遞的資料。如:request(“username”)。這種方法在傳遞資料過程中其資料內容在url欄中是顯示的,使用者能看到提交的內容。
2、form方式
通過在網頁上製作表單互動地區,使用者在瀏覽器端輸入資料,然後通過form提交到伺服器,在提交後的接受form資料的頁面裡就可以接收到相應資料,即form的action頁面中可以使用request對象來接收所傳遞的資料。
如:
發送頁面:
<form name=“formtest” action=“targetweb.asp”>
<input name=“testtext” type=“text”value=“”>
<input name=“testbutton” type =“submit”value =“提交”>
</form>
接收頁面:request(“testtext”)
利用form頁面的文字框來接收使用者資料的輸入,通過submit按鈕提交後在targetweb頁面中使用request來接收資料。
3、cookie方式
cookie是在瀏覽頁面時web伺服器在瀏覽器端所寫入的一些小檔案,cookie是存放在瀏覽器端本機磁碟上,而不是存放在服務端的。可以在發送資料時寫入cookie,接收時讀取cookie完成資料在web頁面間的傳送。
如:
發送頁面:response.cookies(“cookiename”)(“username”)=“liming”
接收頁面:request.cookie(“cookiename”)(“username”)
在發送頁面中對cookie變數賦值,接收頁面中取cookie變數的值就是所傳遞的資料。
4、application對象
application對象是用來記錄整個網站資訊的,是記錄不同瀏覽器端共用的變數,無論有幾個瀏覽者同時存取網頁,都只會產生一個application對象執行個體。使用者可以通過定義application整站共用變數來實現網頁間的資料傳遞。其定義方法是:application(“變數名”)=數值
如:application(“usrname”)=liming
application對象所定義的變數對於所有瀏覽端都是可見的,所以其使用場合是所有瀏覽端共用的全域資料傳遞。
5、session對象
session對象是用來記錄瀏覽器端的變數,是個別瀏覽器端專用的變數,對於每一個瀏覽器訪問時都會自動產生一個seseion對象,該對象提供一個儲存場所,用來儲存僅僅對該訪問者在會話的活動期間開啟的網頁可用的變數和對象。這樣就用可以用來在web間傳遞專對單個瀏覽器端使用的資料。其定義方法:session(“變數名”)=數值
如:session(“usename”)=liming
session對象所定義的變數只是瀏覽器端的專用變數,所以適用於局部會話間的網頁資料傳遞。
6、結束語
上述介紹的是網頁間資料傳遞的常用方法,各有千秋。其中url方式和form方式實現方法簡單,可實現網頁間的簡單資料傳遞,一般為字串類型,其特點是安全性差,而且必須是連續訪問兩頁面間資料傳遞。cookie只能存放string類型的資料,如果想要存放更為複雜的資料類型,那麼必須先將其轉換為string類型。application對象和session對象操作相對複雜些,瀏覽量非常大的網頁使用時應適量,而且使用結束後盡量清除,否則大量使用有可能會導致伺服器的癱瘓。session變數的安全性較高,可傳遞專用瀏覽端資料。具體應用決定了資料傳遞方式的選擇,合理資料傳遞方式選擇是web頁面的設計中的關鍵考慮因素。