首頁  >  文章  >  web前端  >  解決js下referer相容各大瀏覽器的方法_javascript技巧

解決js下referer相容各大瀏覽器的方法_javascript技巧

WBOY
WBOY原創
2016-05-16 16:32:171551瀏覽

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.jb51.net';  
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;  

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn