【Nginx】如何在 Nginx 中阻止来自特定国家的 IP 地址访问

2024-05-11 04:44

本文主要是介绍【Nginx】如何在 Nginx 中阻止来自特定国家的 IP 地址访问,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、准备工作
  • 二、查看 Nginx 服务器都拥有哪些模块
    • 2.1 先查看本地nginx是否有ngx_http_geoip2模块
    • 2.2 安装nginx并配置ngx_http_geoip2模块
      • 2.2.1下载所需版本的nginx到服务器
      • 2.2.2 先安装所需依赖
      • 2.2.3 解压文件
      • 2.2.4 下载ngx_http_geoip2模块
      • 2.2.5 编译安装nginx并指定ngx_http_geoip2_module所在目录
      • 2.2.6 编译安装
    • 3.1 加载 IP 地理位置数据库
    • 3.2 配置拦截规则
    • 3.3 应用拦截规则
    • 3.4 重新加载 Nginx
  • 总结


前言

在网络安全方面,有时你可能需要限制特定国家或地区的访问权限。本文将介绍如何使用 Nginx 配置文件来阻止来自特定国家或地区的 IP 地址访问你的网站。

一、准备工作

首先,确保你的 Nginx 服务器已经安装并正确配置ngx_http_geoip2 模块。另外,你需要获取一个 IP 地理位置数据库文件,通常是 GeoLite2 数据库,以便识别 IP 地址所属的国家或地区。具体步骤如下:

二、查看 Nginx 服务器都拥有哪些模块

2.1 先查看本地nginx是否有ngx_http_geoip2模块

nginx -V

在这里插入图片描述
没有我们所需的模块,如果有的同学有该模块可以直接跳到下面直接配置nginx服务
在这里插入图片描述

在 Nginx 的配置文件中,添加以下代码以加载 IP 地理位置数据库文件:

2.2 安装nginx并配置ngx_http_geoip2模块

本次使用的nginx是编译安装的方式,如果能找到本地的nginx编译的文件在哪就不用重新下载nginx,如果找不到请重新编译安装

2.2.1下载所需版本的nginx到服务器

下载地址

2.2.2 先安装所需依赖

yum install -y libmaxminddb-devel pcre-devel zlib-devel gcc gcc-c++ make git

2.2.3 解压文件

tar -xvzf nginx-1.24.0.tar.gz

2.2.4 下载ngx_http_geoip2模块

在服务上下载模块

git clone https://github.com/leev/ngx_http_geoip2_module.git

2.2.5 编译安装nginx并指定ngx_http_geoip2_module所在目录

切换到nginx所在目录

./configure --prefix=/nginxtest \--user=nginx \--group=nginx \--with-pcre \--with-http_ssl_module \--with-http_v2_module \--with-http_realip_module \--with-http_addition_module \--with-http_sub_module \--with-http_dav_module \--with-http_flv_module \--with-http_mp4_module \--with-http_gunzip_module \--with-http_gzip_static_module \--with-http_random_index_module \--with-http_secure_link_module \--with-http_stub_status_module \--with-http_auth_request_module \--with-http_image_filter_module \--with-http_slice_module \--with-mail \--with-threads \--with-file-aio \--with-stream \--with-mail_ssl_module \--with-stream_ssl_module \--add-module=/usr/local/ngx_http_geoip2_module

解释一下参数的含义
当你运行./configure时,你正在配置nginx的编译选项。以下是每行命令的解释:

–prefix=/nginxtest: 指定nginx的安装目录为/nginxtest,这意味着nginx将安装到该目录下。

–user=nginx: 指定nginx运行时的用户为nginx,这是为了增加安全性,以防止nginx以超级用户权限运行。

–group=nginx: 指定nginx运行时的用户组为nginx,与上述相似,也是为了增加安全性。

–with-pcre: 启用PCRE(Perl Compatible Regular Expressions)库,用于支持正则表达式。

–with-http_ssl_module: 启用HTTP SSL模块,支持HTTPS协议。

