• web服务器-Nginx URL重写


    web服务器-Nginx URL重写

    一. URL重写介绍

    • 和apache等web服务软件一样,rewrite的主要功能是实现URL地址的重定向。Nginx的rewrite功能需要PCRE软件的支持,即通过perl兼容正则表达式语句进行规则匹配的。默认参数编译nginx就会支持rewrite的模块,但是也必须要PCRE的支持。
    • Rewrite功功能是Nginx服务器提供的一个重要功能。几乎是所有的web产品必备技能,用于实现URL重写。URL重写是非常有用的功能,比如它可以在我们在改变网站结构后,不需要客户端修改原来的书签,也不需要其他网站修改对我们网站的友情链接,还可以在一定程度上提高网站的安全性,能够让我们的网站显得更专业。

    二,应用场景

    • 域名变更(京东)
    • 用户跳转(从某个连接跳转到另外一个连接)
    • 伪静态场景(便于CDN缓存动态页面数据)

    三. URL重写原理

    img

    URL重写

    • URL模块语法

      • set设置变量
      • if负责语句中的判断
      • return 返回返回值或者URL
      • break 终止后续的rewire规则
      • rewrite重定向URL
    • set指令 自定义变量

      Syntax:

      set $variable value;

      Default:

      Context:

      server, location, if

      将http://www.ayitula.com  重写为 http://www.ayitula.com/baism
      location / {
                      set $name baism;
                      rewrite ^(.*)$ http://www.ayitula.com/$name;
              }
      
    • if指令 负责判断

      Syntax:

      if (condition) { ... }

      Default:

      Context:

      server, location

      条件匹配

      模糊匹配 #
      匹配 ~
      不匹配 !~
      不区分大小写的匹配  ~*
      精准匹配 = 
      
      
      location / {
                      root html;
                      index index.html index.htm;
                      if ($http_user_agent ~* 'Chrome') {
                              break;
                              return 403;
                              #return http://www.jd.com;
                      }
              }
      
    • return指令 定义返回数据

      Syntax: return code [text];

      return code URL;

      return URL;

      Default: —

      Context: server, location, if

      location / {
                      root html;
                      index index.html index.htm;
                      if ($http_user_agent ~* 'Chrome') {
                              return 403;
                              #return http://www.jd.com;
                      }
              }
             
      
    • break 指令 停止执行当前虚拟主机的后续rewrite指令集

      Syntax: break;

      Default:—

      Context:server, location, if

      location / {
                      root html;
                      index index.html index.htm;
                      if ($http_user_agent ~* 'Chrome') {
                              break;
                              return 403;
           }
              }
              
      
    • rewrite指令 实现重写url
      rewrite <regex> <replacement> [flag];
      
      rewrite 关键字
      regex 正则
      replacement 替换内容
      flag 标记
      
      • flag
        1. last #本条规则匹配完成后,继续向下匹配新的location URI规则
        2. break #本条规则匹配完成即终止,不再匹配后面的任何规则
        3. redirect #返回302临时重定向,浏览器地址会显示跳转后的URL地址
        4. permanent #返回301永久重定向,浏览器地址栏会显示跳转后的URL地址
    • 重定向就是将网页自动转向重定向,permanent和redirect从定向的区别

      • 301永久性重定向:新网址完全继承旧网址,旧网址的排名等完全清零
      • 301重定向是网页更改地址后对搜索引擎友好的最好方法,只要不是暂时搬移的情况,都建议使用301来做转址。
      • 302临时性重定向:对旧网址没有影响,但新网址不会有排名
      • 搜索引擎会抓取新的内容而保留旧的网址
    • permanent标志:永久重定向

      域名跳转
      www.ayitula.com     重写为  www.jd.com
      server {
              listen        80;
              server_name www.ayitula.com;
              location / {
                  rewrite ^/$ http://www.jd.com permanent;
      
                }
      }
      
    • redirect标志:临时重定向

      域名跳转
      www.ayitula.com     重写为  www.jd.com
      server {
              listen        80;
              server_name www.ayitula.com;
              location / {
                  rewrite ^/$ http://www.jd.com redirect;
      
                }
      }
      
      
    • break标志: 类似临时重定向

      域名跳转
      www.ayitula.com     重写为  www.jd.com
      server {
              listen        80;
              server_name www.ayitula.com;
              location / {
                  rewrite ^/$ http://www.jd.com break;
      
                }
      }
      
      
    • last标志:

      • url重写后,马上发起一个新的请求,再次进入server块,重试location匹配,超过10次匹配不到报500错误,地址栏url不变
      • last 一般出现在server或if中
      • 根据用户浏览器重写访问目录
      如果是chrome浏览器  就将  
      http://192.168.10.42/$URI
         重写为  
      http://http://192.168.10.42/chrome/$URI
      
      实现 步骤
      1)URL重写
      2)请求转给本机location
      
      
      
      location / {
      .....
      if ($http_user_agent ~* 'chrome'){
                #^ 以什么开头 ^a
                #$ 以什么结尾 c$
                #. 除了回车以外的任意一个字符
                #* 前面的字符可以出现多次或者不出现
                #更多内容看正则表达式 re
                rewrite ^(.*)$ /chrome/$1 last;
                }
      
      
             location /chrome {
                root html ;
                index index.html;
              }
      }
      
      
  • 相关阅读:
    自定义标签的作用
    自定义标签处理器类的生命周期
    自定义标签的执行过程
    自定义标签入门案例
    JSTL核心标签库详解
    JSTL标签(核心标准库)
    动作标签
    jsp标签
    EL表达式
    JSP学习案例--,竞猜游戏
  • 原文地址:https://www.cnblogs.com/yuncong/p/12430417.html
Copyright © 2020-2023  润新知