nginx 配置文件location块中符号的含义

nginx -t  检查配置文件语法问题

nginx -s reload   重新加载conf文件

location 块

=  表示精确匹配

~    这个符号开头表示区分大小写

 一般和 ~ 公用,  ~*  表示不区分大小写

^   表示正则的开始

前缀匹配:默认的匹配方式,不带修饰符,匹配 URI 的前缀。

location /api {# 处理 /api 及其子路径的请求
}

精确匹配:使用 = 修饰符,仅当请求 URI 与指定字符串完全相等时匹配。​​​​​​​

location = / {# 仅处理根路径 / 的请求
}

正则表达式匹配:使用 ~ 或 ~* 修饰符,分别表示区分大小写和不区分大小写的正则表达式匹配。​​​​​​​

location ~* \.(jpg|png|gif)$ {
# 处理所有以 .jpg、.png 或 .gif 结尾的请求
}

目录匹配:以斜杠 / 结尾的匹配模式,用于匹配特定的目录。​​​​​​​

location /images/ {# 处理 /images/ 目录下的请求
}
location ^~ /favicon.ico {alias /data/webapps/nginx/www/favicon.ico;}location ^~ /css/ {alias /data/nginx/www/css/;}location ^~ /css2/ {alias /data/nginx/www/css2/;}location ^~ /icons/ {alias /data/nginx/www/icons/;}location ^~ /images/ {alias /data/nginx/www/images/;}location ^~ /js/ {alias /data/nginx/www/js/;}
    # 使用正则表达式匹配/a和/b路径  location ~ ^/(a|b)$ {  return 404;  }   # 处理静态文件  location /static/ {  alias /path/to/static/files/;  try_files $uri $uri/ =404;  }  
