深入探索 Nginx 的 URL 重写与位置匹配

2024-08-24 08:04

本文主要是介绍深入探索 Nginx 的 URL 重写与位置匹配,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 深入探索 Nginx 的 URL 重写与位置匹配
  • 官方文档
  • 一、Nginx 正则表达式基础
  • 二、rewrite 和 location 的区别
  • 三、rewrite 指令详解
  • 四、rewrite 跳转实现
  • 五、rewrite 语法格式及 flag 说明
      • flag 标记说明
  • 六、location 指令详解
      • location 常用的匹配规则
      • location 优先级
  • 七、location 示例说明
      • 7.1 示例 1:精准匹配
      • 7.2 示例 2:一般匹配
      • 7.3 示例 3:正则匹配
  • 八、location 匹配优先级总结
  • 九、rewrite 实际应用示例
      • 9.1 基于域名的跳转
      • 9.2 基于客户端 IP 访问跳转
      • 9.3 基于旧域名跳转到新域名加目录
      • 9.4 基于参数匹配的跳转
      • 9.5 基于目录下所有 php 结尾的文件跳转
      • 9.6 基于最普通一条 URL 请求的跳转

深入探索 Nginx 的 URL 重写与位置匹配

官方文档

  • ngx_http_rewrite_module
  • ngx_http_rewrite_module if 条件

一、Nginx 正则表达式基础

Nginx 正则表达式是用于匹配和重写 URL 的强大工具。下面是常用的 Nginx 正则表达式符号及其含义:

  • ^ :匹配输入字符串的起始位置。
  • $ :匹配输入字符串的结束位置。
  • * :匹配前面的字符零次或多次。如“ol*”能匹配“o”及“ol”、“oll”。
  • + :匹配前面的字符一次或多次。如“ol+”能匹配“ol”及“oll”、“olll”,但不能匹配“o”。
  • ? :匹配前面的字符零次或一次,例如“od(es)?”能匹配“do”或者“does”,”?”等效于”{0,1}”。
  • . :匹配除“\n”之外的任何单个字符,若要匹配包括“\n”在内的任意字符,请使用诸如“[.\n]”之类的模式。
  • \ :将后面接着的字符标记为一个特殊字符或一个原义字符或一个向后引用。如“\n”匹配一个换行符,而“$”则匹配“$”。
  • \d :匹配纯数字。
  • {n} :重复 n 次。
  • {n,} :重复 n 次或更多次。
  • {n,m} :重复 n 到 m 次。
  • [] :定义匹配的字符范围。
  • [c] :匹配单个字符 c。
  • [a-z] :匹配 a-z 小写字母的任意一个。
  • [a-zA-Z0-9] :匹配所有大小写字母或数字。
  • () :表达式的开始和结束位置。
  • | :或运算符。

二、rewrite 和 location 的区别

从功能上看,rewritelocation 似乎都有实现跳转的能力。主要区别在于 rewrite 是在同一域名内更改获取资源的路径,而 location 是对一类路径进行访问控制或反向代理,还可以通过 proxy_pass 将请求代理到其他机器。

三、rewrite 指令详解

rewrite 功能就是使用 Nginx 提供的全局变量或自定义变量,结合正则表达式和标记位实现 URL 重写及重定向。常见的应用场景包括域名变更后的跳转、网页地址更改后的跳转以及网站防盗链等。

rewrite 指令只能放在 server{}, location{}, if{} 块中,并且默认只能对域名后面的路径进行重写,不包括传递的参数。例如,http://www.kgc.com/abc/bbs/index.php?a=1&b=2 只会对 /abc/bbs/index.php 进行重写。

四、rewrite 跳转实现

Nginx 通过 ngx_http_rewrite_module 模块支持 URL 重写和 if 条件判断,但不支持 else。跳转时,从一个 location 跳转到另一个 location 的次数最多为 10 次,超过后 Nginx 将返回 500 错误。该模块还支持 Perl 兼容正则表达式的语法规则匹配,以及通过 set 指令创建新变量并赋值。

rewrite 执行顺序如下:

  1. 执行 server 块里面的 rewrite 指令。
  2. 执行 location 匹配。
  3. 执行选定的 location 中的 rewrite 指令。

五、rewrite 语法格式及 flag 说明

语法格式:

rewrite <regex> <replacement> [flag];
  • regex :表示正则匹配规则。
  • replacement :表示跳转后的内容。
  • flag :表示 rewrite 支持的标记。

flag 标记说明

  • last :本条规则匹配完成后,继续向下匹配新的 location URL 规则,一般用在 serverif 中。
  • break :本条规则匹配完成即终止,不再匹配后面的任何规则,一般使用在 location 中。
  • redirect :返回 302 临时重定向,浏览器地址会显示跳转后的 URL 地址。
  • permanent :返回 301 永久重定向,浏览器地址栏会显示跳转后的 URL 地址。

六、location 指令详解

location 大致可以分为三类:

  • 精准匹配:location = / {...}
  • 一般匹配:location / {...}
  • 正则匹配:location ~ / {...}

