国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

用js屏蔽被http劫持的浮動廣告實現方法

2019-11-19 15:51:03
字體:
來源:轉載
供稿:網友

最近發現網站經常在右下角彈出一個浮動廣告,開始的時候以為只是瀏覽器的廣告。

后來越來越多同事反映在家里不同瀏覽器也會出現廣告。然后深入檢查了下,發現網站竟然被劫持了。

然后百度了一大堆資料,什么http劫持、dns劫持、運營商劫持之類的,確定真的是中招了。看圖:

真是偷梁換柱啊,被插入廣告代碼了。真是無良奸商,什么都做得出。

然并卵,最重要的解決辦法是啥?然后把問題扔給了運維的同事。

最終結果是解決不了。沒錯,就是這么的坑爹。除非采用https。網上那些什么打電話、發信投訴之類的貌似沒啥用??赡苁沁\維太爛了。反正結果就是沒結果。

然后,沒辦法啦。只能我們大前端自己想辦法屏蔽啦。然后開啟了研究劫持代碼之旅,

......過程省略了800字尋找過程。

最終發現了,被劫持的廣告會定義一個js全局變量_pushshowjs_ ,里面保存了一些劫持廣告的相關信息,然后創建一個id為_embed_v3_dc的div放廣告。并且每次都是一樣的,不會有變化。

根據劫持廣告的投放原理,最終使用了js屏蔽被劫持廣告的方法。

具體代碼如下:

;(function($,window,undefined){ var needClear=false,  timeout; if(window._pushshowjs_){  console.log("adHttp");  needClear=true; } window._pushshowjs_={}; Object.freeze(window._pushshowjs_);//讓對象只讀, 防止屬性被直接修改 Object.defineProperty(window, '_pushshowjs_', {  configurable: false,//防止屬性被重新定義  writable: false//防止屬性被重新賦值 }); if(needClear){  timeout=setInterval(function(){   if($("#_embed_v3_dc").length>0){    $("#_embed_v3_dc").remove();    console.log("http清除");    needClear=false;    clearInterval(timeout);   }  },500);  $(window).load(function(){   if(needClear){    setTimeout(function(){     clearInterval(timeout);     console.log("清除");    },2000);   }  }); }}(jQuery,window));

代碼不多,就不詳細解析了(如果覺得代碼有問題,望指正)。簡單點說就是把劫持廣告必須的全局js變量_pushshowjs_設定為不可被修改,只讀。如果發現廣告就清除。

放了代碼,終于跟被劫持的廣告說88了。

為什么說是笨辦法?

因為這只是自欺欺人。其實劫持還是存在,并且被劫持了的js的加載順序有可能會發生變化而導致錯誤,理想的辦法還是要靠運維跟運營商去解決或使用https。

每個劫持的廣告邏輯應該都差不多,但廣告代碼都會不同。所以我這個不一定會適用于其他的劫持廣告。這只是一個思路,沒辦法之中的辦法。

有大神有更好的解決辦法,望指教。

以上這篇用js屏蔽被http劫持的浮動廣告實現方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 梁平县| 昌邑市| 襄汾县| 车险| 新巴尔虎左旗| 双鸭山市| 南和县| 天峨县| 盘锦市| 和平县| 自贡市| 湟源县| 稻城县| 景东| 乐山市| 银川市| 滨州市| 蒙城县| 尚义县| 鄄城县| 中卫市| 阜阳市| 乌苏市| 浙江省| 九龙城区| 黄石市| 湄潭县| 西宁市| 施秉县| 临夏县| 墨脱县| 观塘区| 东乡族自治县| 汪清县| 灯塔市| 汕尾市| 天全县| 安泽县| 平定县| 凌源市| 石嘴山市|