nginx 限制特定用户的ip访问
情况:限制用户admin访问网站
1、不分内网外的情况
修改nginx.cong,在admin用户下添加要限制的ip192.168.1.33(只允许admin在192.168.1.33的ip地址下访问)
location /admin {
allow 192.168.1.33;
deny all;
index index.html index.htm;
proxy_set_header Host $host;
proxy_set_header X-real-ip $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_connect_timeout 30s;
}
2、ip地址分内外网
如果存在内网往网ip不一样的情况,直接禁止是无效的,因为外网地址进入nginx地址会变化,可以通过 $http_x_forwarded_for 第一访问地址做限制
修改nginx.cong,定义一下access.log的日志格式
添加参数 $allow_admin,目的是为了做判断
在admin用户下添加要限制的ip192.168.1.33(只允许admin在192.168.1.33的ip地址下访问)
开始设置$allow_admin为0,如果$http_x_forwarded_for =192.168.1.33,$allow_admin为1,如果$allow_admin不为1,则不允许访问
location /admin {
set $allow_admin 0;
if ($http_x_forwarded_for = 192.168.1.33)
{
set $allow_admin 1;
}
if ($allow_admin != 1)
{
return 400;
}
#allow 192.168.1.33;
#deny all;
index index.html index.htm;
proxy_set_header Host $host;
proxy_set_header X-real-ip $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_connect_timeout 30s;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)