Nginx限制特定IP访问自己的网站实现的几种方法

需求

一个网站只想被国内访问,或者只想被一个省或一个市访问,或者只允许特定的IP或IP段访问,或者禁止特定的IP或IP段访问。我知道的有三个方法:

  • 购买云服务器厂商的相关服务,它们能做到,结果相对准确;
  • 购买查询IP的网站的服务,写个中间件,自己的网站收到请求时根据IP去查归属地,然后根据业务需要直接允许或阻止本次请求,结果相对准确,但每次收到请求都去查询的话费用较高;
  • 购买离线的IP库,在Nginx中做配置,结果相对不准确,一次性付费,后续更新另外付费。

云服务器厂商的服务和查询IP的网站的服务,相对来说更准确,IP数量更完整,更新更及时;离线的IP库,由于数据源未知,相对来说不准确,IP数量不完整,更新不一定及时。

使用Nginx实现

 我用了宝塔,网站里添加了多个站点,每个站点都单独配置。

以内网IP为例,公网IP同理。以下配置都写在Nginx配置的server块中(也可以写在location中),IP支持一个一个写,也支持CIDR形式,公网IP的CIDR形式可以在ip138上查,准确性不知道。已知具体的IP段,有网站在线转换成CIDR形式,但我发现不同的网站转出的结果不同,最好还是手动计算验证下。

只允许192.168.1.X的IP访问,其他IP禁止访问。deny all;不能写在allow前面,会导致阻止所有的访问。

allow 192.168.1.1/24;
deny all;

禁止192.168.1.1、192.168.1.2、192.168.1.3访问,允许其他IP访问。

deny 192.168.1.1;
deny 192.168.1.2;
deny 192.168.1.3;
allow all;

被阻止访问时,页面显示403 Forbidden。

如果有大量的IP需要写,可以将上面的语句写在文件里,然后在server块中导入这个文件。这样在同一个服务器中有多个站点都需要这个同样的配置时,容易维护,后面更新IP只需要更新这个文件的内容,不用把每个站点的Nginx配置都改一遍。更新文件中的IP后,需重载Nginx配置才生效。

include /home/ip_limit/ip_limit.conf;

自定义403页面

403页面可以自定义,同样是在Nginx配置的server块中(也可以写在location中)。将页面写在/home/ip_limit/403_my.html,这个html中如果有图片,最好写死成base64,原因后面再说。最好不要用403.html这个文件名,可能和网站根目录中宝塔自动生成的默认403页面冲突,导致自定义403页面不生效。

我的网站只允许指定城市访问,所以Nginx中我配置了allow xxx和deny all;,这样会导致在其他城市访问时还是403 Forbidden,自定义的403页面不生效,所以需要单独设置这个自定义403页面为允许所有的访问。

error_page 403 /403_my.html;
location /403_my.html {
  allow all;  #不加会由于前面的allow和deny all导致阻止加载这个自定义的403页面,从而自定义403页面不生效
  root /home/ip_limit;
  internal;  # 防止直接访问这个页面,不加也行
}

403页面中的图片问题

做完上面的配置后,如果自定义403页面中的图片不是写死成base64,会发现被阻止访问时,页面中的图片没加载出来(img标签中src="./403.png"),然后查了资料在Nginx配置的server块中加了下面的内容,这样自定义403页面中的图片确实可以加载了(前提是这个图片在这里的root处设置的路径中,同理src的值也要做相应的调整),但正常访问网站时有的图片无法加载了。可能因这个设置导致网站的所有图片都从这里设置的路径中加载,但实际无法加载的图片没存放在这里。所以这个配置不具有通用性,还有个方法我没试,就是不加这个配置,把自定义403页面中的图片的src换成一个可加载的网络url。

location ~ .*\.(png|jpg|jpeg|gif|svg|ico){
  allow all;
  root /www/wwwroot/test/web;
}

最简单省事的方法是,不加这个配置,自定义403页面中的图片写死成base64。

允许所有人访问网站中的静态文件

我的网站只允许指定城市访问,但网站中提供一些静态文件可供所有人访问或下载,同样是在Nginx配置的server块中。

location /apk/user.apk { # app下载,不加会由于ip策略无法访问
  allow all;
}

