当前位置:首页 > 技术文章 > 正文内容

Centos7学习笔记(二十一)- nginx的rewrite

ivker_lee4年前 (2021-10-27)技术文章338

一、什么是rewrite

rewirte就是实现Url地址重写,以及重定向,就是把传入的web请求重定向到其他URL的过程。

二、rewrite的使用场景

a、url地址的跳转。比如访问www.example.com/test,重定向到test.example.com网址。

b、协议的跳转,主要的就是实现http协议跳转到https页面去。

c、实现网站的伪静态。伪静态就是将网站动态页面的诸多参数,显示为一种静态页面的方式,以便于搜索引擎记录,减少URL地址暴露过多参数,提高安全性。

d、通过上述伪静态,产生较好的URL地址,利于做SEO优化

三、rewrite指令语法

Syntax:    rewrite    regex    replacement    [flag];
Default:    ---
Context:    sever    location    if

flag标记总共有四种:

last——完成该rewrite规则的执行后,停止处理后续rewrite指令集;然后查找匹配改变后URI的新location;

break——完成该rewrite规则的执行后,停止处理后续rewrite指令集,并不再重新查找;但是当前location内剩余非rewrite语句和location外的的非rewrite语句可以执行;


redirect返回302临时重定向, 地址栏会显示跳转后的地址

permanent返回301永久重定向, 地址栏会显示跳转后的地址


last和break的区别:

server {
    listen    80;
    server_name    rewrite.example.com;
    root    /code;
    
    location    ~ ^/break {
            rewrite    ^/break    /test    break;
    }
    location    ~ ^/last {
            rewrite    ^/last    /test    last;
    }
    location    /test {
            default_type    text/plain;
            return    200    'ok';
    }
}

在这个示例配置文件中,当访问rewrite.example.com/break时,当/code/test目录不存在时,报404错误,目录存在时,报403错误。

而当访问rewrite.example.com/last时,页面会直接返回“OK”字样。

原因呢,在于:

break在匹配到规则后,会去本地目录中去寻找请求的文件。寻找不到,则就会报错。

last在匹配到规则后,则会对其所在的server{...}标签重新发起请求。

那么对于上面的配置文件的理解就是:当/code/test目录下,还存在着index.html文件时,不管index.html文件的内容是什么,因为最后的location都匹配到了/test目录,最终都return回来200的状态码,页面显示的内容都会是“ok”字样(不管是访问rewrite.example.com/break还是rewrite.example.com/last)。只有当不存在"location /test”段的配置时,才会返回index.html页面的内容。


对应redirect和permanent,它们的区别是:

redirect每次请求都会询问服务器,如果服务器不可用,则会跳转失败。

permanent则是第一次请求时会询问,浏览器会记录下跳转后的地址,第二次则不再询问服务器,直接通过浏览器缓存的地址访问。除非清理浏览器缓存。

redirect的缺点是会消耗一定的资源。permanent的 缺点是当被跳转的地址再次发生变化时,跳转的访问就不再可用了。


以下全局变量,在做if判断时可用引用。

$args               #这个变量等于请求行中的参数,同$query_string;
$content_length     #请求头中的Content-length字段;
$content_type       #请求头中的Content-Type字段;
$document_root      #当前请求在root指令中指定的值,如:root /var/www/html;
$host               #请求主机头字段,否则为服务器名称;
$http_user_agent    #客户端agent信息;
$http_cookie        #客户端cookie信息;
$limit_rate         #这个变量可以限制连接速率;
$request_method     #客户端请求的动作,通常为GET或POST;
$remote_addr        #客户端的IP地址;
$remote_port        #客户端的端口;
$remote_user        #已经经过Auth Basic Module验证的用户名;
$request_filename   #当前请求的文件路径,由root或alias指令与URI请求生成;
$scheme             #HTTP方法(如http,https);
$server_protocol    #请求使用的协议,通常是HTTP/1.0或HTTP/1.1;
$server_addr        #服务器地址,在完成一次系统调用后可以确定这个值;
$server_name        #服务器名称;
$server_port        #请求到达服务器的端口号;
$request_uri        #包含请求参数的原始URI,不包含主机名,如:”/foo/bar.php?arg=baz”;
$uri                #不带请求参数的当前URI,$uri不包含主机名,如”/foo/bar.html”;
$document_uri       #与$uri相同,例:http://localhost:88/test1/test2/test.php;


关于rewrite指令,https://www.cnblogs.com/guantou1992/p/12777138.html 这篇文章讲的比较详细全面。

分享给朋友:

相关文章

Centos7学习笔记(二十二)- HTTPS

Centos7学习笔记(二十二)- HTTPS

一、http劫持原理首先通过dns污染,将访问的目标服务器,解析到问题服务器。问题服务器上,做nginx代理,利用sub_filter模块,可以匹配并替换原目标服务器上的部分(或全部)内容,以达到广告发布、挂马等目的。最好的防范措施是hosts直接解析,防止污染。二、https原理http原理具体来说,是很复杂的。这里仅简单描述一下它的大致流程——网站服务器先通过向“登记机构”发起“证书签名申请”(CSR),CA机构在获取CSR后,确认无误,将证书颁发给网站服务器,其证书还包括公钥和私钥内容。网...

Centos7学习笔记(一)

Centos7学习笔记(一)

1、安装部分新知a、LVM——逻辑卷管理,作用:动态管理磁盘分区空间,缺点:影响高并发下的磁盘性能b、CentOS 7安装之前,修改网卡名称:在安装界面,按“tab”键,调整内核参数,添加“net.ifnames=0 biosdevname=0”这2个参数值(如果是安装好系统后修改,则需几步:1、重命名/etc/sysconfig/network-script/ifcfg-ens33为ifcfg-eth0,并修改内容将DEVICE和NAME值修改为eth0;2、修改/etc/default/gr...

Centos7学习笔记(六)——shell编程初步

Centos7学习笔记(六)——shell编程初步

1、shell编程的一些基础a)shell编程有两类变量,                             全局变量(环境变量)——  一般指系统内置的变量,或者手动用export、declare等方式宣称,写入/etc/profile(~./bash_profile、~/bashrc、/etc/bashrc)的全局变量 ...

CentOS8系统优化脚本

CentOS8系统优化脚本

网上看到的一个CentOS8的系统优化脚本,写的挺好的。抄录一下。https://www.cnblogs.com/zxl1024320609/p/16715018.html color () {         RES_COL=60         MOVE_TO_COL="echo -en&n...

Centos7学习笔记(四)——grep、sed、awk

Centos7学习笔记(四)——grep、sed、awk

1、grep——print lines matching a pattern打印匹配内容的行(多行)命令格式:grep [参数] 过滤匹配内容 [文件名]或者grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]常用参数:-v 取反过滤 ◆◆-i 忽略大小写  ◆◆(find 命令可以用-iname)-n 对过滤后的内容,显示源文件行号  ◆◆-w 按单词为单位过滤。◆◆-o只输出匹配的内容。◆◆-E使用扩展规则-r...

Nginx常用编译模块

Nginx常用编译模块

    因为某些特殊需求,最近在折腾网站支持TLS1.3。因此做一些笔记。    首先,要支持TLS1.3,需要openssl在1.1.0以上版本。需要系统重新编译安装。其次,需要nginx调用新版本openssl,用“nginx -V”命令可以查看调用的openssl版本详情。然后下载对应版本的nginx源码,重新编译nginx。    以下罗列nginx编译常用编译模块:&...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。