架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

搜索
查看: 75|回复: 0

[Web] (黑名单)Nginx 屏蔽国内外 IP 访问网站

[复制链接]
发表于 2025-6-6 09:07:44 | 显示全部楼层 |阅读模式
需求:使用 nginx 屏蔽一些 IP 访问网站,例如:爬虫、广告等。或者因为政策原因,需要屏蔽某个国家的 IP 地址访问。

屏蔽指定 IP 访问

Nginx提供了两个最基本的屏蔽和允许IP的命令:deny 屏蔽、allow 允许,如下:

指定目录屏蔽指定 IP 访问

在 Nginx 的配置文件中,可以使用 location 块来匹配特定的 URL 路径。比如我们想在 /foo 开头的 URL 路径中启用屏蔽,匹配所有以 /foo 开头的 URL 路径,例如 /foo/bar 和 /foo/baz/qux 等,如下:

如果要精确匹配 /foo,要使用如下配置:

也可以用正则匹配目录:

屏蔽指定国家(地区)访问

有时候我们想只允许某些地区的用户可以访问我们的网站。知道上边两个方式,剩下的问题就是怎么得到某个地区的所有IP段了。我们可以从ip2location中获取。地址:超链接登录可见。

框左边选择国家,中间框选V4还是V6,右边选择规则类型,根据需要选择即可。以日本为例:

QQ截图20250606090142.jpg

下载完解压得到 txt 文件,删除最开始的 location / { 和最后的 } 最后增加一行 allow all; 将后缀名从 .txt 改为 .conf 上传到服务器上,记住放置的目录。(比如 /usr/local/nginx/conf/nginx.conf/firewall.conf)

QQ截图20250606090458.jpg

修改站点对应的 Nginx 配置文件,比如 /foo 目录只允许非日本的 IP 访问:

如果你想全站生效可以写到 sever 或者 http 字段,例如:

然后输入如下命令,重新加载 nginx 配置:




上一篇:X++ 请求 https 接口“未能创建 SSL/TLS 安全通道”问题
下一篇:Jenkins(八)禁用发送匿名使用统计
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2025-6-15 22:30

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表