–with-http_v2_module: 启用HTTP/2模块,支持HTTP/2协议。

–with-http_realip_module: 启用HTTP RealIP模块,允许nginx在代理模式下获取真实的客户端IP地址。

–with-http_addition_module: 启用HTTP Addition模块,允许在响应中添加内容。

–with-http_sub_module: 启用HTTP Substitution模块,允许在响应中替换内容。

–with-http_dav_module: 启用HTTP DAV(WebDAV)模块,支持WebDAV协议。

–with-http_flv_module: 启用HTTP FLV模块,支持Flash视频流。

–with-http_mp4_module: 启用HTTP MP4模块,支持MP4视频流。

–with-http_gunzip_module: 启用HTTP GUNZIP模块,用于解压缩响应中的gzip压缩数据。

–with-http_gzip_static_module: 启用HTTP Gzip Static模块,用于在发送静态文件时压缩数据。

–with-http_random_index_module: 启用HTTP Random Index模块,允许nginx在目录中选择一个随机文件作为索引。

–with-http_secure_link_module: 启用HTTP Secure Link模块,用于生成带有安全签名的URL。

–with-http_stub_status_module: 启用HTTP Stub Status模块,允许监控nginx的状态信息。

–with-http_auth_request_module: 启用HTTP Auth Request模块,允许在需要认证时向另一个服务器发送认证请求。

–with-http_image_filter_module: 启用HTTP Image Filter模块,允许对图像进行处理。

–with-http_slice_module: 启用HTTP Slice模块,允许nginx按指定大小切片响应。

–with-mail: 启用邮件代理服务器功能。

–with-threads: 启用线程支持。

–with-file-aio: 启用文件异步IO支持。

–with-stream: 启用TCP/UDP流代理功能。

–with-mail_ssl_module: 启用邮件SSL模块,支持SSL加密的邮件传输。

–with-stream_ssl_module: 启用流SSL模块,支持SSL加密的TCP/UDP流。

--add-module=/usr/local/ngx_http_geoip2_module: 添加额外的模块ngx_http_geoip2_module,该模块用于GeoIP2地理定位功能。

2.2.6 编译安装

添加 nginx 模块,只需要编译,然后 make。不需要 make instll,不然线上的 nginx 会被新版本 nginx 完完整整的替换掉。完成后只需要覆盖替换就可以
在这里插入图片描述

make -j2 && make install #安装,重新安装的需要make install

结束查看一下是否安装成功

ln -s /nginxtest/nginx/sbin/nginx /usr/local/sbin/ #让系统识别nginx的操作命令
nginx- V

在这里插入图片描述
三、添加拦截规则配置

先下载 IP 地理位置数据库文件

3.1 加载 IP 地理位置数据库

nginx
http {# 加载 GeoIP 数据库文件geoip2 /path/to/GeoLite2-Country.mmdb { # 指定 GeoIP2 数据库文件路径auto_reload 60m; # 每 60 分钟自动重新加载数据库文件$geoip2_metadata_country_build metadata build_epoch; # 获取数据库元数据$geoip2_data_country_code country iso_code; # 获取 IP 所属国家的 ISO 代码}
}

3.2 配置拦截规则

在配置文件中添加拦截规则,指定你要阻止的国家或地区。以下是一个示例:

nginx
http {# 设置拦截规则map $geoip2_data_country_code $allowed_country {default yes; # 默认情况下允许访问CN no; # 指定中国 IP 地址不被拦截}
}

在这里插入图片描述

3.3 应用拦截规则

在你的服务器块或虚拟主机配置中,使用 if 指令结合上述定义的 map 指令来应用拦截规则:

