博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
nginx Location 语法基础知识
阅读量:5286 次
发布时间:2019-06-14

本文共 1651 字,大约阅读时间需要 5 分钟。

  URL地址匹配是Nginx配置中最灵活的部分 Location 支持正则表达式匹配,也支持条件匹配,用户可以通过location指令实现Nginx对动丶静态网页的过滤处理。

Nginx location 配置语法

  location [ = | ~ | ~* | ^~ ] uri { ... }

  location @name { ... }

location 配置可以有两种配置方法

前缀 + uri(字符串/正则表达式)

@ + name

前缀含义

=:精确匹配(必须全部相等)

~:大小写敏感

~*:忽略大小写

^~:只需匹配uri部分

@:内部服务跳转

Location 基础知识

  location 是在 server 块中配置。

  可以根据不同的 URI 使用不同的配置(location 中配置),来处理不同的请求。

  location 是有顺序的,会被第一个匹配的location 处理。

 Location 配置演示

 =精确匹配

location = / { #规则 }   

  #则匹配到 `http://www.example.com/` 这种请求。

 

~大小写敏感

location~ /Example/ { #规则 }   

  #请求示例#http://www.example.com/Example/ [成功]

  #http://www.example.com/example/ [失败]

 

~*大小写忽略

 location~* /Example/ { #规则 }

  # 则会忽略 uri 部分的大小写

  #http://www.example.com/Example/ [成功]

  #http://www.example.com/example/ [成功]

 

^~只匹配以 uri 开头

 location ^~ /img/ { #规则 }

  #以 /img/ 开头的请求,都会匹配上

  #http://www.example.com/img/a.jpg [成功]

  #http://www.example.com/img/b.mp4 [成功]

 

 

@nginx内部跳转

 location /img/ { error_page404@img_err; }

 location@img_err { # 规则 }

  #以 /img/ 开头的请求,如果链接的状态为 404。则会匹配到 @img_err 这条规则上。

 

规则分类

其中“~ ”和“~”以及“!~”和“!~”前缀表示正则location .

其他前缀(包括:“=”,“^~”和“@ ”)和无任何前缀的都属于普通location .

 

匹配规则

  普通 location ”的匹配规则是“最大前缀.(特殊的是“=”和“^~”,前缀指令将严格匹配uri ,如果匹配,停止搜索.)正则 location ”的匹配规则是“顺序匹配,且只要匹配到第一个就停止后面的匹配.通用匹配 “/”最后匹配

  先匹配普通 location ,再“考虑”匹配正则 location 。注意这里的“考虑”是“可能”的意思,也就是说匹配完“普通 location ”后,有的时候需要继续匹配“正则 location ”,有的时候则不需要继续匹配“正则 location ”。

  两种情况下,不需要继续匹配正则 location :

  ( 1 )当普通 location 前面指定了“ ^~ ”,特别告诉 Nginx 本条普通 location 一旦匹配上,则不需要继续正则匹配;

  ( 2 )当普通location 恰好严格匹配上,不是最大前缀匹配,则不再继续匹配正则.

  总结:正则 location 匹配让步普通 location 的严格精确匹配结果;但覆盖普通 location 的最大前缀匹配结果.

转载于:https://www.cnblogs.com/yyxianren/p/10723052.html

你可能感兴趣的文章
client offset scroll
查看>>
从关系型数据库到非关系型数据库
查看>>
03_10_Object类的toString equals等方法
查看>>
python之三层菜单递归
查看>>
Flink学习笔记:Time的故事
查看>>
JS获取浏览器窗口大小 获取屏幕,浏览器,网页高度宽度
查看>>
Handler对象
查看>>
spring注入
查看>>
eclipse添加xsd
查看>>
域名空间那些事 第二季
查看>>
【2007-4】【鹅卵石图案】
查看>>
利用余数选择特殊位置元素
查看>>
position-relative 的问题
查看>>
浏览器视口宽度高度的封装
查看>>
jquery UI 弹出框
查看>>
CSS之float(解决float自增长高度问题)
查看>>
Java设计模式——策略模式(Strategy Pattern)
查看>>
Index Filter及ICP特性
查看>>
scanf格式控制符之%[]的应用
查看>>
Python 多线程教程:并发与并行
查看>>