单独放行网站中的一个接口

我的网站只允许指定城市访问,但要单独放行网站中的一个接口,例如文件上传接口,同样是在Nginx配置的server块中。假设公网接口是http://公网IP/oss/upload,对应的内网服务是http://192.168.1.1:9966/oss/upload。

location /oss/upload { # 文件上传接口,不设访问限制
  proxy_pass http://192.168.1.1:9966/oss/upload/; # 注意location末尾没斜线,这里末尾有斜线
  allow all;
}

参考链接

Nginx全面配置 – 知乎 (zhihu.com)

nginx 自定义 404、50x 错误页面_nginx 504超时时指定一个html界面-CSDN博客

Nginx配置自定义的403页面 – Mr.peter – 博客园 (cnblogs.com)

到此这篇关于Nginx限制特定IP访问自己的网站实现的文章就介绍到这了,更多相关Nginx限制特定IP访问内容请搜索恩蓝小号以前的文章或继续浏览下面的相关文章希望大家以后多多支持恩蓝小号!

原创文章,作者:EKRJQ,如若转载,请注明出处:https://www.wangzhanshi.com/n/18822.html

(0)
EKRJQ的头像EKRJQ
上一篇 2025年2月24日 07:37:35
下一篇 2025年2月24日 07:37:37

相关推荐

  • Nginx 缓存清理的具体实现

    Nginx 作为一个高效的 Web 服务器和反向代理服务器,在提供快速的页面响应和优化 Web 性能方面起着至关重要的作用。Nginx 的缓存机制通过存储来自后端服务器或客户端的请…

    nginx 2025年2月24日
  • 浅析Nginx如何实现接口分流

    在 Nginx 中实现接口分流可以通过配置 location 块以及反向代理来完成。这种方法允许根据不同的 URL 路径、请求方法或者请求头等特征,将请求转发到不同的后端服务或处理…

    nginx 2024年12月17日
  • nginx的请求转发配置过程

    Nginx的使用(windows环境) linux也和此类似 去官网下载nginx后解压 在当前目录打开cmd窗口输入nginx.exe 即可启动服务 若想停止当前服务 输入命令n…

    2025年2月24日
  • Nginx配置ssl支持https全过程(docker版)

    在Docker中配置Nginx以使用SSL(即HTTPS)主要涉及几个步骤: 准备SSL证书和密钥、编写Nginx配置文件以使用这些证书,以及通过Docker容器运行Nginx。 …

    nginx 2024年12月17日
  • nginx代理本地文件夹如何获取数据

    安装nginx 下载地址 1. 下载windows稳定版 2. 解压即用 3. 双击nginx.exe启动nginx服务(浏览器访问 http://localhost:80/ 出现…

    2025年2月24日
  • Nginx+keepalived双机热备技术实践

    前言 在互联网的高可用性 服务中,单一的服务节点往往无法满足业务对稳定性和可用性的要求。双机热备是一种常见的高可用性解决方案,它通过两台服务器同时运行相同的服务,并使用 Keepa…

    nginx 2025年2月24日
  • nginx文件上传下载控制的实现示例

    上传大小控制 client_max_body_size 设置最大客户端请求体大小 默认大小1M,可以使用在http, server, location块。 根据不同的请求路径设置不…

    nginx 2025年2月24日
  • Nginx中的root和alias指令示例详解

    Nginx是一种强大的Web服务器和反向代理服务器,广泛用于提供静态文件服务、负载均衡以及作为HTTP缓存。在配置Nginx时,root和alias是两个重要但经常令人混淆的指令,…

    nginx 2024年12月17日
  • Nginx安装nginx-rtmp-module模块的实现

    nginx-rtmp-module 是一个用于 Nginx 的第三方模块,它使 Nginx 能够支持实时多媒体流的传输和处理。RTMP(Real-Time Messaging Pr…

    nginx 2025年2月24日
  • Nginx使用mirror指令实现接口复制

    在Nginx中,使用mirro指令可以方便地实现接口请求的复制。这个功能非常适合用于流量监控、数据收集或负载均衡。以下是一个具体示例,展示如何配置Nginx以实现接口请求的镜像。 …

    nginx 2024年12月17日

发表回复

登录后才能评论