location 常用的匹配规则

  • = :进行普通字符精确匹配,完全匹配时触发。
  • ^~ :表示普通字符匹配,使用前缀匹配。如果匹配成功,则不再匹配其它 location
  • ~ :区分大小写的正则匹配。
  • ~* :不区分大小写的正则匹配。
  • !~ :区分大小写的匹配取非。
  • !~* :不区分大小写的匹配取非。

location 优先级

  1. 首先精确匹配 =
  2. 其次前缀匹配 ^~
  3. 按文件中顺序的正则匹配 ~~*
  4. 匹配不带任何修饰的前缀匹配
  5. 最后交给 / 通用匹配

七、location 示例说明

7.1 示例 1:精准匹配

location = / 精确匹配根路径,通常用于处理网站的首页访问。此规则优先级最高,只要请求的路径完全匹配 /,就会触发此规则。

7.2 示例 2:一般匹配

location / {} 匹配所有以 / 开头的请求,这是一个最为通用的匹配规则,但优先级较低。

7.3 示例 3:正则匹配

location ~* \.(gif|jpg|jpeg)$ {} 匹配所有以 .gif.jpg.jpeg 结尾的请求。此规则适用于需要区分文件类型的情况。

八、location 匹配优先级总结

  • 精确匹配优先级最高
  • 其次是 ^~ 前缀匹配
  • 正则匹配(~~*)次之
  • 最后是通用的 / 匹配

九、rewrite 实际应用示例

9.1 基于域名的跳转

旧域名 www.kgc.com 需要跳转到新域名 www.benet.com,可以使用以下配置:

server {listen       80;server_name  www.kgc.com;if ($host = 'www.kgc.com'){rewrite ^/(.*)$ http://www.benet.com/$1 permanent;}root   html;index  index.html index.htm;
}

9.2 基于客户端 IP 访问跳转

所有 IP 访问显示维护页面,只有公司 IP 192.168.10.19 可以正常访问:

server {listen       80;server_name  www.kgc.com;set $rewrite true;if ($remote_addr = "192.168.10.19"){set $rewrite false;}if ($rewrite = true){rewrite (.+) /weihu.html;}location = /weihu.html {root /var/www/html;}location / {root   html;index  index.html index.htm;}
}

9.3 基于旧域名跳转到新域名加目录

旧域名 bbs.kgc.com/post/ 需要跳转到新域名 www.kgc.com/bbs/post/

server {listen       80;server_name  bbs.kgc.com;location /post {rewrite (.+) http://www.kgc.com/bbs$1 permanent;}location / {root   html;index  index.html index.htm;}
}

9.4 基于参数匹配的跳转

访问 `http://www.kgc.com/100-(100

|200)-100.html跳转到http://www.kgc.com`:

server {listen       80;server_name  www.kgc.com;if ($request_uri ~ ^/100-(100|200)-(\d+).html$) {rewrite (.+) http://www.kgc.com permanent;}location / {root   html;index  index.html index.htm;}
}

9.5 基于目录下所有 php 结尾的文件跳转

访问 http://www.kgc.com/upload/123.php 跳转到首页:

server {listen       80;server_name  www.kgc.com;location ~* /upload/.*\.php$ {rewrite (.+) http://www.kgc.com permanent;}location / {root   html;index  index.html index.htm;}
}

9.6 基于最普通一条 URL 请求的跳转

访问 http://www.kgc.com/abc/123.html 跳转到首页:

server {listen       80;server_name  www.kgc.com;location ~* ^/abc/123.html {rewrite (.+) http://www.kgc.com permanent;}location / {root   html;index  index.html index.htm;}
}

80;
server_name www.kgc.com;
location ~* ^/abc/123.html {
rewrite (.+) http://www.kgc.com permanent;
}
location / {
root html;
index index.html index.htm;
}
}


这篇关于深入探索 Nginx 的 URL 重写与位置匹配的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1101904

相关文章

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SpringBoot3匹配Mybatis3的错误与解决方案

《SpringBoot3匹配Mybatis3的错误与解决方案》文章指出SpringBoot3与MyBatis3兼容性问题,因未更新MyBatis-Plus依赖至SpringBoot3专用坐标,导致类冲... 目录SpringBoot3匹配MyBATis3的错误与解决mybatis在SpringBoot3如果

Nginx添加内置模块过程

《Nginx添加内置模块过程》文章指导如何检查并添加Nginx的with-http_gzip_static模块:确认该模块未默认安装后,需下载同版本源码重新编译,备份替换原有二进制文件,最后重启服务验... 目录1、查看Nginx已编辑的模块2、Nginx官网查看内置模块3、停止Nginx服务4、Nginx

Spring Security重写AuthenticationManager实现账号密码登录或者手机号码登录

《SpringSecurity重写AuthenticationManager实现账号密码登录或者手机号码登录》本文主要介绍了SpringSecurity重写AuthenticationManage... 目录一、创建自定义认证提供者CustomAuthenticationProvider二、创建认证业务Us

通过配置nginx访问服务器静态资源的过程

《通过配置nginx访问服务器静态资源的过程》文章介绍了图片存储路径设置、Nginx服务器配置及通过http://192.168.206.170:8007/a.png访问图片的方法,涵盖图片管理与服务... 目录1.图片存储路径2.nginx配置3.访问图片方式总结1.图片存储路径2.nginx配置