关闭nginx空主机头 防止nginx空主机头及恶意域名指向

Shams ·
更新时间:2024-09-21
· 547 次阅读

nginx的默认配置中的虚拟主机允许用户通过IP访问,或者通过未设置的域名访问(比如有人恶意把他自己的域名指向了你的ip)
这是因为默认配置中的server区域里有这一行:
listen 80 default;
后面的default参数表示这个是默认虚拟主机,接受所有指向过来的域名
比如别人通过ip或者未知域名访问你的网站的时候,你希望禁止显示任何有效内容,可以给他返回500.

server { listen 80 default; server_name _; return 500; }

你也可以把这些流量收集起来,导入到自己的网站,只要做以下跳转设置就可以:

server { listen 80 default; rewrite ^(.*) //www.jb51.net permanent; }

如果是多IP的服务器时,只屏蔽了一个IP:
可以试下这样:

server { listen *:80 default; server_name _; return 500; }

不行时再试下:

server { listen *:80; server_name _; return 500; }

使用空主机头后,PHPmyadmin 之后将无法访问,加个二级域名指向phpmyadmin目录就行了。



主机头 域名 Nginx

需要 登录 后方可回复, 如果你还没有账号请 注册新账号