Maison interface Web js tutoriel JavaScript peut-il envoyer un ping à un serveur sans utiliser de bibliothèques externes ?

JavaScript peut-il envoyer un ping à un serveur sans utiliser de bibliothèques externes ?

Dec 01, 2024 pm 07:31 PM

Can JavaScript Ping a Server Without Using External Libraries?

Javascript peut-il pinger un serveur ?

Lors de la création d'applications Web, il devient nécessaire de déterminer la disponibilité des serveurs externes. Bien que les scripts côté serveur puissent facilement effectuer cette tâche à l'aide de commandes telles que "ping", les capacités de Javascript dans ce domaine ont été limitées.

Cependant, une méthode ingénieuse a émergé utilisant l'objet Image natif. En chargeant une image à partir du serveur cible, Javascript peut exploiter les mécanismes intégrés de récupération des ressources afin de déterminer la disponibilité du serveur.

Implémentation

L'extrait de code suivant illustre le fonction principale pour exécuter le ping :

function Pinger_ping(ip, callback) {

  if(!this.inUse) {

    this.inUse = true;
    this.callback = callback
    this.ip = ip;

    var _that = this;

    this.img = new Image();

    this.img.onload = function() {_that.good();};
    this.img.onerror = function() {_that.good();};

    this.start = new Date().getTime();
    this.img.src = "http://" + ip;
    this.timer = setTimeout(function() { _that.bad();}, 1500);

  }
}
Copier après la connexion

La fonction crée un objet image et définit les écouteurs pour le "onload" et événements « onerror ». L'image est ensuite chargée à partir du serveur cible et un délai d'attente est défini pour gérer le cas où le serveur ne répond pas. En fonction du résultat, les méthodes "good()" ou "bad()" sont appelées pour indiquer la disponibilité du serveur.

Avantages

Cette technique offre plusieurs avantages :

  • Compatibilité multiplateforme : Il fonctionne sur différents types de serveurs et prend en charge ports.
  • Impact minimal sur le chargement de la page : En effectuant le ping côté client, le chargement initial de la page n'est pas affecté.
  • Simplicité de mise en œuvre : Le code est simple et facile à intégrer applications.

Mises à jour

La solution présentée peut rencontrer des problèmes de compatibilité avec les navigateurs les plus récents. Pour les dernières mises à jour et solutions alternatives, reportez-vous au référentiel GitHub inclus :

[https://github.com/jdfreder/pingjs](https://github.com/jdfreder/pingjs)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Musée de deux points: Guide de localisation de Bungle Wasteland
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Musée de deux points: Guide de localisation de Bungle Wasteland
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Remplacer les caractères de chaîne en javascript Remplacer les caractères de chaîne en javascript Mar 11, 2025 am 12:07 AM

Remplacer les caractères de chaîne en javascript

jQuery Vérifiez si la date est valide jQuery Vérifiez si la date est valide Mar 01, 2025 am 08:51 AM

jQuery Vérifiez si la date est valide

jQuery obtient un rembourrage / marge d'élément jQuery obtient un rembourrage / marge d'élément Mar 01, 2025 am 08:53 AM

jQuery obtient un rembourrage / marge d'élément

Plugins JS de manipulation de 5 premiers Plugins JS de manipulation de 5 premiers Feb 28, 2025 am 12:34 AM

Plugins JS de manipulation de 5 premiers

10 vaut la peine de vérifier les plugins jQuery 10 vaut la peine de vérifier les plugins jQuery Mar 01, 2025 am 01:29 AM

10 vaut la peine de vérifier les plugins jQuery

10 onglets jQuery Accordion 10 onglets jQuery Accordion Mar 01, 2025 am 01:34 AM

10 onglets jQuery Accordion

jQuery Ajouter une barre de défilement à div jQuery Ajouter une barre de défilement à div Mar 01, 2025 am 01:30 AM

jQuery Ajouter une barre de défilement à div

10 Ajax / jQuery Tutoriels / plugins assortis 10 Ajax / jQuery Tutoriels / plugins assortis Feb 28, 2025 am 01:03 AM

10 Ajax / jQuery Tutoriels / plugins assortis

See all articles