某些手机网页上面的JavaScript类型广告元素怎么屏蔽?

JavaScript020

某些手机网页上面的JavaScript类型广告元素怎么屏蔽?,第1张

代码如下:

<div class='google-ad testAd'>这个div将会被屏蔽掉 </div>

有了这个规律,我就能够使用JavaScript发现当前浏览器是否开启了AdBlock插件。首先,我们将Google广告代码放到一个div里,并且将div的css class name里放入一个很明显的表示google AD的类名:

复制代码代码如下:

<div class='google-ad testAd'>这里放置Google广告代码</div>

然后在页面的底部用Js检测,:

复制代码代码如下:

if ($('.google-ad').height() == 0) showOtherImage()

这里还有一个问题,Google的广告通常是指Dom加载完毕后显示的,为了保证在Google广告加载完成后再进行探测,要给js代码加入延迟执行特征,这样避免了误检测:

复制代码代码如下:

$(function(){

setTimeout(function(){

if ($('.google-ad').height() == 0)

showOtherImage()

},3000)

})

以手机端为例子:

1. 登录Google Adsense。

2. 点击左侧“屏蔽控制功能”,再点击下面的“内容广告”,接着点击“所有网站”,进入屏蔽广告设置。如果你有运营英文站,可以只设置下面的中文站域名。

3. 进入的页面会有三种屏蔽广告显示的方法:“广告客户网址”,“敏感类别”和“常规类别”。

这里点击“常规类别”下面的“管理常规类别”。

4. 直接打开最后一页,点击“移动应用实用工具”,再点击里面的“网络连接应用”,在右侧点击设置成“已屏蔽”。

如果你嫌麻烦,可以直接在上面搜索框搜索“网络连接应用”来直接设置。用同样方法,你还可以屏蔽其它类型的广告。

这是去视频广告的,我是复制傲游浏览器的暴利猴脚本:

// ==UserScript==

// @name 去视频广告

// @author Anonymous

// @description 通过替换swf播放器的方式来解决优酷的黑屏广告+Bilibili黑科技 In God,We Turst.

// @version 1.366.2

// @namespace http://userscripts.org/users/Kawaiiushio

// @updateURL https://userscripts.org/scripts/source/162286.meta.js

// @downloadURL https://userscripts.org/scripts/source/162286.user.js

// @icon http://extensiondl.maxthon.cn/skinpack/17276781/1366787326/icons/icon_48.png

// @include http://*/*

// @include https://*/*

// ==/UserScript==

/*

* === 说明 ===

* 本脚本参考http://bbs.kafan.cn/thread-1514537-1-1.html 感谢卡饭大神

* Chrome用户也可以使用Adkill and Media download这个扩展

* 此脚本设计修改人员OpenGG Harv xplsy 15536900 yndoc KawaiiUshio 5B4B铅笔

* Bilibili黑科技由FireAway提供 参考:http://userscripts.org/scripts/show/165424

* Opera兼容部分由Gerald修改

* In God,We Trust.

* THX.

*/

/*

* Love Jiani

*/

