Nginx拒绝国外地址访问网站

文章描述了在Linux环境中,如何安装Nginx、GeoIP数据库以及相关依赖(pcre、zlib、libmaxminddb),然后配置Nginx以使用GeoIP数据库进行访问控制,通过HTTP地图块和服务器块设置实现了针对不同国家的IP访问限制,例如对特定国家返回403Forbidden响应。

[root@devonl ~]# cd /usr/local/src/

[root@devonl src]# ls

libmaxminddb-1.6.0.tar.gz  nginx-1.6.0.tar.gz  ngx_http_geoip2_module-master.zip  pcre-8.35.tar.gz  zlib-1.2.8.tar.gz

[root@devonl src]# cd /usr/share/GeoIP/

[root@devonl GeoIP]# ls

GeoIP.dat  GeoIP-initial.dat  GeoIPv6.dat  GeoIPv6-initial.dat  GeoLite2-City.mmdb  GeoLite2-Country.mmdb

  • 解压所有压缩包文件

[root@devonl src]# tar xf libmaxminddb-1.6.0.tar.gz

[root@devonl src]# tar xf nginx-1.6.0.tar.gz

[root@devonl src]# tar xf pcre-8.35.tar.gz

[root@devonl src]# tar xf zlib-1.2.8.tar.gz

[root@devonl src]# unzip ngx_http_geoip2_module-master.zip

  • 安装pcre、zlib、libmaxminddb、nginx

[root@devonl src]# cd pcre-8.35/

[root@devonl pcre-8.35]# ./configure

[root@devonl pcre-8.35]# make

[root@devonl pcre-8.35]# make install

[root@devonl pcre-8.35]# cd ..

[root@devonl src]# cd zlib-1.2.8/

[root@devonl zlib-1.2.8]# ./configure

[root@devonl zlib-1.2.8]# make

[root@devonl zlib-1.2.8]# make install

[root@devonl nginx-1.6.0]# cd ..

[root@devonl src]# cd libmaxminddb-1.6.0/

[root@devonl libmaxminddb-1.6.0]# ./configure

[root@devonl libmaxminddb-1.6.0]# make

[root@devonl libmaxminddb-1.6.0]# make install

[root@devonl libmaxminddb-1.6.0]# echo '/usr/local/lib' > /etc/ld.so.conf.d/geoip.conf

[root@devonl libmaxminddb-1.6.0]# ldconfig

[root@devonl libmaxminddb-1.6.0]# cd .. /nginx-1.6.0/

[root@devonl nginx-1.6.0]# ./configure --prefix=/usr/local/nginx --with-pcre=/usr/local/src/pcre-8.35 --with-zlib=/usr/local/src/zlib-1.2.8 --add-module=/usr/l

ocal/src/ngx_http_geoip2_module-master

[root@devonl nginx-1.6.0]# make

[root@devonl nginx-1.6.0]# make install

[root@devonl nginx]# ./sbin/nginx -V

nginx version: nginx/1.6.0

built by gcc 4.8.5 20150623 (Red Hat 4.8.5-44) (GCC)

configure arguments: --prefix=/usr/local/nginx --with-pcre=/usr/local/src/pcre-8.35 --with-zlib=/usr/local/src/zlib-1.2.8 --add-module=/usr/local/src/ngx_http_geoip2_module-master

  • 在http字段里加入配置文件

048f209a09064f2ab8f163ff1ec3da84.png

    map $geoip2_data_country_code $allowed_country {

        CN no;

        default yes;

    }

 

    geoip2 /usr/share/GeoIP/GeoLite2-Country.mmdb {

      $geoip2_country_code country iso_code;

    }

    geoip2 /usr/share/GeoIP/GeoLite2-City.mmdb {

      $geoip2_data_country_code default=China source=$remote_addr country iso_code;

      $geoip2_data_country_name country names en;

      $geoip2_data_city_name city names en;

      $geoip2_data_province_name subdivisions 0 names en;

      $geoip2_data_province_isocode subdivisions 0 iso_code;

      $geoip2_continent_code continent code;

}

Server字段添加

d79243bcaba2465f9eab93cc7bd79e1c.png

        if ($allowed_country = yes) {

            return 403;

        }

  • 配置IP测试服务,server字段中添加location字段

location /myip {

            default_type text/plain;

            return 200 "$remote_addr $geoip2_data_city_name $geoip2_country_code $geoip2_continent_code\n";

        }

[root@devonl nginx]# ./sbin/nginx -t

  • 访问测试

f2e4c7d9f68e4407a37c71997b718579.png

4a1a19a65f924d77b8ed74c5e56a1996.png

新加坡地址访问403Forbidden

5144c6ea6aa847aeb1af8bb9e57ad2ac.png

日本东京

478af5bbdaef42cda606ce4a8f909634.png

be5df78c7b0549d6b0136b3c738abc30.png

 

要配置 Nginx 以阻止特定 IP 地址访问,可以使用 `deny` 指令来实现。该指令通常放在 `http`, `server`, 或 `location` 块中,具体取决于需要限制的范围。例如,若希望在整个站点范围内阻止某个 IP 地址,可以在 `server` 块中添加如下配置: ```nginx location / { deny 192.168.1.1; # 其他访问控制规则或代理设置 } ``` 如果需要阻止多个 IP 地址,可以依次列出每个 `deny` 指令: ```nginx location / { deny 192.168.1.1; deny 10.0.0.2; # 其他访问控制规则或代理设置 } ``` 此外,也可以结合 `allow` 和 `deny` 来实现更复杂的访问控制策略。例如,先拒绝所有请求,然后仅允许某些 IP 地址访问: ```nginx location / { deny 192.168.1.1; deny 10.0.0.2; allow all; # 其他访问控制规则或代理设置 } ``` 上述规则在匹配过程中,Nginx 会按照配置文件中的顺序依次检查 `deny` 和 `allow` 指令,并根据第一个匹配的规则决定是否允许访问[^2]。 如果希望阻止来自特定国家或地区的访问,可以借助 IP 地理数据库(如 GeoIP)与 `geoip_country` 模块配合使用。这需要事先安装 MaxMind 的 GeoIP 数据库,并启用 Nginx 的 `--add-module=../ngx_http_geoip_module` 编译选项。之后,在配置文件中定义一个变量来表示地理位置,并基于该变量进行访问控制: ```nginx geoip_country /etc/nginx/GeoIP.dat; map $geoip_country_code $allow_country { default no; US yes; CA yes; } server { if ($allow_country = no) { return 403; } # 其他 server 配置 } ``` 以上方法能够灵活地控制哪些客户端 IP 可以访问服务器资源,从而增强网站的安全性。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DevonL77

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值