HTTP Header referer這玩意主要是告訴人們我是從哪兒來的,就是告訴人家我是從哪個頁面過來的,可以用於統計訪問本網站的用戶來源,也可以用來防盜鏈。獲取這個東西最好的方式是js,如果在服務器端獲取(PHP方法如:$_SERVER['HTTP_REFERER']) 不靠譜,人家可以偽造,用js獲取最好,人家很難偽造,
方法:利用js的 document.referer 方法可以准確地判斷網頁的真實來路。 目前百度統計,google ads統計,CNZZ統計,都是用的這個方法。防盜鏈也很簡單了,js裡判斷來路url如果不是本站不顯示圖片。
眾所周知,我們web開發人員痛恨IE浏覽器,因為IE不支持標准,標准外的默認行為又和其他浏覽器經常不一致:
在IE中用javascript做跳轉,比如用window.location.href = “”; google如果使用document.referrer無法取到浏覽器請求的HTTP referrer,因為IE清空了
而其他主流浏覽器Firefox和Chrome都會保留referrer,沒辦法,這意味著IE又要享受“部長級”特殊待遇了:
以下代碼可以解決ie的這個問題:
//檢測如果是ie浏覽器,則手動的給增加一個referer
這樣的原理就是給IE浏覽器的頁面偷偷加了個鏈接,然後自動點這個鏈接,於是referrer就能保留了。
代碼如下:
var url = 'http://www.cnblogs.com';
if (/MSIE (\d+\.\d+);/.test(navigator.userAgent) || /MSIE(\d+\.\d+);/.test(navigator.userAgent))
{
var referLink = document.createElement('a');
referLink.href = url;
document.body.appendChild(referLink);
referLink.click();
}
else
{
location.href = url;
}