Maison Opération et maintenance Nginx Comment Nginx implémente la configuration du contrôle d'accès en fonction de l'emplacement géographique de la source de la requête

Comment Nginx implémente la configuration du contrôle d'accès en fonction de l'emplacement géographique de la source de la requête

Nov 08, 2023 am 11:18 AM
nginx 访问控制 地理位置

Comment Nginx implémente la configuration du contrôle daccès en fonction de lemplacement géographique de la source de la requête

La manière dont Nginx implémente la configuration du contrôle d'accès en fonction de l'emplacement géographique de la source de la requête nécessite des exemples de code spécifiques

Introduction :
Avec le développement d'Internet, il est devenu normal que des utilisateurs de différentes régions accèdent à des sites Web. Parfois, nous souhaitons effectuer une configuration de contrôle d'accès ciblée en fonction de l'emplacement géographique de la source de la demande. En tant que serveur proxy inverse hautes performances, Nginx peut non seulement mettre en œuvre l'équilibrage de charge et la mise en cache HTTP, mais également configurer le contrôle d'accès en fonction de l'emplacement géographique de la source de la requête. Cet article expliquera comment utiliser Nginx pour implémenter la configuration du contrôle d'accès en fonction de l'emplacement géographique de la source de la requête et fournira des exemples de code spécifiques.

1. Obtenir l'emplacement géographique de la source de la demande
Avant de mettre en œuvre la configuration du contrôle d'accès basée sur l'emplacement géographique de la source de la demande, nous devons obtenir les informations de localisation géographique de la source de la demande. Une méthode courante consiste à utiliser une base de données IP tierce pour interroger l'emplacement géographique correspondant à l'adresse IP demandée.

1.1 Télécharger la base de données IP
Tout d'abord, nous devons télécharger une base de données IP, qui contient la relation de mappage entre les adresses IP et les emplacements géographiques. Actuellement, les bases de données IP les plus couramment utilisées incluent la base de données GeoIP2 de MaxMind et la base de données IP de Taobao. Dans cet article, nous utilisons la base de données GeoIP2 de MaxMind à des fins de démonstration.

Vous pouvez télécharger le fichier de base de données GeoIP2 (généralement un fichier .mmdb) sur le site officiel de MaxMind et l'enregistrer localement.

1.2 Installer le module GeoIP2
Ensuite, nous devons installer le module GeoIP2 dans Nginx afin d'utiliser la base de données pour interroger les informations de localisation géographique correspondant à l'adresse IP demandée.

Tout d'abord, ouvrez le répertoire du code source Nginx et entrez le répertoire ngx_http_geoip2_module sous le dossier modules. Exécutez la commande suivante pour télécharger le module GeoIP2 :

git clone https://github.com/leev/ngx_http_geoip2_module.git
Copier après la connexion

Ensuite, retournez dans le répertoire source de Nginx et exécutez la commande config pour configurer les options de compilation :

./configure --add-module=modules/ngx_http_geoip2_module
Copier après la connexion

Enfin, exécutez les commandes make et make install pour compiler et installer Nginx.

1.3 Configurer le module GeoIP2
Dans le fichier de configuration Nginx, nous devons configurer le module GeoIP2 pour indiquer à Nginx d'interroger les informations de localisation géographique de l'adresse IP à partir du fichier de base de données spécifié.

Ajoutez la configuration suivante dans le bloc http :

geoip2 /path/to/your/database/GeoLite2-Country.mmdb {
    $geoip2_data_country_code country iso_code;
}
Copier après la connexion

Ici "/path/to/your/database/GeoLite2-Country.mmdb" est le chemin d'accès au fichier de base de données GeoIP2 que vous avez téléchargé. "$geoip2_data_country_code" est une variable qui enregistrera les résultats de la requête. "country" indique que la requête est le code du pays et "iso_code" indique le nom du champ où les résultats sont enregistrés dans la variable.

  1. Configuration du contrôle d'accès basée sur la localisation géographique de la source de la demande
    Après avoir obtenu les informations de localisation géographique de la source de la demande, nous pouvons configurer le contrôle d'accès selon les besoins.

