通過分析伺服器傳回的http協定狀态代碼,可以分析伺服器端的基本響應狀态。
在asp中,我們可以在檔案頭部修改伺服器傳回的資訊,當浏覽器通路此頁面時候,會對http狀态進行解釋。
例如
Response.Status="404 Not Found"
Response.End
通路此頁面時候會得到404結果;浏覽器提示頁面不存在或者已經删除;
如果在檔案頭部使用一下代碼:
Response.Status="403 Forbidden"
Response.End
IE中的結果就是:
您無權檢視該網頁
您可能沒有權限用您提供的憑據檢視此目錄或網頁。
--------------------------------------------------------------------------------
如果您确信能夠檢視該目錄或網頁,請嘗試使用xxx首頁上所列的電子郵件位址或電話與網站聯系。
可以單擊搜尋,尋找 Internet 上的資訊。
HTTP 錯誤 403 - 禁止通路
Internet Explorer
一下為http協定中的狀态代碼一覽:
狀态代碼/狀态資訊/代碼含義
100 Continue 初始的請求已經接受,客戶應當繼續發送請求的其餘部分。
101 Switching Protocols 伺服器将遵從客戶的請求轉換到另外一種協定
200 OK 一切正常,對GET和POST請求的應答文檔跟在後面。
201 Created 伺服器已經建立了文檔,Location頭給出了它的URL。
202 Accepted 已經接受請求,但處理尚未完成。
203 Non-Authoritative Information 文檔已經正常地傳回,但一些應答頭可能不正确,因為使用的是文檔的拷貝
204 No Content 沒有新文檔,浏覽器應該繼續顯示原來的文檔。如果使用者定期地重新整理頁面,而Servlet可以确定使用者文檔足夠新,這個狀态代碼是很有用的。
205 Reset Content 沒有新的内容,但浏覽器應該重置它所顯示的内容。用來強制浏覽器清除表單輸入内容
206 Partial Content 客戶發送了一個帶有Range頭的GET請求,伺服器完成了它。
300 Multiple Choices 客戶請求的文檔可以在多個位置找到,這些位置已經在傳回的文檔内列出。如果伺服器要提出優先選擇,則應該在Location應答頭指明。
301 Moved Permanently 客戶請求的文檔在其他地方,新的URL在Location頭中給出,浏覽器應該自動地通路新的URL。
302 Found 類似于301,但新的URL應該被視為臨時性的替代,而不是永久性的。注意,在HTTP1.0中對應的狀态資訊是“Moved”
303 See Other 類似于301/302,不同之處在于,如果原來的請求是POST,Location頭指定的重定向目标文檔應該通過GET提取
304 Not Modified 用戶端有緩沖的文檔并發出了一個條件性的請求(一般是提供If-Modified-Since頭表示客戶隻想比指定日期更新的文檔)。伺服器告訴客戶,原來緩沖的文檔還可以繼續使用。
305 Use Proxy 客戶請求的文檔應該通過Location頭所指明的代理伺服器提取
307 Temporary Redirect 和302 (Found)相同。許多浏覽器會錯誤地響應302應答進行重定向,即使原來的請求是POST,即使它實際上隻能在POST請求的應答是303時才能重定 向。由于這個原因,HTTP 1.1新增了307,以便更加清除地區分幾個狀态代碼:當出現303應答時,浏覽器可以跟随重定向的GET和POST請求;如果是307應答,則浏覽器隻 能跟随對GET請求的重定向。
400 Bad Request 請求出現文法錯誤。
401 Unauthorized 客戶試圖未經授權通路受密碼保護的頁面。應答中會包含一個WWW-Authenticate頭,浏覽器據此顯示使用者名字/密碼對話框,然後在填寫合适的Authorization頭後再次送出請求。
403 Forbidden 資源不可用。伺服器了解客戶的請求,但拒絕處理它。通常由于伺服器上檔案或目錄的權限設定導緻。
404 Not Found 無法找到指定位置的資源。這也是一個常用的應答。
405 Method Not Allowed 請求方法(GET、POST、HEAD、DELETE、PUT、TRACE等)對指定的資源不适用。
406 Not Acceptable 指定的資源已經找到,但它的MIME類型和客戶在Accpet頭中所指定的不相容
407 Proxy 類似于401,表示客戶必須先經過代理伺服器的授權。
408 Request Timeout 在伺服器許可的等待時間内,客戶一直沒有發出任何請求。客戶可以在以後重複同一請求。
409 Conflict 通常和PUT請求有關。由于請求和資源的目前狀态相沖突,是以請求不能成功。
410 Gone 所請求的文檔已經不再可用,而且伺服器不知道應該重定向到哪一個位址。它和404的不同在于,傳回407表示文檔永久地離開了指定的位置,而404表示由于未知的原因文檔不可用。
411 Length Require 伺服器不能處理請求,除非客戶發送一個Content-Length頭。
412 Precondition Failed 請求頭中指定的一些前提條件失敗
413 Request Entity Too Large 目标文檔的大小超過伺服器目前願意處理的大小。如果伺服器認為自己能夠稍後再處理該請求,則應該提供一個Retry-After頭
414 Request URI Too Long URI太長 。
416 Requested Range Not Satisfiable 伺服器不能滿足客戶在請求中指定的Range頭。
500 Internal Server Error 伺服器遇到了意料不到的情況,不能完成客戶的請求。
501 Not Implemented 伺服器不支援實作請求所需要的功能。例如,客戶發出了一個伺服器不支援的PUT請求。
502 Bad Gateway 伺服器作為網關或者代理時,為了完成請求通路下一個伺服器,但該伺服器傳回了非法的應答。
503 Service Unavailable 伺服器由于維護或者負載過重未能應答。例如,Servlet可能在資料庫連接配接池已滿的情況下傳回503。伺服器傳回503時可以提供一個Retry-After頭。
504 Gateway Timeout 由作為代理或網關的伺服器使用,表示不能及時地從遠端伺服器獲得應答。
505 HTTP Version Not Supported 伺服器不支援請求中所指明的HTTP版本。
在實際過程中比較有價值的是301/302重定向:
Response.Status="301" or 302
Response.AddHeader "Location","url"
Response.End
兩種方式,對于引擎都是不友好的,蜘蛛人和一般的浏覽器有差距,根據觀察,google一般僅僅收錄轉向後的第一個頁面。
301的作用相當于redirect;
另外一個是200 OK,用于表示請求成功,文檔下載下傳完畢,在ajax中使用很多。
而最讓人惱火的是500号,伺服器内部錯誤。