关闭

配置Nginx防止直接用IP访问Web服务器

105人阅读 评论(0) 收藏 举报
分类:

PS:转自 http://down.chinaz.com/server/201112/1469_1.htm

看了很多Nginx的配置,好像都忽略了ip直接访问Web的问题,这样理论上不利于SEO优化,所以我们希望可以避免直接用IP访问网站,而是域名访问,具体怎么做呢,看下面。

  官方文档中提供的方法:

If you do not want to process requests with undefined "Host" header lines, you may define a default server that just drops the requests:

server {
listen 80 default_server;
server_name _;
return 444;
}

  说白了就是只要是访客用ip访问就直接重置444错误。但是这样好像又不太友好,如果能直接给跳转到该web server的网址就好了。配置如下:

server {
listen 80 default_server;
server_name _;
rewrite ^ http://www.domain.com$request_uri?;
}

ps:网址必须要写全  

这样还是有一点问题,某些特别的地址,我需要用ip访问,其他的都禁止,如何配置呢?比如说我想让监控宝直接用ip访问我的机器的nginx状态信息,其他的用ip访问的所有请求都跳转到域名上。

server {
listen 80 default_server;
server_name _;
location /xxxxx{
stub_status on;
access_log off;
}
location /{
rewrite ^ http://www.domain.com$request_uri?;
}
}

 这样就实现了我们想要的功能了。


  禁止IP访问是在全区配置文件nginx.conf设置,另外在vhost目录中添加虚拟主机www.domain.com.conf,这样就可以通过域名访问,而ip访问的时候也会直接跳转到域名了,配置如下:

全局配置:

server {
listen 80 default_server;
server_name _;
#return 444;
rewrite ^ http://www.domain.com$request_uri?;
}
虚拟主机配置

server {
server_name www.domain.com;
index index.html index.htm index.php;
root  /wwwroot/domain;
}

1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    最新评论
    个人资料
    • 访问:132870次
    • 积分:2650
    • 等级:
    • 排名:第14329名
    • 原创:130篇
    • 转载:43篇
    • 译文:0篇
    • 评论:3条