2.1 Autoriser l'accès à des emplacements géographiques spécifiques

location / {
    if ($geoip2_data_country_code = "CN") {
        allow;
    }
    deny;
}
Copier après la connexion

Dans cette configuration, nous utilisons la directive if et la variable $geoip2_data_country_code pour déterminer si l'emplacement géographique demandé est la Chine (le code est "CN"). S’il s’agit de la Chine, l’accès est autorisé ; sinon, l’accès est refusé.

2.2 Interdire l'accès à des emplacements géographiques spécifiques

location / {
    if ($geoip2_data_country_code = "US") {
        deny;
    }
    allow;
}
Copier après la connexion

Dans cette configuration, si l'emplacement géographique demandé est les États-Unis (le code est "US"), l'accès sera directement refusé sinon, l'accès sera autorisé ;

2.3 Autres configurations de contrôle d'accès
En plus du contrôle d'accès basé sur le code du pays, il peut également être configuré en fonction d'informations de localisation géographique spécifiques. Par exemple, le contrôle d'accès peut être effectué en fonction de la ville, de la latitude, de la longitude et d'autres informations.

location / {
    if ($geoip2_data_city_name = "Shanghai" && $geoip2_data_latitude > 31.2 && $geoip2_data_latitude < 31.3) {
        allow;
    }
    deny;
}
Copier après la connexion

Dans cette configuration, nous déterminons si la localisation géographique demandée est Shanghai et la latitude est comprise entre 31,2 et 31,3. Si les conditions sont remplies, l’accès est autorisé ; sinon, l’accès est refusé.

Conclusion : 
En utilisant le module GeoIP2 de Nginx, nous pouvons facilement implémenter une configuration de contrôle d'accès basée sur l'emplacement géographique de la source de la requête. Tout d’abord, nous avons téléchargé une base de données IP pour interroger les informations de localisation géographique des adresses IP. Ensuite, installez et configurez le module GeoIP2 afin que Nginx puisse utiliser cette base de données pour interroger des informations de localisation géographique. Enfin, la configuration du contrôle d'accès est effectuée sur la base des résultats de la requête, et un contrôle d'accès basé sur l'emplacement géographique de la source de la requête est mis en œuvre.

Bien sûr, il ne s'agit que d'un exemple simple, et les scénarios d'application réels peuvent être plus complexes. En utilisation réelle, nous pouvons également combiner d'autres modules et fonctions, tels que le proxy inverse HTTP, l'équilibrage de charge, etc., pour obtenir une configuration de contrôle d'accès plus flexible et plus efficace.

Exemple de code :

geoip2 /path/to/your/database/GeoLite2-Country.mmdb {
    $geoip2_data_country_code country iso_code;
}

location / {
    if ($geoip2_data_country_code = "CN") {
        allow;
    }
    deny;
}
Copier après la connexion

Ce qui précède est une introduction détaillée et un exemple de code spécifique d'utilisation de Nginx pour implémenter la configuration du contrôle d'accès en fonction de l'emplacement géographique de la source de la demande. De cette manière, nous pouvons facilement contrôler l'accès en fonction de la localisation géographique de la demande et améliorer la sécurité et la fiabilité du site Web. J'espère que cet article vous aidera !

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

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)

Comment résoudre nginx403 Comment résoudre nginx403 Apr 14, 2025 am 10:33 AM

Comment corriger l'erreur interdite Nginx 403? Vérifier les autorisations de fichier ou de répertoire; 2. Vérifier le fichier .htaccess; 3. Vérifiez le fichier de configuration NGINX; 4. Redémarrer Nginx. D'autres causes possibles incluent les règles de pare-feu, les paramètres de Selinux ou les problèmes d'application.

Comment résoudre l'erreur Nginx403 Comment résoudre l'erreur Nginx403 Apr 14, 2025 pm 12:54 PM

Le serveur n'a pas l'autorisation d'accéder à la ressource demandée, ce qui donne une erreur NGINX 403. Les solutions incluent: vérifier les autorisations de fichiers. Vérifiez la configuration .htaccess. Vérifiez la configuration de Nginx. Configurez les autorisations Selinux. Vérifiez les règles du pare-feu. Dépanner d'autres causes telles que les problèmes de navigateur, les défaillances du serveur ou d'autres erreurs possibles.

Comment démarrer Nginx dans Linux Comment démarrer Nginx dans Linux Apr 14, 2025 pm 12:51 PM

Étapes pour démarrer Nginx dans Linux: Vérifiez si Nginx est installé. Utilisez SystemCTL Start Nginx pour démarrer le service NGINX. Utilisez SystemCTL Activer Nginx pour activer le démarrage automatique de Nginx au démarrage du système. Utilisez SystemCTL Status Nginx pour vérifier que le démarrage est réussi. Visitez http: // localhost dans un navigateur Web pour afficher la page de bienvenue par défaut.

Comment configurer Nginx dans Windows Comment configurer Nginx dans Windows Apr 14, 2025 pm 12:57 PM

Comment configurer Nginx dans Windows? Installez Nginx et créez une configuration d'hôte virtuelle. Modifiez le fichier de configuration principale et incluez la configuration de l'hôte virtuel. Démarrer ou recharger nginx. Testez la configuration et affichez le site Web. Activer sélectivement SSL et configurer les certificats SSL. Définissez sélectivement le pare-feu pour permettre le trafic Port 80 et 443.

Comment configurer l'équilibrage de charge dans nginx Comment configurer l'équilibrage de charge dans nginx Apr 14, 2025 am 08:33 AM

Comment configurer Nginx pour l'équilibrage de charge? Définit le pool de serveur en amont et spécifie l'IP et le port du serveur. Définissez les hôtes virtuels, écoutez les connexions et transmettez-les au pool en amont. Spécifiez l'emplacement, faites correspondre la demande et transmettez-le au pool en amont.

Comment vérifier l'état de course de Nginx Comment vérifier l'état de course de Nginx Apr 14, 2025 am 11:48 AM

Les méthodes pour afficher l'état en cours d'exécution de Nginx sont: utilisez la commande PS pour afficher l'état du processus; Afficher le fichier de configuration Nginx /etc/nginx/nginx.conf; Utilisez le module d'état NGINX pour activer le point de terminaison d'état; Utilisez des outils de surveillance tels que Prometheus, Zabbix ou Nagios.

Comment résoudre l'erreur Nginx304 Comment résoudre l'erreur Nginx304 Apr 14, 2025 pm 12:45 PM

Réponse à la question: 304 Erreur non modifiée indique que le navigateur a mis en cache la dernière version de ressource de la demande du client. Solution: 1. Effacer le cache du navigateur; 2. Désactiver le cache du navigateur; 3. Configurer Nginx pour permettre le cache client; 4. Vérifier les autorisations du fichier; 5. Vérifier le hachage du fichier; 6. Désactiver le CDN ou le cache proxy inversé; 7. Redémarrez Nginx.

Comment vérifier si Nginx est démarré Comment vérifier si Nginx est démarré Apr 14, 2025 pm 01:03 PM

Comment confirmer si Nginx est démarré: 1. Utilisez la ligne de commande: SystemCTl Status Nginx (Linux / Unix), netStat -ano | Findstr 80 (Windows); 2. Vérifiez si le port 80 est ouvert; 3. Vérifiez le message de démarrage NGINX dans le journal système; 4. Utilisez des outils tiers, tels que Nagios, Zabbix et Icinga.

See all articles