nginx
server {listen 80;server_name example.com;if ($allowed_country = yes) { # 如果 IP 地址所属国家被标记为不允许访问return 403; # 返回 403 Forbidden 错误页面}# 其他配置项
}

3.4 重新加载 Nginx

完成配置后,重新加载或重启 Nginx 以使更改生效:

nginx -s reload

这样配置后,Nginx 将会拦截来自指定国家或地区的 IP 请求,并返回 403 Forbidden 错误页面。

在这里插入图片描述

总结

通过简单的 Nginx 配置,你可以有效地限制来自特定国家或地区的 IP 地址访问你的网站。这种措施有助于加强你的网络安全,保护你的服务器免受潜在的恶意攻击。

这篇关于【Nginx】如何在 Nginx 中阻止来自特定国家的 IP 地址访问的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/978539

相关文章

通过高德api查询所有店铺地址信息

通过高德api查询所有店铺地址电话信息 需求:通过高德api查询所有店铺地址信息需求分析具体实现1、申请高德appkey2、下载types city 字典值3、具体代码调用 需求:通过高德api查询所有店铺地址信息 需求分析 查询现有高德api发现现有接口关键字搜索API服务地址: https://developer.amap.com/api/webservice/gui

时间服务器中,适用于国内的 NTP 服务器地址,可用于时间同步或 Android 加速 GPS 定位

NTP 是什么?   NTP 是网络时间协议(Network Time Protocol),它用来同步网络设备【如计算机、手机】的时间的协议。 NTP 实现什么目的?   目的很简单,就是为了提供准确时间。因为我们的手表、设备等,经常会时间跑着跑着就有误差,或快或慢的少几秒,时间长了甚至误差过分钟。 NTP 服务器列表 最常见、熟知的就是 www.pool.ntp.org/zo

vue3项目将所有访问后端springboot的接口统一管理带跨域

vue3项目将所有访问后端springboot的接口统一管理带跨域 一、前言1.安装Axios2.创建Axios实例3.创建API服务文件4.在组件中使用API服务 二、跨域三、总结 一、前言 在Vue 3项目中,统一管理所有访问后端Spring Boot接口的最佳实践是创建一个专门的API服务层。这可以让你的代码更加模块化、可维护和集中管理。你可以使用Axios库作为HTT

[vivado][IP核]FFT

刘东华的IP核详解: 1、 2、

[vivado][IP核]DDS

刘东华的IP核详解: 1、 这里的是指IP核配置中的相位数据的宽度。 2、 实际使用此IP核时并没有“频率分辨率”可以配,是靠改变来变的。 3、 4、 5、 数据输出的ready在数据正式输出时才会有。 自己仿真: 使用SIN/COS LUT only的模式,使用一个累加器作为相位输入,不知怎么,输出为X。

[ip核][vivado]aurora

Xapp1193:  discovered:1)并不是所有芯片都支持aurora.xc7z010就没有。                     2)XDC文件的指令-允许未约束的引脚的存在:                 set_property BITSTREAM.General.UnconstrainedPins {Allow} [current_design] PG046

[ip核][vivado]Block Menory Gennerator 学习

<刘东华的xilinx系列FPGA芯片IP核详解>读书摘录: 1. 2. 3.

[ip核][vivado]FIFO 学习

<xlinx FPGA应用进阶 通用IP核详解和设计开发>读书摘录: 1.        2.3.仿真模型 特点总结:1)复位后会有busy状态,需要等待wr_rst_busy信号低电平后才能正常写入                  2)prog_full信号的高电平长度可调                  3)仿真中的读状态很奇怪,并没有正常读取,都是XXX的状态。 所用的te

开启青龙 Ninja 扫码功能失效后修改成手动填写CK功能【修正Ninja拉库地址】

国内:进入容器docker exec -it qinglong bash #获取ninjagit clone -b main https://ghproxy.com/https://github.com/wjx0428/ninja.git /ql/ninja#安装cd /ql/ninja/backend && pnpm install cp .env.example .env

局域网内vue2 配置本地IP地址访问项目

在日常开发中同事可能需要访问你的前端项目,可以通过配置实现通过ip访问 一.首先找到config文件夹目录下的 index.js文件             将此处的host的值修改为0.0.0.0(即 host: 0.0.0.0) // Various Dev Server settings//host: 'localhost' //将localhost进行替换成 0.0.0.0host: