一文彻底读懂nginx中的location指令

news/2024/11/24 9:31:30/

Nginx主配置文件结构

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZGY8x5nd-1682987968763)(/upload/2023/03/image-1679222228652.png)]

location 介绍

location是Nginx中的块级指令(block directive),,location指令的功能是用来匹配不同的url请求,进而对请求做不同的处理和响应,这其中较难理解的是多个location的匹配顺序,本文会作为重点来解释和说明。

开始之前先明确一些约定,我们输入的网址叫做请求URI,nginx用请求URI与location中配置的URI做匹配。

localtion 语法

location有两种匹配规则:

  • 匹配URL类型,有四种参数可选,当然也可以不带参数。
    location [ =| ^~ | ~ | ~* | uri | / ]
  • 命名location,用@标识,类似于定于goto语句块。
    location @name { … }

location匹配参数解释

= ,精确匹配

内容要同表达式完全一致才匹配成功

location = /abc/ {.....}
只匹配http://abc.com/abc
http://abc.com/abc [匹配成功]
http://abc.com/abc/index [匹配失败]

^~,表示普通字符串匹配上以后不再进行正则匹配。

location ^~ /index/ {.....
}
#以 /index/ 开头的请求,都会匹配上
#http://abc.com/index/index.page  [匹配成功]
#http://abc.com/error/error.page [匹配失败]

~,执行正则匹配,区分大小写。

location ~ /Abc/ {.....
}
#http://abc.com/Abc/ [匹配成功]
#http://abc.com/abc/ [匹配失败]

~*,执行正则匹配,忽略大小写

location ~* /Abc/ {.....
}则会忽略 uri 部分的大小写
http://abc.com/Abc/ [匹配成功]
http://abc.com/abc/ [匹配成功]

不加任何规则时,默认是大小写敏感,前缀匹配,相当于加了~^~

location /index/ {......
}
#http://abc.com/index  [匹配成功]
#http://abc.com/index/index.page  [匹配成功]
#http://abc.com/test/index  [匹配失败]
#http://abc.com/Index  [匹配失败]
匹配到所有uri

@,nginx内部跳转

location /index/ {error_page 404 @index_error;
}
location @index_error {.....
}
#以 /index/ 开头的请求,如果链接的状态为 404。则会匹配到 @index_error 这条规则上。

location匹配顺序

= > ^~ > ~ | ~* > 最长前缀匹配 > /

序号越小优先级越高
location = # 精准匹配
= 匹配优先级最高。一旦匹配成功,则不再查找其他匹配项。
location ^~ # 带参前缀匹配
^~类型表达式。一旦匹配成功,则不再查找其他匹配项。
location ~ # 正则匹配(区分大小写)
location ~* # 正则匹配(不区分大小写)
location /a # 普通前缀匹配,优先级低于带参数前缀匹配。
location / # 任何没有匹配成功的,都会匹配这里处理

举例

location = /  {
#规则A
}location = /login {
#规则B
}location ^~ /static/ {
#规则C
}location ~ \.(gif|jpg|png|js|css)$ {
#规则D
}location ~* \.png$ {
#规则E
}location !~ \.xhtml$ {
#规则F
}location !~* \.xhtml$ {
#规则G
}location / {
#规则H
}

匹配结果:

访问根目录/, 比如http://localhost/ 将匹配规则A访问 http://localhost/login 将匹配规则B,http://localhost/register 则匹配规则H访问 http://localhost/static/a.html 将匹配规则C访问 http://localhost/b.jpg 将匹配规则D和规则E,但是规则D顺序优先,规则E不起作用, 而 http://localhost/static/c.png 则优先匹配到 规则C访问 http://localhost/a.PNG 则匹配规则E, 而不会匹配规则D,因为规则E不区分大小写。访问 http://localhost/a.xhtml 不会匹配规则F和规则G,http://localhost/a.XHTML不会匹配规则G,因为不区分大小写。规则F,规则G属于排除法,符合匹配规则但是不会匹配到。访问 http://localhost/qll/id/1111 则最终匹配到规则H,因为以上规则都不匹配。

location URI结尾带不带 /

