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

转载 2016年08月29日 13:43:57

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;
}

相关文章推荐

在nginx中配置如何防止直接用ip访问服务器web server及server_name特性讲解

看了很多nginx的配置,好像都忽略了ip直接访问web的问题,不利于SEO优化,所以我们希望可以避免直接用IP访问网站,而是域名访问,具体怎么做呢,看下面。 官方文档中提供的方法:  I...

禁止通过ip直接访问网站来防止恶意解析-(apache,nginx,iis)

一、IIS 禁止IP直接访问 首先就是打开IIS管理器之后,在IIS管理器左侧找到网站下面的相应网站,右键选择打开该网站属性,进入相关IIS网站属性设置。  (IIS打开网站属性方...

maven部署web项目到远程服务器的Tomcat,以及输入IP地址直接访问到这个web项目

远程服务器linux下上安装Tomcat,这里以Tomcat7为例 a. 解压Tomcat7(记得先把jdk配置好) [root@VM_30_175_centos /]# cd /usr/loc...
  • Luo_da
  • Luo_da
  • 2017年03月29日 21:04
  • 1839

怎样配置让apache访问日志记录真实客户端IP,而不是nginx代理服务器IP

默认apache记录的是nginx代理服务器的IP,并不是真实客户端的IP。怎样让其显示真正的客户端ip呢? 修改nginx配置文件,确保有这一行:proxy_set_header  X-Real-...

怎样配置让apache访问日志记录真实客户端IP,而不是nginx代理服务器IP

默认apache记录的是nginx代理服务器的IP,并不是真实客户端的IP。怎样让其显示真正的客户端ip呢? 修改nginx配置文件,确保有这一行:proxy_set_header  X-Real-...

web安全tomcat tomcat禁止ip直接访问

key: tomcat禁止ip直接访问 设置Tomcat不允许通过IP直接访问 更改host节点后虚拟目录设置失效  发现内部ip泄露模式   1、若公布于外网的服务器IP地址未备案,就有...

Tomcat 部署 Web 通过 ip 直接访问项目

正常情况下,在访问在Tomcat中部署的项目是 http://localhost:8080/demo 方式 其中,IP,端口,项目名(Demo)都是必须的。 那么,怎么样才能通过 http...

Nginx服务器fair负载访问安装配置

  • 2017年07月18日 17:07
  • 18KB
  • 下载

高性能Web服务器Nginx的配置与部署研究(7)核心模块之主模块的非测试常用指令

1. error_log 含义:指定存储错误日志的文件 语法:error_log [debug|info|notice|warn|error|crit] 缺省:${prefix}/logs/e...

web服务器之LNMP(1)Ubuntu中Nginx的安装与配置

那个项目比较烦了,先放下,学习下自己想学的东西,web服务器。 LNMP是一个很流行的web架构,使用nginx作为web服务器,因为nginx没有像Apache那样的php模块,这里使用的是php-...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:配置Nginx防止直接用IP访问Web服务器
举报原因:
原因补充:

(最多只允许输入30个字)