HTTP參照位址
维基百科,自由的百科全书
(重定向自HTTP referrer)
| HTTP |
| 持久 · 压缩 · 安全 |
| 头字段 |
| ETag · Cookie · Referrer · Location · Do Not Track · X-Forwarded-For |
| HTTP状态码 |
| 301 Moved permanently |
| 302 Found |
| 303 See Other |
| 403 Forbidden |
| 404 Not Found |
HTTP參照位址(referer,或HTTP referer),是HTTP表頭的一個欄位,用來表示從哪兒連結到目前的網頁,採用的格式是URL。換句話說,藉著HTTP參照位址,目前的網頁可以檢查訪客從哪裡而來,這也常被用來對付偽造的跨網站請求。
而 dereferer 則是將HTTP參照位址資訊剝離,所以網站將無法識別訪客從何而來。
Referer的正确英语拼法是referrer。由于早期HTTP规范的拼写错误,为了保持向后兼容就将错就错了。其它网络技术的规范企图修正此问题,使用正确拼法,所以目前拼法不统一。
細節 [编辑]
當訪客訪問網頁時,HTTP參照位址 (referer 或 referring page) 是前一個網頁的URL。如果是圖片的話,通常指的就是圖片所在的網頁。在网页浏览器送往網頁伺服器的時候,HTTP參照位址就被包含在HTTP請求方法中。
許多網站都會把參照位址紀錄起來以便追蹤使用者的動態,大部分的分析軟體都會處理這個資訊。但是參照位址資訊可能會有隐私权的問題,部份网页浏览器允許使用者设置不要送出這個資訊,有些代理服务器和防火牆也會把參照位址資訊过滤掉,以避免讓外部知道非公開的網站地址。缺少了參照位址資訊有可能會造成某些使用問題:某些伺服器會因為缺少了正確的參照位址資訊而進行阻擋,以避免未經授權的圖片引用(图像防盗链)或是其他對伺服器有影響的行為。針對這樣的阻擋,有些軟體則提供了針對特定網站送出假来源位址的功能(反防盗链)。
如何取得HTTP參照位址 [编辑]
- ASP.NET(C#)
- string strReferrer = Request.UrlReferrer.AbsolutePath.ToString();
- string strReferrer = Request.ServerVariables("http_referrer");
- string strReferrer = Request.UrlReferrer.ToString();
- strReferrer = Request.ServerVariables("HTTP_REFERRER").Item;
- $strReferrer = $_SERVER["HTTP_REFERER"];