"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment détecter les VPN avec JavaScript

Comment détecter les VPN avec JavaScript

Publié le 2024-11-07
Parcourir:171

How to Detect VPNs with JavaScript

Dans notre monde de plus en plus connecté, les VPN (Virtual Private Networks) offrent à la fois des avantages et des défis. Bien qu'ils aident les utilisateurs à préserver leur confidentialité et leur sécurité, ils peuvent également être utilisés à des fins malveillantes.

Nous verrons comment implémenter la détection VPN dans vos applications Web à l'aide de JavaScript et de l'API fetch. Vous pouvez utiliser n'importe quelle API de votre choix.

Pourquoi la détection VPN est importante

Avant de passer au code, explorons pourquoi la détection des VPN est importante :

  • Restrictions géographiques : Si votre service est spécifique à une région, les VPN peuvent contourner ces limites.
  • Prévention de la fraude : Les VPN peuvent masquer la véritable localisation d'un utilisateur, ce qui permet aux acteurs malveillants de commettre plus facilement des fraudes.
  • Bots : Les robots utiliseront parfois cela.

La détection des VPN garantit que votre application est utilisée comme prévu et contribue à protéger votre entreprise contre les risques potentiels.

Pour commencer : les essentiels

Pour détecter les VPN en JavaScript, nous utiliserons un service tiers comme IPQuery.io. Ce service fournit des informations détaillées sur les adresses IP, notamment si elles sont liées à des VPN, des proxys ou d'autres outils d'anonymisation.

Étape 1 : configuration de votre environnement

Gardons les choses simples avec Vanilla JavaScript. Pas besoin de bibliothèques externes : juste l'API de récupération intégrée, qui nous permet d'effectuer des requêtes HTTP et de traiter les réponses.

Étape 2 : effectuer l'appel API

Voici comment utiliser l'API fetch pour vérifier si une adresse IP est associée à un VPN :

async function detectVPN(ip) {
    const response = await fetch(`https://api.ipquery.io/${ip}`);
    const data = await response.json();

    if (data.risk.is_vpn) {
        console.log(`The IP address ${ip} is associated with a VPN.`);
    } else {
        console.log(`The IP address ${ip} is not associated with a VPN.`);
    }
}

detectVPN('1.1.1.1');

Dans cet exemple, la fonction detectVPN envoie une requête GET à l'API IPQuery, qui renvoie des informations détaillées sur l'adresse IP, notamment si elle est liée à un VPN.

Étape 3 : Gestion des demandes groupées

Besoin de vérifier plusieurs adresses IP à la fois ? IPQuery prend également en charge les recherches groupées :

async function detectVPNs(ips) {
    const response = await fetch(`https://api.ipquery.io/${ips.join(',')}`);
    const data = await response.json();

    data.forEach(ipInfo => {
        if (ipInfo.risk.is_vpn) {
            console.log(`The IP address ${ipInfo.ip} is associated with a VPN.`);
        } else {
            console.log(`The IP address ${ipInfo.ip} is not associated with a VPN.`);
        }
    });
}

// Example usage
detectVPNs(['1.1.1.1', '2.2.2.2']);

Cette fonction prend un tableau d'adresses IP, envoie une requête à l'API et vérifie chacune d'entre elles pour les associations VPN. C'est un moyen efficace de traiter plusieurs adresses simultanément.

Étape 4 : Personnalisation du format de réponse

En fonction de vos besoins, vous souhaiterez peut-être la réponse dans différents formats tels que JSON, XML ou YAML. Vous pouvez facilement spécifier le format avec un paramètre de requête :

async function detectVPN(ip, format = 'json') {
    const response = await fetch(`https://api.ipquery.io/${ip}?format=${format}`);
    const data = await response.text();  // Use .text() for non-JSON formats

    console.log(data);
}

detectVPN('1.1.1.1', 'xml');
Déclaration de sortie Cet article est reproduit sur : https://dev.to/ohwow/how-to-detect-vpns-with-javascript-4aj3?1 En cas d'infraction, veuillez contacter [email protected] pour le supprimer.
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3