一.header函數 按照官方文檔的說法,header函數用來輸出http頭部信息,你能夠有下面的這些用法:javascript
一、使用header函數進行跳轉頁面;
header(‘Location:’.$url);
其中$url就是將要跳轉的url了。
這種用法的注意事項有如下幾點:
Location 和」:」之間不能有空格,不然會出現錯誤(註釋:我剛測試了,在我本地環境下,沒有跳轉頁面,可是也沒有報錯,不清楚什麼緣由); 在用header前不能有任何的輸出(註釋:這點你們都知道的,若是header以前有任何的輸出,包括空白,就會出現header already sent by xxx的錯誤); header 後面的東西還會執行的;css
二、使用header聲明content-type
header(‘content-type:text/HTML;charset=utf-8′);
這個沒有什麼好說的;
三、使用header返回response 狀態碼
header(sprintf(‘%s %d %s’, $http_version, $status_code, $description));
樣式就是這樣的;
例如:header(‘HTTP/1.1 404 Not Found’);
四、使用header在某個時間後執行跳轉
header(「Refresh: {$delay}; url={$url}」);
其中$delay就是推遲跳轉的時間,$url爲須要跳轉的url
例如:header(‘Refresh: 10; url=http://www.example.org/’); 意思爲10s後跳轉到http://www.eexample.org這個網站
五、使用header控制瀏覽器緩存
header(「Expires: Mon, 26 Jul 1997 05:00:00 GMT」);
header(「Last-Modified: 」 . gmdate(「D, d M Y H:i:s」) . 「GMT」);
header(「Cache-Control: no-cache, must-revalidate」);
header(「Pragma: no-cache」);
六、執行http驗證
header(‘HTTP/1.1 401 Unauthorized’);
header(‘WWW-Authenticate: Basic realm=」Top Secret」‘);
七、使用header進行下載操做
header(‘Content-Type: application/octet-stream’);//設置內容類型
header(‘Content-Disposition: attachment; filename=」example.zip」‘); //設置MIME用戶做爲附件下載 若是將attachment換成inline意思爲在線打開
header(‘Content-Transfer-Encoding: binary’);//設置傳輸方式
header(‘Content-Length: ‘.filesize(‘example.zip’));//設置內容長度
// load the file to send:
readfile(‘example.zip’);//讀取須要下載的文件html
問題來了,究竟什麼是http頭部信息呢?java
二.http 頭信息詳解c++
HTTP(HyperTextTransferProtocol)是超文本傳輸協議 的縮寫,它用於傳送WWW方式的數據,關於HTTP協議的詳細內容請參考RFC2616。HTTP協議採用了請求/響應模型。客戶端向服務器發送一個請 求,請求頭包含請求的方法、URI、協議版本、以及包含請求修飾符、客戶信息和內容的相似於MIME的消息結構。服務器以一個狀態行做爲響應,相應的內容 包括消息協議的版本,成功或者錯誤編碼加上包含服務器信息、實體元信息以及可能的實體內容。git
一般HTTP消息包括客戶機向服務器的請求 消息和服務器向客戶機的響應消息。這兩種類型的消息由一個起始行,一個或者多個頭域,一個只是頭域結束的空行和可選的消息體組成。HTTP的頭域包括通用 頭,請求頭,響應頭和實體頭四個部分。每一個頭域由一個域名,冒號(:)和域值三部分組成。域名是大小寫無關的,域值前能夠添加任何數量的空格符,頭域能夠 被擴展爲多行,在每行開始處,使用至少一個空格或製表符。web
通用頭域shell
通用頭域包含請求和響應消息都支持的頭域,通用頭 域包含Cache-Control、 Connection、Date、Pragma、Transfer-Encoding、Upgrade、Via。對通用頭域的擴展要求通信雙方都支持此擴 展,若是存在不支持的通用頭域,通常將會做爲實體頭域處理。下面簡單介紹幾個在UPnP消息中使用的通用頭域。數據庫
Cache-Control頭域api
Cache- Control指定請求和響應遵循的緩存機制。在請求消息或響應消息中設置 Cache-Control並不會修改另外一個消息處理過程當中的緩存處理過程。請求時的緩存指令包括no-cache、no-store、max-age、 max-stale、min-fresh、only-if-cached,響應消息中的指令包括public、private、no-cache、no- store、no-transform、must-revalidate、proxy-revalidate、max-age。各個消息中的指令含義如 下:
Public指示響應可被任何緩存區緩存。
Private指示對於單個用戶的整個或部分響應消息,不能被共享緩存處理。這容許服務器僅僅描述當用戶的部分響應消息,此響應消息對於其餘用戶的請求無效。
no-cache指示請求或響應消息不能緩存
no-store用於防止重要的信息被無心的發佈。在請求消息中發送將使得請求和響應消息都不使用緩存。
max-age指示客戶機能夠接收生存期不大於指定時間(以秒爲單位)的響應。
min-fresh指示客戶機能夠接收響應時間小於當前時間加上指定時間的響應。
max-stale指示客戶機能夠接收超出超時期間的響應消息。若是指定max-stale消息的值,那麼客戶機能夠接收超出超時期指定值以內的響應消息。
Date頭域
Date頭域表示消息發送的時間,時間的描述格式由rfc822定義。例如,Date:Mon,31Dec200104:25:57GMT。Date描述的時間表示世界標準時,換算成本地時間,須要知道用戶所在的時區。
Pragma頭域
Pragma頭域用來包含實現特定的指令,最經常使用的是Pragma:no-cache。在HTTP/1.1協議中,它的含義和Cache- Control:no-cache相同。
請求消息
請求消息的第一行爲下面的格式:
MethodSPRequest-URISPHTTP-VersionCRLFMethod 表示對於Request-URI完成的方法,這個字段是大小寫敏感的,包括OPTIONS、GET、HEAD、POST、PUT、DELETE、 TRACE。方法GET和HEAD應該被全部的通用WEB服務器支持,其餘全部方法的實現是可選的。GET方法取回由Request-URI標識的信息。 HEAD方法也是取回由Request-URI標識的信息,只是能夠在響應時,不返回消息體。POST方法能夠請求服務器接收包含在請求中的實體信息,可 以用於提交表單,向新聞組、BBS、郵件羣組和數據庫發送消息。
SP表示空格。Request-URI遵循URI格式,在此字段爲星號 (*)時,說明請求並不用於某個特定的資源地址,而是用於服務器自己。HTTP- Version表示支持的HTTP版本,例如爲HTTP/1.1。CRLF表示換行回車符。請求頭域容許客戶端向服務器傳遞關於請求或者關於客戶機的附加 信息。請求頭域可能包含下列字段Accept、Accept-Charset、Accept- Encoding、Accept-Language、Authorization、From、Host、If-Modified-Since、If- Match、If-None-Match、If-Range、If-Range、If-Unmodified-Since、Max-Forwards、 Proxy-Authorization、Range、Referer、User-Agent。對請求頭域的擴展要求通信雙方都支持,若是存在不支持的請 求頭域,通常將會做爲實體頭域處理。
典型的請求消息:
GET http://download.microtool.de:80/somedata.exe
Host: download.microtool.de
Accept:*/*
Pragma: no-cache
Cache-Control: no-cache
Referer: http://download.microtool.de/
User-Agent:Mozilla/4.04[en](Win95;I;Nav)
Range:bytes=554554-
上例第一行表示HTTP客戶端(多是瀏覽器、下載程序)經過GET方法得到指定URL下的文件。棕色的部分表示請求頭域的信息,綠色的部分表示通用頭部分。
Host頭域
Host頭域指定請求資源的Intenet主機和端口號,必須表示請求url的原始服務器或網關的位置。HTTP/1.1請求必須包含主機頭域,不然系統會以400狀態碼返回。
Referer頭域
Referer 頭域容許客戶端指定請求uri的源資源地址,這能夠容許服務器生成回退鏈表,可用來登錄、優化cache等。他也容許廢除的或錯誤的鏈接因爲維護的目的被 追蹤。若是請求的uri沒有本身的uri地址,Referer不能被髮送。若是指定的是部分uri地址,則此地址應該是一個相對地址。
Range頭域
Range頭域能夠請求實體的一個或者多個子範圍。例如,
表示頭500個字節:bytes=0-499
表示第二個500字節:bytes=500-999
表示最後500個字節:bytes=-500
表示500字節之後的範圍:bytes=500-
第一個和最後一個字節:bytes=0-0,-1
同時指定幾個範圍:bytes=500-600,601-999
可是服務器能夠忽略此請求頭,若是無條件GET包含Range請求頭,響應會以狀態碼206(PartialContent)返回而不是以200 (OK)。
User-Agent頭域
User-Agent頭域的內容包含發出請求的用戶信息。
響應消息
響應消息的第一行爲下面的格式:
HTTP-VersionSPStatus-CodeSPReason-PhraseCRLF
HTTP- Version表示支持的HTTP版本,例如爲HTTP/1.1。Status- Code是一個三個數字的結果代碼。Reason-Phrase給Status-Code提供一個簡單的文本描述。Status-Code主要用於機器自 動識別,Reason-Phrase主要用於幫助用戶理解。Status-Code的第一個數字定義響應的類別,後兩個數字沒有分類的做用。第一個數字可 能取5個不一樣的值:
1xx:信息響應類,表示接收到請求而且繼續處理
2xx:處理成功響應類,表示動做被成功接收、理解和接受
3xx:重定向響應類,爲了完成指定的動做,必須接受進一步處理
4xx:客戶端錯誤,客戶請求包含語法錯誤或者是不能正確執行
5xx:服務端錯誤,服務器不能正確執行一個正確的請求
響 應頭域容許服務器傳遞不能放在狀態行的附加信息,這些域主要描述服務器的信息和 Request-URI進一步的信息。響應頭域包含Age、Location、Proxy-Authenticate、Public、Retry- After、Server、Vary、Warning、WWW-Authenticate。對響應頭域的擴展要求通信雙方都支持,若是存在不支持的響應頭 域,通常將會做爲實體頭域處理。
典型的響應消息:
HTTP/1.0200OK
Date:Mon,31Dec200104:25:57GMT
Server:Apache/1.3.14(Unix)
Content-type:text/html
Last-modified:Tue,17Apr200106:46:28GMT
Etag:」a030f020ac7c01:1e9f」
Content-length:39725426
Content-range:bytes554554-40279979/40279980
上例第一行表示HTTP服務端響應一個GET方法。棕色的部分表示響應頭域的信息,綠色的部分表示通用頭部分,紅色的部分表示實體頭域的信息。
Location響應頭
Location響應頭用於重定向接收者到一個新URI地址。
Server響應頭
Server響應頭包含處理請求的原始服務器的軟件信息。此域能包含多個產品標識和註釋,產品標識通常按照重要性排序。
實體
請 求消息和響應消息均可以包含實體信息,實體信息通常由實體頭域和實體組成。實體頭域包含關於實體的原信息,實體頭包括Allow、Content- Base、Content-Encoding、Content-Language、 Content-Length、Content-Location、Content-MD五、Content-Range、Content-Type、 Etag、Expires、Last-Modified、extension-header。extension-header容許客戶端定義新的實體 頭,可是這些域可能沒法未接受方識別。實體能夠是一個通過編碼的字節流,它的編碼方式由Content-Encoding或Content-Type定 義,它的長度由Content-Length或Content-Range定義。
Content-Type實體頭
Content-Type實體頭用於向接收方指示實體的介質類型,指定HEAD方法送到接收方的實體介質類型,或GET方法發送的請求介質類型 Content-Range實體頭
Content-Range實體頭用於指定整個實體中的一部分的插入位置,他也指示了整個實體的長度。在服務器向客戶返回一個部分響應,它必須描述響應覆蓋的範圍和整個實體長度。通常格式:
Content-Range:bytes-unitSPfirst-byte-pos-last-byte-pos/entity-legth
例 如,傳送頭500個字節次字段的形式:Content-Range:bytes0- 499/1234若是一個http消息包含此節(例如,對範圍請求的響應或對一系列範圍的重疊請求),Content-Range表示傳送的範圍, Content-Length表示實際傳送的字節數。
Last-modified實體頭
Last-modified實體頭指定服務器上保存內容的最後修訂時間。
應答頭 | 說明 |
Allow | 服務器支持哪些請求方法(如GET、POST等)。 |
Content-Encoding | 文檔的編碼(Encode)方法。只有在解碼以後才能夠獲得Content-Type頭指定的內容類型。利用gzip壓 縮文檔可以顯著地減小HTML文檔的下載時間。Java的GZIPOutputStream能夠很方便地進行gzip壓縮,但只有Unix上的 Netscape和Windows上的IE 四、IE 5才支持它。所以,Servlet應該經過查看Accept-Encoding頭(即request.getHeader(「Accept- Encoding」))檢查瀏覽器是否支持gzip,爲支持gzip的瀏覽器返回經gzip壓縮的HTML頁面,爲其餘瀏覽器返回普通頁面。 |
Content-Length | 表示內容長度。只有當瀏覽器使用持久HTTP鏈接時才須要這個數據。若是你想要利用持久鏈接的優點,能夠把輸出文檔寫入 ByteArrayOutputStram,完成後查看其大小,而後把該值放入Content-Length頭,最後經過 byteArrayStream.writeTo(response.getOutputStream()發送內容。 |
Content-Type | 表示後面的文檔屬於什麼MIME類型。Servlet默認爲text/plain,但一般須要顯式地指定爲text/html。因爲常常要設置Content-Type,所以HttpServletResponse提供了一個專用的方法setContentTyep。 |
Date | 當前的GMT時間。你能夠用setDateHeader來設置這個頭以免轉換時間格式的麻煩。 |
Expires | 應該在何時認爲文檔已通過期,從而再也不緩存它? |
Last-Modified | 文檔的最後改動時間。客戶能夠經過If-Modified-Since請求頭提供一個日期,該請求將被視爲一個條件 GET,只有改動時間遲於指定時間的文檔纔會返回,不然返回一個304(Not Modified)狀態。Last-Modified也可用setDateHeader方法來設置。 |
Location | 表示客戶應當到哪裏去提取文檔。Location一般不是直接設置的,而是經過HttpServletResponse的sendRedirect方法,該方法同時設置狀態代碼爲302。 |
Refresh | 表示瀏覽器應該在多少時間以後刷新文檔,以秒計。除了刷新當前文檔以外,你還能夠經過setHeader(「Refresh」, 「5; URL=http://host/path」)讓瀏覽器讀取指定的頁面。 注 意這種功能一般是經過設置HTML頁面HEAD區的<META HTTP-EQUIV=」Refresh」 CONTENT=」5;URL=http://host/path」>實現,這是由於,自動刷新或重定向對於那些不能使用CGI或Servlet的 HTML編寫者十分重要。可是,對於Servlet來講,直接設置Refresh頭更加方便。注意Refresh的意義是「N秒以後刷 新本頁面或訪問指定頁面」,而不是「每隔N秒刷新本頁面或訪問指定頁面」。所以,連續刷新要求每次都發送一個Refresh頭,而發送204狀態代碼則可 以阻止瀏覽器繼續刷新,不論是使用Refresh頭仍是<META HTTP-EQUIV=」Refresh」 …>。注意Refresh頭不屬於HTTP 1.1正式規範的一部分,而是一個擴展,但Netscape和IE都支持它。 |
Server | 服務器名字。Servlet通常不設置這個值,而是由Web服務器本身設置。 |
Set-Cookie | 設置和頁面關聯的Cookie。Servlet不該使用response.setHeader(「Set-Cookie」, …),而是應使用HttpServletResponse提供的專用方法addCookie。參見下文有關Cookie設置的討論。 |
WWW-Authenticate | 客戶應該在Authorization頭中提供什麼類型的受權信息?在包含401(Unauthorized)狀態行的 應答中這個頭是必需的。例如,response.setHeader(「WWW-Authenticate」, 「BASIC realm=\」executives\」")。 注意Servlet通常不進行這方面的處理,而是讓Web服務器的專門機制來控制受密碼保護頁面的訪問(例如.htaccess)。 |
1.幫助主頁被各大搜索引擎登陸;
2.定義頁面的使用語言;
3.自動刷新並指向新的頁面;
4.實現網頁轉換時的動畫效果;
5.網頁定級評價;
6.控制頁面緩衝;
7.控制網頁顯示的窗口。
meta 的屬性有兩種:name和http-equiv。
name屬性主要用於描述網頁,對應於content(網頁內容),以便於搜索引擎機器人查找、分類(目前幾乎全部的搜索引擎都使用網上機器人自動查找meta值來給網頁分類)。這其中最重要的是description(站點在搜索引擎上的描述)和keyWords(分類關鍵詞),因此應該給每頁加一個meta值。
name 屬性
1.<meta name=」Generator」 contect=」editplus」>用以說明生成工具(如Microsoft FrontPage 4.0)等;
2.<meta name=」KEYWords」 contect=」webjx,cnrose」>向搜索引擎說明你的網頁的關鍵詞;
3.<meta name=」Description」 contect=」webjx’s blog」>告訴搜索引擎你的站點的主要內容;
4.<meta name=」Author」 contect=」webjx」>告訴搜索引擎你的站點的製做的做者;
5.<meta name=」Robots」 contect=」all|none|index|noindex|follow|nofollow」>
name屬性:
設定爲all:文件將被檢索,且頁面上的連接能夠被查詢;
設定爲none:文件將不被檢索,且頁面上的連接不能夠被查詢;
設定爲index:文件將被檢索;
設定爲follow:頁面上的連接能夠被查詢;
設定爲noindex:文件將不被檢索,但頁面上的連接能夠被查詢;
設定爲nofollow:文件將不被檢索,頁面上的連接能夠被查詢。
meta標籤的http-equiv屬性語法格式是:<meta http-equiv=」參數」 content=」參數變量值」> ;其中http-equiv屬性主要有如下幾種參數:
一、Expires(期限)
說明:能夠用於設定網頁的到期時間。一旦網頁過時,必須到服務器上從新傳輸。
用法:<meta http-equiv=」expires」 content=」Wed, 20 Jun 2007 22:33:00 GMT」>
注意:必須使用GMT的時間格式。
二、Pragma(cache模式)
說明:禁止瀏覽器從本地計算機的緩存中訪問頁面內容
用法:<meta http-equiv=」Pragma」 content=」no-cache」>
注意:這樣設定,訪問者將沒法脫機瀏覽。
三、Refresh(刷新)
說明:自動刷新並指向新頁面。
用法:<meta http-equiv=」Refresh」 content=」2;URL=http://www.net.cn/」>
注意:其中的2是指停留2秒鐘後自動刷新到URL網址。
四、Set-Cookie(cookie設定)
說明:若是網頁過時,那麼存盤的cookie將被刪除。
用法:<meta http-equiv=」Set-Cookie」 content=」cookievalue=xxx; expires=Wednesday, 20-Jun-2007 22:33:00 GMT; path=/」>
注意:必須使用GMT的時間格式。
五、Window-target(顯示窗口的設定)
說明:強制頁面在當前窗口以獨立頁面顯示。
用法:<meta http-equiv=」Window-target」 content=」_top」>
注意:用來防止別人在框架裏調用本身的頁面。
六、content-Type(顯示字符集的設定)
說明:設定頁面使用的字符集。
用法:<meta http-equiv=」content-Type」 content=」text/html; charset=gb2312″>
七、Pics-label(網頁等級評定)
用法:<meta http-equiv=」Pics-label」 contect=」">網頁等級評定
說明:在IE的internet選項中有一項內容設置,能夠防止瀏覽一些受限制的網站,而網站的限制級別就是經過meta屬性來設置的。
還有Page_Enter、Page_Exit……
補充:
設定進入頁面時的特殊效果<meta http-equiv=」Page-Enter」 contect=」revealTrans(duration=1.0,transtion= 12)」>
設定離開頁面時的特殊效果<meta http-equiv=」Page-Exit」 contect=」revealTrans(duration=1.0,transtion= 12)」>
Duration的值爲網頁動態過渡的時間,單位爲秒。
Transition是過渡方式,它的值爲0到23,分別對應24種過渡方式。以下表:
0 盒狀收縮 1 盒狀放射
2 圓形收縮 3 圓形放射
4 由下往上 5 由上往下
6 從左至右 7 從右至左
8 垂直百葉窗 9 水平百葉窗
10 水平格狀百葉窗 11垂直格狀百葉窗
12 隨意溶解 13從左右兩端向中間展開
14從中間向左右兩端展開 15從上下兩端向中間展開
16從中間向上下兩端展開 17 從右上角向左下角展開
18 從右下角向左上角展開 19 從左上角向右下角展開
20 從左下角向右上角展開 21 水平線狀展開
22 垂直線狀展開 23 隨機產生一種過渡方式
上面的http-equiv這些值咱們均可以在header函數中使用,其中有一個屬性content-type咱們常常看到,那麼content-type究竟有那些值呢?
四.Content-Type一覽