通過對Request對象的學習,可以瞭解到,Request對象是伺服器端用來擷取用戶端的資訊的。
但作為伺服器和用戶端進行互動,是不是還缺少伺服器端向用戶端發送資訊呢?對象Response正是擔任此責任。
負責將資訊傳遞給使用者的對象就是Response了,它可動態地響應用戶端的請求,並將動態產生的響應結果返回給用戶端瀏覽器。
一,Response.write
在Response中write方法是使用最頻繁的一個了,write就是寫:將指定的字串寫到當前的 HTTP 輸出。
1,write.asp
<% response.write("hello,world"&"<br>") Randomize response.write "任意數是"&rnd()&"<br>" %> |
response.write後面為所顯示的資訊,可以用括弧包含,也可以直接書寫(注意和response.write之間有空格)。
書寫的字串資訊或者HTML代碼相關,用引號包含;而ASP本身的函數或變數則不需要,直接用即可。
並且無論字串資訊、HTML代碼、函數還是變數之間進行串連都是採用&號(針對vbscript)
以上遇到一個隨機函數rnd(),該函數返回一個小於 1 但大於或等於 0 的值。
需要注意的是在調用 Rnd 之前,先使用無參數的 Randomize 語句初始化隨機數產生器,該產生器具有基於系統計時器的種子。
若缺少Randomize,則無法繼續產生隨機種子。
下面一個利用隨機函數的例子,產生隨機背景顏色效果:
<script language=vbs><br />Randomize '首先Randomize產生隨機種子<br />suij=rnd() '接著將函數值賦變數suij<br />suij=replace(suij,".","9") '然後對變數suij中小數點符號轉換為數字9<br />suij=left(suij,6) '再取變數中的左6位<br />document.write "<body bgcolor=#"&suij&">" '最後應用到背景顏色中去<br /></script><br />
[Ctrl+A 全部選擇進行拷貝 提示:可先修改部分代碼,再點擊運行]
當然要產生指定範圍的隨機整數,請使用以下公式:
Int((upperbound - lowerbound + 1) * Rnd + lowerbound)
這裡, upperbound 是此範圍的上界,而 lowerbound 是此範圍內的下界。
<script language=vbs><br />Do Until choose = vbNo<br /> value = Int((41 * Rnd) + 60) '產生 60 到 100 之間的隨機數。<br /> msgbox value<br /> choose = MsgBox ("Roll again? ", vbYesNo)<br />Loop<br /></script><br />
[Ctrl+A 全部選擇進行拷貝 提示:可先修改部分代碼,再點擊運行]
隨機函數在做考試系統的時候非常有用,當然你也可以用來自己搖獎,拿個頭彩也分點我就行了
二,Response.end
這是Response常用的一種方法,使 Web 服務器停止處理指令碼並返回當前結果,檔案中剩餘的內容將不被處理。
主要放在一頁多功能的ASP頁中,為讓程式運行到此,抑或往下的程式沒必要再執行顯示……
2,end.asp
<%response.write now() response.end '程式執行顯示到此結束 response.write rnd()%> |
三,Response.clear
該方法主要作用是清除緩衝區中的所有 HTML 輸出,但該方法只清除響應本文而不清除響應標題。
該方法和end方法似相反,end是到此結束返回上面的結果,而clear卻是清除上面的執行,然後只返回下面的結果。
3,clear.asp
<%response.write now() response.clear '以上程式到此全被清除 response.write rnd()%> |
下面通過一個例子來仔細看看end and clear
4,end2clear.asp
<% filepath=request.servervariables("script_name") user=Request.Form("username") pwd=Request.Form("password") %><form method="POST" action="<%=filepath%>"> name:<input type="text" name="username"><br> pwd:<input type="password" name="password"><br> <input type="submit" value="submit"> </form> <% If user="cnbruce" and pwd="cnbruce" Then response.write "採用clear方法,上面的程式結果將清除。" response.clear ' 清空儲存在緩衝中的頁面 Else response.write "採用end方法,下面的程式將停運。" Response.End ' 立即停止指令碼處理,並將緩衝中的頁面輸出 End If %> 如果你只看到“重新整理”連結就表明clear方法已經生效<br> <a href="<%=filepath%>">重新整理</a> |
以上程式中,當輸入使用者名稱和密碼同為cnbruce的時候會發現clear方法的處理結果,反之是另外一個效果。
四,Response.redirect
Redirect 方法是讓瀏覽器立即重新導向到程式指定的URL地址。這在根據客戶的不同響應,為不同的客戶指定不同的頁面,或根據不同的情況指定不同的頁面時,顯得非常重要。
該方法是立即生效的,在其後的指令碼都不執行。
5,redirect.asp
<%response.redirect("http://www.cnbruce.com/")%> |
以上四則運用屬於Response對象的幾個比較重要的方法:write、end、clear、redirect等當然方法還有:AddHeader、AppendToLog、BinaryWrite、Flush……
早說過,一個ASP對象除了對象方法外,還有對象屬性
那response對象的屬性有哪些呢?
五,Response.ContentType
ContentType 屬性指定伺服器響應的 HTTP 內容類型。如果未指定 ContentType,預設為 text/html。
6,contenttype.asp(非text/html的)
<% Response.ContentType = "text/HTML" %> <% Response.ContentType = "image/GIF" %> <% Response.ContentType = "image/JPEG" %> <% Response.ContentType = "text/plain" %> <% Response.ContentType = "image/JPEG" %> |
六,Response.charset
Charset 屬性將字元集名稱附加到 Response 對象中 content-type 標題的後面,用來設定伺服器響應給用戶端的檔案字元編碼。
7,charset.asp
<% Response.charset = "big5" %> 中文顯示,但採用的big5繁體的編碼,所以看到的是亂碼。 |
當然Response.ContentType和Response.charset應用得比較少了。直接在head頭部屬性裡面添加就OK了。
七,Response.expires
該屬性指定了在瀏覽器上緩衝儲存的頁,距到期還有多少時間。
如果使用者在某個頁到期之前又回到此頁,就會顯示緩衝區中的頁面。
但若設定 response.expires=0,則可使緩衝的頁面立即到期。
這是一個較實用的屬性,當客戶通過 ASP 的登陸頁面進入 WEB 網站後,應該利用該屬性使登陸頁面立即到期,以確保安全。
引用一個經典的例子
8,expires.asp
<% Response.Expires = 0 Response.Expiresabsolute = Now() - 1 Response.AddHeader "pragma","no-cache" Response.AddHeader "cache-control","private" Response.CacheControl = "no-cache" %> |
八,Response.status
設定伺服器要響應的狀態行的值。Response.status="狀態原因字串",字串可以為一個三位整數或一串解說文字組成,但必須防在<html>之前。
9,status.asp
<% Response.Status = "401 Unauthorized" %> |
九,Response.buffer
比較重要的一個,值為true or false。該屬性指示是否緩衝頁輸出。
引用:當緩衝頁輸出時,只有當前頁的所有伺服器指令碼處理完畢或者調用了 Flush 或 End 方法後,伺服器才將響應發送給用戶端瀏覽器,伺服器將輸出發送給用戶端瀏覽器後就不能再設定 Buffer 屬性。因此應該在 .asp 檔案的第一行調用 Response.Buffer。
對於Response對象的屬性和方法先到這裡,剩下一個資料集合,即cookie。
繼續看cookies講座吧。
應用舉例題
表單發OutLook郵件
<style><br />input{ border:1px solid navy; width:150}<br /></style><br /><script><br />function test(){<br />var NewTitle=title.value;<br />var NewContent=content.value;<br />document.location.href="mailto:"+aaa.value+"?cc="+bbb.value+"&bcc="+ccc.value+"&subject="+NewTitle+"&body="+NewContent;<br />}<br /></script><br /><pre><br /><font color=red>收件者: </font><input name=aaa><br><br /><font color=red>操送: </font><input name=bbb><br><br /><font color=red>密件操送: </font><input name=ccc><br><br /><font color=red>主題: </font><input name=title><br><br /><font color=red>內容: </font></pre><p><br /><textarea cols=30 rows=10 name=content></textarea><br><br /><input type=button value="send" onClick="test()"><br />
[Ctrl+A 全部選擇進行拷貝 提示:可先修改部分代碼,再點擊運行]
ASP的
<% submitname=request.form("submit") if submitname="submit" then email=request.form("email") cc=request.form("cc") subject=request.form("subject") body=request.form("body") response.redirect("mailto:"&email&"?cc="&cc&"&subject="&subject&"&body="&body) else %> <form name="form1" method="post" action="email.asp"> email:<input name="email"><br> cc:<input name="cc"><br> subject:<input name="subject"><br> body:<input name="body"><br> <input type="submit" name="submit" value="submit"> </form> <%end if%> |