Kod pelaksanaan untuk pengesanan javascript kemahiran akses_javascript Internet

WBOY
Lepaskan: 2016-05-16 16:35:07
asal
1230 orang telah melayarinya

Cara paling mudah dan kasar ialah memuatkan sumber rangkaian, fail JS atau fail imej.

Salin kod Kod adalah seperti berikut:


typeof window.jQuery === "undefined" // return false atau true

Gunakan pembolehubah jQuery untuk mengesan sama ada anda disambungkan ke Internet

function doConnectFunction() {
  return true;
}
function doNotConnectFunction() {
  return false;
}

 var i = new Image();
i.onload = doConnectFunction;
i.onerror = doNotConnectFunction;
i.src = 'http://su.bdimg.com/static/superplus/img/logo_white.png?d=' + escape(Date());
Salin selepas log masuk

Masalah dengan memuatkan sumber rangkaian ialah pengesanan Internet Jika ia adalah pengesanan LAN, tiada apa yang boleh anda lakukan.
Pada masa ini, kami memerlukan penyelesaian yang lebih baik, jadi kami perlu menggunakan navigator.onLine Kelemahan atribut ini ialah ia serasi dengan pelayar Chrome dan Safari semuanya menyokongnya dengan sempurna, dan IE7 dan ke atas disokong. Firefox dan IE6 lebih menyedihkan Mereka hanya mengembalikan palsu apabila penyemak imbas berada dalam "luar talian", dan sebaliknya kembali benar. Memang benar walaupun kabel rangkaian dicubit, tetapi Opera tidak lagi menyokongnya.

Jadi kita perlu menambah kaedah keserasian: hantar permintaan pengepala http ke alamat location.hostname, kodnya adalah seperti berikut:

var xhr = new ( window.ActiveXObject || XMLHttpRequest )( "Microsoft.XMLHTTP" );
var status;
xhr.open( "HEAD", "//" + window.location.hostname + "/?rand=" + Math.floor((1 + Math.random()) * 0x10000), false );
 try {
  xhr.send();
  return ( xhr.status >= 200 && xhr.status < 300 || xhr.status === 304 );
 } catch (error) {
  return false;
 }
Salin selepas log masuk

Satu perkara yang perlu diambil perhatian ialah parameter ketiga kaedah terbuka mesti diluluskan palsu, dan ia mestilah permintaan segerak.

Ringkasan: Jika penyemak imbas menyokong navigator.onLine, gunakan navigator.onLine Jika ia tidak menyokongnya, hantar permintaan pengepala http.

Artikel asal, sila nyatakan semasa mencetak semula: Dicetak semula daripada Pembangunan Hadapan

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan