zoukankan      html  css  js  c++  java
  • nginx的301与302跳转详细配置教程


    511遇见

    什么是301跳转

    301跳转也叫301重定向,也叫301转向,也叫301永久重定向,是网站建设过程中的一个功能。一般用于2个域名指向同一个网站。 一般来说,利用跳转,对网站的排名不会有影响。但不会转移全部权重。只能说让损失降到最低。

    302跳转就网址重定向的一种,它区别于301跳转,301是网址永久重定向,302则是网址的临时定向。302转向或者302重定向(302 redirect)指的是当浏览器要求一个网页的时候,主机所返回的状态码。302状态码的意义是暂时转向到另外一个网址。

    所以当我们在做页面跳转的时分必定要正视,利用的不能够是302重定向,而是301重定向。

    首先看一个完整代码示例,关于nginx 301 302跳转的。

    301跳转设置:

    server {
    listen 80;
    server_name abc.com;
    rewrite ^/(.*) http://edf.com/$1 permanent;
    access_log off;
    }

    302跳转设置:

    server {
    listen 80;
    server_name abc.com;
    rewrite ^/(.*) http://edf.com/$1 redirect;
    access_log off;
    }

    nginx 301 302跳转的详细说明文档

    server {
    server_name test.com;
    rewrite ^/(.*) http://www.test1.com/$1 permanent;
    }

    last – 基本上都用这个Flag。
    break – 中止Rewirte,不在继续匹配
    redirect – 返回临时重定向的HTTP状态302
    permanent – 返回永久重定向的HTTP状态301

    Nginx的重定向用到了Nginx的HttpRewriteModule,下面简单解释以下如何使用的方法:
    rewrite命令

    nginx的rewrite相当于apache的rewriterule(大多数情况下可以把原有apache的rewrite规则加上引号就可以直接使用),它可以用在server,location 和IF条件判断块中,命令格式如下:

    rewrite 正则表达式 替换目标 flag标记
    flag标记可以用以下几种格式:
    last – 基本上都用这个Flag。
    break – 中止Rewirte,不在继续匹配
    redirect – 返回临时重定向的HTTP状态302
    permanent – 返回永久重定向的HTTP状态301

    特别注意:

    lastbreak用来实现URL重写,浏览器地址栏的URL地址不变,但是在服务器端访问的路径发生了变化;

    redirectpermanent用来实现URL跳转,浏览器地址栏会显示跳转后的URL地址;

    例如下面这段设定nginx将某个目录下面的文件重定向到另一个目录,$2对应第二个括号(.*)中对应的字符串:

    location /download/ {
    rewrite ^(/download/.*)/m/(.*)..*$ $1/nginx-rewrite/$2.gz break;
    }

    nginx重定向的IF条件判断

    serverlocation两种情况下可以使用nginxIF条件判断,条件可以为以下几种:
    正则表达式

    如:
    匹配判断
    ~ 为区分大小写匹配; !~为区分大小写不匹配
    ~* 为不区分大小写匹配;!~为不区分大小写不匹配
    例如下面设定nginx在用户使用ie的使用重定向到/nginx-ie目录下:

    if ($http_user_agent ~ MSIE) {
    rewrite ^(.*)$ /nginx-ie/$1 break;
    }

    文件和目录判断

    -f和!-f判断是否存在文件
    -d和!-d判断是否存在目录
    -e和!-e判断是否存在文件或目录
    -x和!-x判断文件是否可执行

    例如下面设定nginx在文件和目录不存在的时候重定向:

    if (!-e $request_filename) {
    proxy_pass http://127.0.0.1;
    }
    return

    返回http代码,例如设置nginx防盗链:
    location ~* .(gif|jpg|png|swf|flv)$ {
    valid_referers none blocked www.test.com www.test1.com;
    if ($invalid_referer) {
    return 404;
    }
    }

     
     
     

    发布日期: 2016-10-01

    所属分类: Apache/Ngnix 标签:   

  • 相关阅读:
    cmd 进入不同的驱动盘及上下级目录
    子网/ip/子网掩码
    虚拟化技术与"云"
    OSI 7层模型
    第一天的CI笔记
    在本地Apache服务器配置虚拟主机站点
    phpmailer 发送邮件
    mysql 中执行的 sql 注意字段之间的反向引号和单引号
    手动部署LNMT(Nginx+Tomcat)并实现Nginx反向代理Tomcat
    JS 创建元素的三种方法
  • 原文地址:https://www.cnblogs.com/xiager/p/6855431.html
Copyright © 2011-2022 走看看