博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Nginx——重写与重定向
阅读量:2442 次
发布时间:2019-05-10

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

重写与重定向

在实际网站运营的过程中,为了能够在修改网站结构或域名后,避免造成网站中的链接或在其他网站中的外链失效,以及提高该网站在搜索引擎的收录量和排名等目的。通常会采用URL重写与重定向,在增强网站专业化的同时,为用户提供更加舒适的使用体验。

rewrite模块概述

重写与重定向功能是现在大多数Web服务器都支持的一项功能,相对于其他产品而言,Nginx中的rewrite模块提供的功能在配置上更加的灵活自由,可定制性非常的高。它的实现方式也非常的简单,只需要通过rewrite指令根据Nginx提供的全局变量或自定义的变量,结合正则表达式以及进一步处理的标识就可以完成URL重写或重定向。

rewrite实现重写

在使用rewrite指令实现重写前,首先看一下rewrite指令的基本语法,具体如下:

rewrite regex replacement [flag];

上述语法表示,符合rewrite 编写的正则语法规则,就执行相应的替换算法。其中,参数regex表示正则表达式,参数replacement表示符合正则规则的替换算法,可选参数flag用于指定进一步处理的标识,flag的可选值如表所示:

在这里插入图片描述
当flag的值为last或break时,标识当前的设置为重写,当flag的值为redirect或permanent时表示重定向。

1. rewrite的重写:

打开Nginx的配置文件,配置域名为localhost的虚拟主机,并规定访问不到文件或目录时执行重写操作,具体配置如下所示:

server {
listen 80; server_name localhost; index index.html index.htm; root html; if (!-e $request_filename){
rewrite "^/.*" /default/default.html break; }}

上述第6行配置,通过if指令判断访问不到用户请求的文件或目录时,执行第7行指令。其中,!-e用于判断不存在指定的文件或目录时,执行if块内的语句。内置变量$request_ filename 表示当前请求的文件路径;^/.*用于匹配当前网站下的所有请求,/default/default.html用于替换符合指定规则的请求。

值得一提的是,if指令根据给定的条件进行判断,如果判断结果为true,则执行大括号“{}”内的指令。当判断条件仅是一个变量时,如果值为空或任何以0开头的字符串都会当做false,不再执行大括号内的指令。

if指令中可以使用的判断符号如表:

在这里插入图片描述

在根目录下创建default目录,并在该目录下编写default.html文件:

Welcome to html/default/default.html!

访问一个不存在的文件:localhost/ffff.df

在这里插入图片描述

2. break和last标识的区别:

在使用rewrite实现重写时,需要注意flag可选参数值break和last的区别,前者在rewrite指令匹配成功后就不再进行匹配,而后者在rewrite后会根据rewrite匹配的规则重新发起一个请求继续进行匹配。为了明确地看到两者的区别,下面通过二个案例进行验证。

① 设置匹配规则

server {
listen 80; server_name localhost; root html; location /break/ {
rewrite ^/break/(.*)/test/$1 break; echo "break page"; } location /last/ {
rewrite ^/last/(.*)/test/$1 last; echo "last page"; } location /test/ {
echo "test page"; }}

上述配置,根据location的不同匹配规则,执行不同的rewrite重写,并通过echo指令在rewrite后输出不同的提示信息。

② 测试验证

在这里插入图片描述

对比.上述验证结果,当用户的请求符合第5行location 规则时,执行第6行rewrite指令后,根据break的指定,继续执行第7行配置。而当用户的请求符合第9行location规则时,执行第10行rewrite指令后,根据last的指定,按照匹配到的替换算法发起一个新的请求http://test. ng. test/ test/ last. html,最终匹配到第13行的location规则,然后执行第14行的echo输出语句。

因此,在实际使用rewrite配置重写时,要根据实际情况选择合适的flag可选参数值,,否则会造成与预期不一样的结果。

rewrite实现重定向

rewrite的重定向就是将用户访问的URL修改为重定向的地址,只需将flag的可选参数值设置为redirect或permanent即可实现。具体配置如下:

server {
listen 80; server_name localhost; root html; set $name $1; rewrite ^/img-([0-9]+).jpg$/img/$name.jpg permanent;}

上述第5行配置,利用set指令为变量$name赋值,$1表示符合正则表达式第一个子模式的值,如第6行中的子模式([0-9]+ )匹配到的值,可以是2、45等由一个或多个数字组成的字符串。第6行用于在用户请求“http://localhost/img-数字. jpg”时,重定向到“http://localhost/img/数字jpg"

接下来,在localhost的网站目录中创建一个用于存放图片的img目录,然后在该目录中保存一个文件名为2.jpg的图片。为了测试当前配置是否成功,通过浏览器访问http://localhost/img-2. jpg,会跳转到http://localhost/img/2.jpg

需要注意的是,redirect和permanent在使用时有一定的区别,前者返回的HTTP状态码是302(临时重定向),使得搜索引擎在抓取新内容的同时保留旧的网址,后者返回的HTTP状态码是,301(永久重定向)会让搜索引擎在抓取新内容的同时也将旧的网址永久替换为重定向之后的网址。

转载地址:http://ilpqb.baihongyu.com/

你可能感兴趣的文章
使用批处理脚本上传ftp_通过批处理脚本将文件上传到FTP站点
查看>>
linux下如何更改主机名_如何在不重新启动的情况下更改Linux主机名
查看>>
pxe网络启动引导程序_如何使用PXE设置网络可引导实用程序光盘
查看>>
凌乱的yyy_如何清理凌乱的Internet Explorer上下文菜单
查看>>
Laravel Eloquent:API资源
查看>>
在React中使用Font Awesome 5
查看>>
React Hooks入门
查看>>
盖茨比乔布斯_用盖茨比快速浏览WordPress站点
查看>>
docker react_10分钟内即可实现具有安全性的React + Docker
查看>>
vue.js表单验证_Vue.js中的模板驱动表单验证
查看>>
软件测试结束标志_使用功能标志进行生产中的测试
查看>>
css网格_在CSS网格中放置,跨度和密度
查看>>
火狐动态调试css_使用Firefox开发工具调试CSS网格
查看>>
服务周期性工作内容_使服务工作者生命周期神秘化
查看>>
响应式屏幕_检测角度的响应式屏幕尺寸
查看>>
vue中使用vuex_使用Vuex在Vue中处理身份验证
查看>>
报纸打字项目_使用打字稿设置节点项目
查看>>
nuxt.js 全局 js_在Nuxt.js应用中实现身份验证
查看>>
具有NgClass和NgStyle的Angular 2+类
查看>>
网络抓取_使用ScrapeStack轻松进行网络抓取
查看>>