Nginx限制IP访问某些页面的操作
1、要禁止所有IP访问a1.htma2.htma3.htm这个三个页面在location可以这样写
location~*/(a1.htm|a2.htm|a3.htm)${
denyall;
condition………;
}
2、只允许指定的ip访问a1.htma2.htma3.htm这个三个页面,其他IP的访问都拒绝
location~*/(a1.htm|a2.htm|a3.htm)${
allow10.0.0.2;
denyall;
condition………;
}
这种设置只有ip地址为10.0.0.2的主机可以放问这三个页面,其他的ip都被拒绝了。
其他情况可以以此类推。
比如我需要指定只能8.8.8.8这个ip访问info.php页面。那么就可以在nginx-server中添加如下配置,即可
如果非8.8.8.8访问info.php页面,则返回403
后面需要加上跳转地址,proxy_passhttp://192.168.1.110:10480;否则会404错误。
location~/info.php${
if($remote_addr!='8.8.8.8'){
return403;
}
proxy_passhttp://192.168.1.110:10480;
}
}
也可以在server代码中添加
location~/info.php${
allow8.8.8.8;
denyall;
condition………;
}
一样的效果
如何配置禁用ip或ip段呢?
下面说明假定nginx的目录在/usr/local/nginx/
首先要建一个封ip的配置文件blockips.conf,然后viblockips.conf编辑此文件,在文件中输入要封的ip。
deny1.2.3.4; deny91.212.45.0/24; deny91.212.65.0/24;
然后保存此文件,并且打开nginx.conf文件,在http配置节内添加下面一行配置:
includeblockips.conf;
保存nginx.conf文件,然后测试现在的nginx配置文件是否是合法的:
/usr/local/nginx/sbin/nginx-t
如果配置没有问题,就会输出:
theconfigurationfile/usr/local/nginx/conf/nginx.confsyntaxisok
configurationfile/usr/local/nginx/conf/nginx.conftestissuccessful
如果配置有问题就需要检查下哪儿有语法问题,如果没有问题,需要执行下面命令,让nginx重新载入配置文件。
/usr/local/nginx/sbin/nginx-sreload
只允许某些的ip访问页面,或者禁止某些ip访问页面
server_namees.mila66.com;
location/{
include/etx/nginx/all/ip.conf;
denyall;
ip.conf里面的文件格式:
allow192.168.1.11;
allow192.168.1.12;
这样就实现了只允许某些ip访问页面。
如果禁止某些IP访问,只需要修改如下:把allow改成deny即可。
server_namees.mila66.com;
location/{
include/etx/nginx/all/ip.conf;
allowall;
ip.conf里面的文件格式:
deny192.168.1.11;
deny192.168.1.12;
nginx-sreload
重启服务器即可
以上这篇Nginx限制IP访问某些页面的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
