この質問の時代にもかかわらず、私は最近それが非常に便利であると気づきました。ここや他の場所を調べた後、広告ブロッカーを間接的に検出するための主要な3つのクライアント側のチェックは、ブロックされた div
/ img
、ブロックされたiframe
、ブロックされたリソース(JavaScriptファイル)。
たぶん、それはトップレベルか偏執狂かもしれませんが、選択から1つまたは2つだけをブロックする広告ブロックシステムを対象としているため、1つのチェックしか実行しなかった場合は対象外でした。
チェックを実行しているページに追加します:(私はjQueryを使用しています)
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="advertisement.js"></script>
<script type="text/javascript" src="abds.js"></script>
そして、ページの他の場所に以下を追加します:
<div id="myTestAd"><img src="http://placehold.it/300x250/000000/ffffff.png&text=Advert" /></div>
私は、餌の名前のdivと、「Advert」というテキストがあり、AdSenseが使用するディメンション(placehold.itに感謝)を外部でホストする画像を使用しました。
に advertisement.js
、あなたたちは、後で確認することができ、ドキュメントに何かを追加する必要があります。以前と同じように作業しているように見えますが、実際advertisement.js
には、出力ではなく、ファイル()自体がロードされているかどうかを確認しています。
$(document).ready(
{
$("body").append("<div id=\"myTestAd2\">check</div>");
});
そして、すべてを組み合わせた広告ブロッカー検出スクリプト
$(document).ready(function()
{
var ifr = '<iframe id="adServer" src="http://ads.google.com/adserver/adlogger_tracker.php" width="300" height="300"></iframe>';
$("body").append(ifr);
});
$(window).on("load",function()
{
var atb = $("#myTestAd");
var atb2= $("#myTestAd2");
var ifr = $("#adServer");
setTimeout(function()
{
if( (atb.height()==0) ||
(atb.filter(":visible").length==0) ||
(atb.filter(":hidden").length>0) ||
(atb.is("hidden")) ||
(atb.css("visibility")=="hidden") ||
(atb.css("display")=="none") ||
(atb2.html()!="check") ||
(ifr.height()!=300) ||
(ifr.width()!=300) )
{
alert("You're using ad blocker you normal person, you!");
}
},500);
});
ドキュメントの準備ができたら、つまりマークアップが読み込まれると、iframeもドキュメントに追加されます。次に、ウィンドウが読み込まれると、コンテンツが含まれます。画像などが読み込まれ、チェックします:
- 最初のテストdivの寸法と可視性。
- あれば、それはあったであろうように、第2の試験のdivの内容は、「チェック」であること
advertimsent.js
でしたいないブロックされました。
- iframeの寸法(および非表示オブジェクトには高さまたは幅がないため、可視性を推測しますか?)
そしてスタイル:
div#myTestAd, iframe#adServer
{
display: block;
position: absolute;
left: -9999px;
top: -9999px;
}
div#myTestAd2
{
display: none;
}
お役に立てれば