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就能保留了。