server {  listen       80;  server_name  example.com;  # 精确匹配/a和/b路径,并返回404  location = /a {  return 404 "Not Found: /a is not allowed.";  }  location = /b {  return 404 "Not Found: /b is also not allowed.";  }  # 处理API请求,可能通过proxy_pass转发到其他服务器  location /api/ {  proxy_pass http://backend_server/api/;  proxy_set_header Host $host;  proxy_set_header X-Real-IP $remote_addr;  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  proxy_set_header X-Forwarded-Proto $scheme;  }  # 匹配所有其他路径,尝试服务静态文件(如果配置了的话),否则返回404  location / {  root   /usr/share/nginx/html;  try_files $uri $uri/ /index.html; # 尝试服务文件,如果找不到则重定向到index.html(常用于单页应用)  # 如果上面的try_files没有匹配到任何文件,并且没有重定向到index.html,则可以考虑在这里返回404  # 但由于try_files的最后一个参数是/index.html,通常不会执行到这里  # 如果不希望重定向到index.html,可以去掉/index.html,并在下面添加return 404;  }  # 错误页面处理(可选)  error_page 404 /404.html;  location = /404.html {  root /usr/share/nginx/html;  internal;  }  }

location 块的优先级

当有多个 location 块匹配同一个请求时,Nginx 会根据以下规则来确定使用哪个 location 块:

1.首先检查是否有精确匹配 (=)。

2.如果没有,检查是否有带有正则表达式的匹配 (~ 或 ~*),并使用第一个匹配的规则。

3.如果没有正则表达式匹配,则使用最长的前缀匹配。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/39754.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自动装配在Spring框架中的原理与实现方式

自动装配在Spring框架中的原理与实现方式 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿! 自动装配的概念与背景 在Spring框架中,自动装配&#x…

告别PS修图,设计师都在用的AI抠图工具

引言 大家好!如果你是美工或设计师,肯定深知Photoshop修图的繁琐和耗时。现在有一款超方便的工具,让你摆脱这些问题——千鹿设计助手。它不仅是个抠图工具,还能通过先进的AI技术,让抠图变得简单快速,让你专…

[Leetcode 128][Medium] 最长连续序列

目录 题目描述 整体思路 具体代码 题目描述 原题链接 整体思路 首先看到找连续升序排序的最长序列长度,想到对数组进行排序预处理。但是排序算法时间复杂度需要O(nlogn),题目要求时间复杂度为O(n)。因此不能进行排序与处理 接着想到数据结构哈希表&a…

Laravel 文件操作全指南:上传与下载实践

Laravel 提供了一系列强大的工具来简化文件上传和下载的过程,使得在 Web 应用程序中处理文件变得更加容易和安全。本文将详细介绍如何在 Laravel 中实现文件的上传和下载,包括表单创建、路由设置、控制器逻辑以及安全性考虑。 文件上传基础 文件上传是…

为什么网上商店需要翻译成其他语言

网上商店不仅仅是一个可以买到商品的网站。它是一个完整的电子商务平台,为来自世界各地的用户提供购买所需物品的机会。但是,为了让这些用户舒适地使用网站,需要高质量的翻译和本地化。 本地化是指产品或服务适应特定文化或市场的过程。它包…

问题 P: 表达式树的值

问题 P: 表达式树的值 题目描述 读入表达式树的先序遍历字符串,求其值。运算符只可能是加减乘除,保证输入的每个子表达式树的结果都是整数值且可以用C语言的int类型表达。 输入 输入由多组测试数据组成。 每组数据包含一行字符串,即表达式…

Nginx详解-安装配置等

目录 一、引言 1.1 代理问题 1.2 负载均衡问题 1.3 资源优化 1.4 Nginx处理 二、Nginx概述 三、Nginx的安装 3.1 安装Nginx 3.2 Nginx的配置文件 四、Nginx的反向代理【重点】 4.1 正向代理和反向代理介绍 4.2 基于Nginx实现反向代理 4.3 关于Nginx的location路径…

CSS 文本输入框右下角的尺寸控件(三斜线:-webkit-resizer)消除,以及如何配置其样式,添加 resize 让标签元素可进行拖拽放大。

前言:在日常的前端开发中,不管是原始的和 还在在各类组件库中的文本输入框中,元素内容的右下角总是有一个三斜线的样式,本文简单了解它是什么?如何去控制并修改样式? 一、它是? 这三个斜线其实…

echarts实现3D柱状图(视觉层面)

一、第一种效果 效果图 使用步骤 完整实例&#xff0c;copy就可直接使用 <template><div :class"className" :style"{height:height,width:width}" /> </template><script>import echarts from echartsrequire(echarts/theme/…

leetcode基础算法刷题汇总

前言 总结算法刷题的一些模板和刷题规律。 目录 单调栈并查集滑动窗口前缀和 & HASH差分拓扑排序字符串二分查找BFSDFS动态规划贪心算法字典树

Python面向对象编程:派生

本套课在线学习视频&#xff08;网盘地址&#xff0c;保存到网盘即可免费观看&#xff09;&#xff1a; ​​https://pan.quark.cn/s/69d1cc25d4ba​​ 面向对象编程&#xff08;OOP&#xff09;是一种编程范式&#xff0c;它通过将数据和操作数据的方法封装在一起&#xff0…

Qt通过句柄获取其它进程控件实例

1.通过spy获取想要获取控件的句柄id 通过spy获取另一个软件的文本框的句柄 2.Qt写代码&#xff0c; 根据句柄获取文本框的内容 void getTextFromExternalWindow(HWND hwnd) {const int bufferSize 256;TCHAR buffer[bufferSize];// 获取窗口文本内容int length GetWindowT…

一文读懂企业为什么需要数字工厂管理系统

在当今这个日新月异的数字化时代&#xff0c;企业面临着前所未有的挑战与机遇。为了在激烈的市场竞争中保持领先地位&#xff0c;实现高效、灵活、可持续的生产运营&#xff0c;企业纷纷转向数字化转型&#xff0c;而数字工厂管理系统作为其中的关键一环&#xff0c;正逐步成为…

京东e卡怎么用?

京东618过去后&#xff0c;就没有多大购物欲望了&#xff0c;最后导致我手里还有好几张200块钱面值的e卡没地方用 本来说送朋友&#xff0c;但是又感觉面值太小了 最后还是在收卡云上把提取出来了&#xff0c;主要回收价格不错&#xff0c;而且到账也快&#xff0c;很方便

VMware配置Ubuntu

VMware下载官方链接&#xff1a;Download VMware Workstation Player | VMware Ubuntu20.04下载&#xff1a;https://ubuntu.com/download/desktop 安装步骤 点击【浏览】可更改安装位置&#xff08;建议不要安装在C盘&#xff0c;可以在D盘或其它磁盘下新建一个“ubuntu”文…

linux深度deepin基于rsync和apt-mirror同步软件源及构建本地内网源

目录 一、rsync方式二、apt-mirror方式1.安装apt-mirror2.配置apt-mirror(/etc/apt/mirror.list)3.新建存放目录开始下载 3.发布mirror站点 一、rsync方式 参考官方文档地址&#xff1a; https://www.deepin.org/index/docs/wiki/05_HOW-TO/08_%E9%95%9C%E5%83%8F%E5%8A%A0%E9%…

国产高边开关驱动芯片替换ST VN7010

RAMSUN提供代理的类比HD7008Q车规级单通道智能高边驱动主要应用于汽车12V接地负载应用中&#xff0c;例如座椅加热&#xff0c;并可以提供进一步的智能保护功能&#xff0c;包括负载过流限制保护、动态过温保护以及过热关断保护等。输入控制引脚兼容3V和5V CMOS接口&#xff0c…

【CSS】深入浅出CSS过渡

CSS过渡&#xff08;Transitions&#xff09;是一种使元素在更改其样式时能够平滑过渡的CSS特性。它允许元素从一种样式逐渐改变为另一种样式&#xff0c;为网页添加动态效果和交互性。下面我们将深入浅出地介绍CSS过渡。 1. 基本概念 过渡属性&#xff1a;你想要过渡的CSS属…

创建数据库表的语法定义包含了SQL Server、Mysql、PostgreSQL、SQLite的示例

目录 &#x1f383;一、数据库表的组成部分 &#x1f384;二、SQL 创建表的基本语法 &#x1f386;三、示例&#xff1a;创建用户表 1.SQL Server 示例 2.MySQL 示例 3.PostgreSQL 示例 4.SQLite 示例 &#x1f455;四、详细说明 &#x1f389;五、注意事项 在数据…

时钟服务器方案选型推荐:ATGM332D-5T和ATGM331C-5T

ATGM331C-5T系列模块同样是具有高灵敏度、低功耗、低成本等优势&#xff0c;适用于电力授时设备、时钟服务器、守时设备&#xff0c;可以直接替换Ublox LEA T系列模块。 性能指标&#xff1a; 从下面的图来看&#xff0c;ATGM331C-5T系列比ATGM332D-5T系列性能更好&#xff0c;…