(function() {

Function.prototype.bind = function() {

var fn = this, args = Array.prototype.slice.call(arguments), obj = args.shift()

return function() {

return fn.apply(obj, args.concat(Array.prototype.slice.call(arguments)))

}

}

function YoukuAntiAds() {}

YoukuAntiAds.prototype = {

_players: null,

_rules: null,

_done: null,

get players() {

if(!this._players) {

this._players = {

'youku': 'http://lovejiani.cdn.duapp.com/kafan/loader.swf',

'ku6': 'http://lovejiani.cdn.duapp.com/kafan/ku6.swf',

'iqiyi': 'http://lovejiani.cdn.duapp.com/kafan/iqiyi.swf',

'iqiyi5': 'http://lovejiani.cdn.duapp.com/kafan/iqiyi5.swf',

'tudou': 'http://lovejiani.cdn.duapp.com/kafan/tudou.swf',

'tudou_olc': 'http://lovejiani.cdn.duapp.com/kafan/olc_8.swf',

'tudou_sp': 'http://lovejiani.cdn.duapp.com/kafan/sp.swf',

'letv': 'http://lovejiani.cdn.duapp.com/kafan/letv.swf'

}

}

return this._players

},

get rules() {

if(!this._rules) {

this._rules = {

'youku': {

'find': /^http:\/\/static\.youku\.com(\/v[\d\.]+)?\/v\/swf\/(loader|q?player[^\.]*)\.swf/i,

'replace': this.players['youku']

},

'youku_out': {

'find': /^http:\/\/player\.youku\.com\/player\.php\/.*sid\/([\w=]+).*(\/v)?\.swf.*/i,

'replace': this.players['youku'] + '?showAd=0&VideoIDS=$1'

},

'ku6': {

'find': /^http:\/\/player\.ku6cdn\.com\/default\/.*\/\d+\/player\.swf/i,

'replace': this.players['ku6']

},

'ku6_out': {

'find': /^http:\/\/player\.ku6\.com\/(inside|refer)\/([^\/]+)\/v\.swf.*/i,

'replace': this.players['ku6'] + '?vid=$2'

},

'letv1': {

'find': /^http:\/\/.*letv[\w]*\.com\/[^\.]*\/.*player\/((?!Live).*)Player[^\.]*\.swf/i,

'replace': this.players['letv']

},

'letv2': {

'find': /^http:\/\/.*letv[\w]*\.com\/.*player[^\.]*\.swf\?v_list=[\d]/i,

'replace': this.players['letv']

},

'letv3': {

'find': /^http:\/\/.*letv[\w]*\.com\/.*\/v_list=[\d]*\/\.swf/i,

'replace': this.players['letv']

},

'iqiyi': {

'find': /^http:\/\/www\.iqiyi\.com\/player\/\d+\/player\.swf/i,

'replace': this.players['iqiyi']

},

'iqiyi_out': {

'find': /^http:\/\/(player|dispatcher)\.video\.i?qiyi\.com\/(.*[\?&]vid=)?([^\/&]+).*/i,

'replace': this.players['iqiyi5'] + '?vid=$3'

},

'tudou': {

'find': /^http:\/\/js\.tudouui\.com\/.*player[^\.]*\.swf/i,

'replace': this.players['tudou']

},

'tudou_out': {

'find': /^http:\/\/www\.tudou\.com\/.*(\/v\.swf)?/i,

'replace': this.players['tudou_olc'] + '?tvcCode=-1&swfPath=' + this.players['tudou_sp']

}

}

}

return this._rules

},

get done() {

if(!this._done) {

this._done = new Array()

}

return this._done

},

initPreHandlers: function() {

this.rules['iqiyi']['preHandle'] = function(elem, find, replace, player) {

if(document.querySelector('span[data-flashplayerparam-flashurl]')) {

replace = this.players['iqiyi5']

}

this.reallyReplace.bind(this, elem, find, replace)()

}

this.rules['tudou_out']['preHandle'] = function(elem, find, replace, player) {

var fn = this

var isFx = /firefox/i.test(navigator.userAgent)

GM_xmlhttpRequest({

method: isFx ? 'HEAD' : 'GET',

url: isFx ? player : 'https://query.yahooapis.com/v1/public/yql?format=json&q=' + encodeURIComponent('use"https://haoutil.googlecode.com/svn/trunk/firefox/tudou_redirect.yql.xml" as tudouselect * from tudou where url="' + player + '" and referer="' + window.location.href + '"'),

onload: function(response) {

var finalUrl = (isFx ? response.finalUrl : response.responseText)

var match = finalUrl.match(/(iid|youkuid|resourceid|autoplay|snap_pic)=[^&]+/ig)

if(match &&!/error/i.test(finalUrl)) {

replace += '&' + match.join('&')

fn.reallyReplace.bind(fn, elem, find, replace)()

}

}

})

}

},

addAnimations: function() {

var style = document.createElement('style')

style.type = 'text/css'

style.innerHTML = 'object,embed{\

-webkit-animation-duration:.001s-webkit-animation-name:playerInserted\

-ms-animation-duration:.001s-ms-animation-name:playerInserted\

-o-animation-duration:.001s-o-animation-name:playerInserted\

animation-duration:.001sanimation-name:playerInserted}\

@-webkit-keyframes playerInserted{from{opacity:0.99}to{opacity:1}}\

@-ms-keyframes playerInserted{from{opacity:0.99}to{opacity:1}}\

@-o-keyframes playerInserted{from{opacity:0.99}to{opacity:1}}\

@keyframes playerInserted{from{opacity:0.99}to{opacity:1}}'

document.getElementsByTagName('head')[0].appendChild(style)

},

animationsHandler: function(e) {

if(e.animationName === 'playerInserted') {

this.replace(e.target)

}

},

replace: function(elem) {

if(this.done.indexOf(elem) != -1) return

this.done.push(elem)

var player = elem.data || elem.src

if(!player) return

var i, find, replace, isReplacing = false

for(i in this.rules) {

find = this.rules[i]['find']

if(find.test(player)) {

replace = this.rules[i]['replace']

if('function' === typeof this.rules[i]['preHandle']) {

isReplacing = true

this.rules[i]['preHandle'].bind(this, elem, find, replace, player)()

}

if(!isReplacing) {

this.reallyReplace.bind(this, elem, find, replace)()

}

break

}

}

},

reallyReplace: function(elem, find, replace) {

elem.data &&(elem.data = elem.data.replace(find, replace)) || elem.src &&((elem.src = elem.src.replace(find, replace)) &&(elem.style.display = 'block'))

this.reloadPlugin(elem)

},

reloadPlugin: function(elem) {

var nextSibling = elem.nextSibling

var parentNode = elem.parentNode

parentNode.removeChild(elem)

var newElem = elem.cloneNode(true)

this.done.push(newElem)

if(nextSibling) {

parentNode.insertBefore(newElem, nextSibling)

} else {

parentNode.appendChild(newElem)

}

},

init: function() {

this.initPreHandlers()

var handler = this.animationsHandler.bind(this)

document.body.addEventListener('webkitAnimationStart', handler, false)

document.body.addEventListener('msAnimationStart', handler, false)

document.body.addEventListener('oAnimationStart', handler, false)

document.body.addEventListener('animationstart', handler, false)

this.addAnimations()

}

}

new YoukuAntiAds().init()

})()