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,如若转载,请注明出处:http://www.wangzhanshi.com/n/18822.html

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

相关推荐

  • Nginx中try_files指令的实现示例

    1. 简介 try_files是Nginx中一个非常强大且常用的指令,其用于按顺序检查文件是否存在,并将请求传递给第一个找到的文件,或者在所有文件都未找到时,执行一个回退URI。该…

    nginx 2024年12月17日
  • Nginx中proxy_pass的斜杠的两种方式

    1、proxy_pass的类型 Nginx的官网将proxy_pass分为两种类型: 一种是只包含IP和端口号的(连端口之后的/也没有,这里要特别注意),比如proxy_pass …

    nginx 2024年12月17日
  • Nginx解决跨域访问的完整实例

    引言 在现代的Web开发中,跨域访问是一种常见的需求。由于浏览器的同源策略,不同域名之间的访问存在一定的限制。但是,我们经常需要在不同的域名之间进行数据交互,这就需要解决跨域问题。…

    2024年12月17日
  • nginx: [emerg] unknown directive报错误的问题

    前言 今天修改Nginx中的conf配置文件,由于自己没有备份,导致出问题,解决了两个小时都没有解决掉。不过遇到问题是好事,可以解决,如果有备份遇到问题也许不会一直去解决吧。但是,…

    2024年12月17日
  • tomcat在nginx中的配置方式

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 一、下载安装tomcat 将下载的tomcat压缩包,通过ssh工具传输到linux的目录/usr/src/目录下…

    2025年2月24日
  • nginx 499错误处理及nginx的配置参数小结

    背景 近期响应集团降本增效,节省ci,stg机器,我们项目开始容器化,在改造过程中,链路的访问发生了变化,导致出现了499,解决方如下 访问链路: 域名—> EL…

    nginx 2024年12月17日
  • Linux下Nginx服务设置开机自启动的命令详解

    一、准备工作 注意:准备搭建好的nginx机器 二、操作步骤 2.1 先创建开机自启脚本 注意:使用root用户执行!!! cd /etc/systemd/system vim n…

    nginx 2024年12月17日
  • Nginx中实现请求的缓存数据过期通知

    在 Web 开发的领域中,Nginx 作为高性能的反向代理服务器,缓存机制是其优化性能的重要手段之一。然而,当缓存数据过期时,如何及时有效地通知相关模块或应用,这可是个技术活。 首…

    nginx 2024年12月17日
  • 使用Nginx搭建代理服务器(正向代理HTTPS网站)的操作指南

    一、正向代理与反向代理的区别 1.1 正向代理 正向代理位于客户端和服务器之间,代表客户端向服务器发起请求。其主要功能是隐藏客户端信息,代理客户端进行网络访问,尤其是访问某些受限资…

    nginx 2024年12月17日
  • Nginx+Keepalive实现高可用负载均衡

    引言 在互联网的高速发展下,网站的稳定性与性能成为了企业核心竞争力之一。负载均衡作为提高网站可用性和处理能力的关键技术,被广泛应用于互联网架构中。Nginx 作为一款高性能的 HT…

    nginx 2025年2月24日

发表回复

登录后才能评论