Nginx location 与 Rewrite

Nginx正则表达式

location

通过前缀或正则匹配用户的URL访问路径做页面跳转、访问控制和代理转发

location 大致可以分为三类:

精准匹配:location = / {...}

一般匹配:location / {...}

正则匹配:location ~ / {...}

location 常用的匹配规则:

= :进行普通字符精确匹配,也就是完全匹配。

^~ :表示普通字符匹配。使用前缀匹配。如果匹配成功,则不再匹配其它 正则匹配location。

~ :区分大小写的匹配。

~* :不区分大小写的匹配。

!~ :区分大小写的匹配取非。

!~* :不区分大小写的匹配取非。

location匹配机制:

优先级:精准匹配 = > 最长前缀匹配 ^~ > 正则匹配 ~ ~* !~ !~* > 一般前缀匹配 /XXXX > 通用匹配 /

在没有合适的精准匹配的情况下,先看前缀匹配的长度,取最长匹配的location(如果此最长匹配是带有^~的则不再看正则匹配;如果此最长匹配是不带有^~的则会继续再看正则匹配)

前缀匹配看长度,最长的优先匹配;正则匹配看上下顺序,根据nginx配置文件的配置由上往下依次匹配,匹配到即停止

网站匹配规则

#网站首页匹配

location = / {

root 网页根目录;

index index.html;

}

#网站静态页面,通过前缀匹配或通用匹配在nginx服务器本地处理

location ~ /static/ {

root 目录;

}

location / {

root 目录;

}

#网站动态页面,通过匹配不同的动态网页文件后缀转发给不同的后端应用服务器处理

location \.php$ {

fastcgi_pass PHP服务器地址:端口;

}

location \.jsp$ {

proxy_pass TOMCAT服务器地址:端口;

}

rewrite

对用户的URL访问路径进行重写,再重定向跳转访问重写后的路径

rewrite格式

rewrite 正则表达式 重写的地址 [标记位];

last break permanent redirect

###flag标记说明###

last :本条规则匹配完成后,不终止重写后的url匹配,一般用在 server 和 if 中。

break :本条规则匹配完成即终止,终止重写后的url匹配,一般使用在 location 中。

redirect :返回302临时重定向,浏览器地址会显示跳转后的URL地址。

permanent :返回301永久重定向,浏览器地址栏会显示跳转后的URL地址。

rewrite默认情况下只对从域名后面的根目录 / 开始到传递参数的 ? 号前面的URL路径进行重写

rewrite 正则表达式 /新URL; http://域名/旧URL -> http://域名/新URL #默认只对域名后面的URL部分重写

rewrite 正则表达式 http://新域名/新URL; http://旧域名/旧URL -> http://新域名/新URL; #如果需要全域名路径重写需要加上协议和域名

http://域名/旧URL --rewrite重写--> http://域名/新URL --> location匹配新URL路径跳转页面

rewrite 正则表达式 /新URL permanent; #重写后会修改浏览器里的地址栏再重新访问

http://域名/旧URL --rewrite重写--> http://域名/新URL --> 浏览器地址栏也会改为 http://域名/新URL 再发起一次访问请求 --> location匹配新URL路径跳转页面

location ~ URL路径正则表达式 {

rewrite 正则表达式 重写的地址 [标记位];

}

$request_uri

if ($uri ~ URL路径正则表达式) {

rewrite 正则表达式 重写的地址 [标记位];

}

rewrite示例

相关推荐
Full Stack Developme4 小时前
Linux 多种压缩格式,优缺点和适用场景
linux·运维·服务器
敲敲了个代码7 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
TG:@yunlaoda360 云老大8 小时前
华为云国际站代理商GeminiDB的企业级高可用具体是如何实现的?
服务器·网络·数据库·华为云
j_xxx404_8 小时前
Linux:第一个程序--进度条|区分回车与换行|行缓冲区|进度条代码两个版本|代码测试与优化
linux·运维·服务器
dly_blog8 小时前
Vue 响应式陷阱与解决方案(第19节)
前端·javascript·vue.js
消失的旧时光-19438 小时前
401 自动刷新 Token 的完整架构设计(Dio 实战版)
开发语言·前端·javascript
console.log('npc')9 小时前
Table,vue3在父组件调用子组件columns列的方法展示弹窗文件预览效果
前端·javascript·vue.js
用户47949283569159 小时前
React Hooks 的“天条”:为啥绝对不能写在 if 语句里?
前端·react.js
我命由我123459 小时前
SVG - SVG 引入(SVG 概述、SVG 基本使用、SVG 使用 CSS、SVG 使用 JavaScript、SVG 实例实操)
开发语言·前端·javascript·css·学习·ecmascript·学习方法
用户479492835691510 小时前
给客户做私有化部署,我是如何优雅搞定 NPM 依赖管理的?
前端·后端·程序员