如果 URI 结构是 https://domain.com/ 的形式,尾部有没有 / 都不会造成重定向。因为浏览器在发起请求的时候,默认加上了 / 。虽然很多浏览器在地址栏里也不会显示 / 。这一点,可以访问百度验证一下。
如果 URI 的结构是 https://domain.com/some-dir/ 。尾部如果缺少 / 将导致重定向。因为根据约定,URL 尾部的 / 表示目录,没有 / 表示文件。所以访问 /some-dir/ 时,服务器会自动去该目录下找对应的默认文件。如果访问 /some-dir 的话,服务器会先去找 some-dir 文件,找不到的话会将 some-dir 当成目录,重定向到 /some-dir/ ,去该目录下找默认文件。
举个例子:


server {listen       9001;server_name  www.abc.com;location ~ /edu {proxy_pass http://127.0.0.1:8080;}}

我们访问www.abc.com:9001/edu,看下效果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0G3ymyM1-1682987968764)(/upload/2023/03/image-1679223312505.png)]

访问 /edu 时,服务器首先去找edu文件,找不到则将edu当做目录,重定向到 /edu/,在该目录下找默认文件。
但是如果想这两种请求对应不同的处理,就要明确增加不带/结尾的location配置。例如:

location  /doc {proxy_pass http://www.doc123.com
}
location  /doc/ {proxy_pass http://www.doc456.com
}

转载


http://www.ppmy.cn/news/59526.html

相关文章

Win11如何下载安装java?

一、问题描述 我在复现论文代码的时候,遇到了这样的问题: 我没有下载java,那么该如何解决呢? 下载 Java 的作用是为了能够在计算机上运行使用 Java 语言编写的应用程序。Java 是一种广泛使用的编程语言,可用于开发各…

从0开始利用Jenkins构建Maven项目(微服务)并自动发布

0. 前言 本文旨在帮助读者梳理如何从0开始利用Jenkins构建Maven项目(微服务)的自动发布任务 本文目录如下: 如何完成自动部署 0. 前言1. 配置工具类地址1.1 JDK1.2 Git1.3 Maven 2. 安装Jenkins3. 安装额外的工具插件4. 配置必要参数4.1 配…

错题笔记第一篇

目录 1. strlen的用法2. case3. switch4. 二分查找 1. strlen的用法 正确答案 :C strlen计算的是字符串的长度,二字符串是以\0结尾,而咱们并没有存储\0,后序的空间是未知的,strlen找不到\0就会一直找,所以它…

大四毕业生想要找实习程序员工作 ,我总结了三点分享给大家

最近有粉丝留言,说自己已经大四了,想找一份实习工作,但不知道如何找一份实习工作,或者说在找实习工作之前,自己需要准备些什么。今天我们来聊聊这个话题。在聊这个话题之前,我觉得有必要认清当前互联网的现…

python实战应用讲解-【numpy数组篇】常用函数(六)(附python示例代码)

目录 Python numpy.ix_()函数 Python numpy.ma.compress_cols()函数 Python numpy.ma.compress_rowcols()函数 Python numpy.ma.mask_rowcols()函数 Python numpy.ma.mask_rows()函数 Python Numpy MaskedArray.astype()函数 Python numpy.ix_()函数 numpy.ix_()函数从多…

redis使用总结

目录 redis安装与登录redis 持久化RDB(Redis DataBase)AOF(Append Only File)RDB-AOF混合持久纯缓存模式 redis 的 keyredis 的数据类型和常见应用场景StringListHashMapSet集合ZSet有序集合bitmap位图HyperLogLog基数统计GEO 地理空间Stream 流bitfiled redis 事务事务的正常执…

搞懂 API ,API 分类全知道

API,即应用程序编程接口,是为了方便应用程序之间的数据和功能交互而设计的一些标准方法。API 的分类可以从多个维度进行,我会对 API 的分类维度进行简单的介绍。 根据使用方式的不同 通常情况下,API 可以分为两种使用方式&#…

为什么是三次握手和四次挥手

文章目录 为什么是三次握手为什么是四次挥手什么是TIME_WAIT状态解决TIME_WAIT状态引起的bind失败的方法 为什么是三次握手 因为这是双方都有收发的最小次数 握手的目的:确认网络好着没,对方好着没 确认双方主机是否健康(双方)…