详解常用的nginx rewrite重写规则

详解常用的nginx rewrite重写规则

本文主要介绍Nginx常用的重写规则。nginx的重写功能是利用nginx提供的全局变量或者自己设置的变量,结合正则表达式和标志位,对URL进行重写和重定向。有兴趣的可以一起了解一下。

本文提供了一些常用的重写规则来美化网页的链接。如果你不知道如何得到规则中的$1$2,只要记住第一个()是$1,第二个()是$2。

请求的网址是给人看的,重写的网址是给电脑看的。

执行搜索

此规则的目的是搜索URL中包含的关键字。

请求的网址//hqidi . com/search/some-search-keywords

重写网址//hqidi.com/search.php?p=一些搜索关键词

重写规则rewrite/search/(。*) $/search.php?p=$1?

用户个人资料页面

大多数运行访问者注册的动态网站都提供了一个页面,您可以在其中查看个人数据。该页面的URL包含用户的UID和用户名。

请求的网址//hqidi.com/user/47/dige

重写网址//hqidi.com/user.php?id=47name=dige

重写规则rewrite/user/([0-9])/(。)$/user.php?id=$1name=$2?

多个参数

一些网站对字符串参数使用不同的语法,例如用斜杠“/”分隔未命名的参数

请求的URL//hqidi . com/index . PHP/param 1/param 2/param 3

重写网址//hqidi.com/index.php?p1=param1p2=param2p3=param3

重写规则rewrite/index.php/(。*)/(.*)/(.*) $/index.php?p1=$1p2=$2p3=$3?

类似百科的格式

这种格式的特点是前缀目录后跟文章名称。

请求的URL//hqidi . com/wiki/Some-keywords

重写网址//hqidi.com/wiki/index.php?title=一些-关键字

重写规则rewrite/wiki/(。*) $/wiki/index.php?title=$1?

论坛

一般论坛用两个参数,一个话题,一个发帖。

请求的网址//hqidi . com/topic-1234-50-some-keywords . html

重写网址//hqidi.com/viewtopic.php?主题=1234开始=50

重写规则重写/主题-([0-9])-([0-9])-(。*) .html $ viewtopic.php?topic=$1start=$2?

新网站的文章

这个URL结构的特征是一个文章标识符,后跟一个斜杠和一个关键字列表。

请求的网址//hqidi.com/88/future

重写网址//hqidi.com/atricle.php?id=88

重写规则rewrite/([0-9])/。* $/article . PHP?id=$1?

最后一个问号

如果替换的URI包含参数(比如/app/test.php?URI如id=5),默认情况下,该参数会自动附加到替换字符串上,这可以通过添加?马克解决了这个问题。

重写^/users/(.*)$ /show?user=$1?最后;

对比一加?标而不加?标记的URL跳转差异:

重写^/test(.*)$//hqidi . com/home pre manent;

去//hqidi.com/test?id=5 301跳转后的URL地址是//hqidi.com/home?id=5

重写^/test(.*)$ //hqidi.com/home?持久的;

去//hqidi.com/test?id=5 301跳转后的网址是//hqidi.com/home

Nginx的重写功能需要PCRE软件的支持,即通过perl兼容的正则表达式语句匹配规则。参数编译nginx默认会支持重写模块,但也必须PCRE支持。

重写是实现URL重写的关键指令。根据regex(正则表达式)部分,重定向到替换,标志在末尾。

nginx rewrite指令执行顺序

1.执行服务器块的重写指令(这里的块是指server关键字后用{}包围的区域,类似于其他xx块)

2.执行位置匹配

3.在所选位置执行重写命令

如果一个步骤的URI被重写,再次执行1-3,直到找到真正的文件。

如果循环次数超过10次,则返回500内部服务器错误错误。

标志位

重写的语法很简单,比如:

重写正则表达式URL[标志];

Rewrite是关键字,regex是正则表达式,URL是要替换的内容,[flag]是标志位的意思。它具有以下值:

Last:相当于Apache的[L]标记,表示重写完成。

Break:停止执行当前虚拟主机的后续重写指令集。

重定向:返回302临时重定向,跳转后地址栏会显示地址。

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

因为301和302不能简单的只返回状态码,还必须有重定向的URL,这也是返回指令不能返回301,302的原因。这里last和break的区别有点难以理解:

Last一般写在server和if,而break一般用在location。

Last不终止重写后的url匹配,即新的url将从服务器再次经历匹配过程,break终止重写后的匹配。

并且break last可以组织继续执行下面的重写指令。

看一个简单的例子:

重写^/listings/(.*)$ /listing.html?listing=$ 1 last

重写^/images/(.*)_(d )x(d )。(png|jpg|gif)$ /resizer/$1。$4?宽度=$ 2高度=$3?最后;

在第一个重写规则中,我们可以使用友好的URL:http://mysite.com/listings/123而不是http://mysite.com/listing.html?清单=123,这意味着我们在浏览器的地址栏输入http://mysite.com/listings/123后,实际访问的URL资源是http://mysite.com/listing.html?清单=123。

在第二个规则中,对形状像http://mysite.com/images/bla_500x400.jpg的文档的请求被重写为http://mysite.com/resizer/bla.jpg?宽度=500高度=400地址,并将继续尝试匹配位置。

If指令和全局变量

if指令的语法是if(condition){.},判断给定的条件。如果为真,将执行花括号中的重写指令。

看看代码规则:

if ($http_user_agent ~ MSIE) {

重写^(.*)$/msie/$ 1 break;

}//如果UA包含“MSIE”,则将请求重写到/msid/目录

if($ http _ cookie ~ * id=([^;] )(?|$)) {

设置$ id $ 1;

}//如果cookie匹配正则,则将变量$id设置为正则引用部分

if ($request_method=POST) {

返回405;

}//如果提交方法是POST,则返回状态405(不允许方法)。退货不能退301,302。

if(slow){

limit _ rate 10k

}//速度限制,$slow可以通过set命令设置

如果(!-f $请求文件名){

打破;

proxy _ pass http://127 . 0 . 0 . 1;

}//如果请求的文件名不存在,反向代理到localhost。这里的中断也停止了重写检查。

if ($args ~ post=140){

重写http://mysite.com/^永久;

}//如果查询字符串包含“post=140”,则永久重定向到mysite.com

在if指令中,可以使用全局变量。这些变量是:

$ args: #此变量等于请求行中的参数,与$query_string相同

$content_length:请求头中的内容长度字段。

$content_type:请求头中的内容类型字段。

$document_root:当前请求指定了根指令中的值。

$host:请求主机头字段,否则为服务器名。

$http_user_agent:客户端代理信息

$http_cookie:客户端cookie信息

$limit_rate:这个变量可以限制连接速率。

$request_method:客户端请求的动作,通常是GET或POST。

$remote_addr:客户端的IP地址。

$remote_port:客户端的端口。

$remote_user:已经通过Auth Basic模块验证的用户名。

$request_filename:当前请求的文件路径,由root或alias指令和URI请求生成。

$ scheme: http协议(比如http,https)。

$server_protocol:用于请求的协议,通常是HTTP/1.0或HTTP/1.1。

$server_addr:服务器地址,可以在系统调用完成后确定。

$server_name:服务器名称。

$server_port:请求到达服务器的端口号。

$request_URI:包含请求参数的原始URI,但不包含主机名,例如:“/foo/bar.php?”arg=baz .

$uri:没有请求参数的当前uri。$uri不包含主机名,例如“/foo/bar.html”。

$document_uri:与$uri相同。

使用return跳转

有时候我们需要使用重写在Nginx上做301地址跳转,比如下面的规则:

重写^ $ scheme://www . my site . com $ request _ uri永久;

当访问任何网址,301将被永久定向到www.mysite.com的网址。这样写是对的,但是因为重写的规律匹配,会浪费一些资源。nginx官网不推荐这种写法。我们也可以用return来实现301跳转,简单实用。参见示例:

01永久定向到新域名

服务器{

听80;

监听443 ssl

www.old-name.comold-name.com;

return 301 $ scheme://www . new-name . com;

}

上面的代码实现了旧域名301跳转到新域名。如果网站要换新域名,用这个方法做301跳转。

没有www的域名301跳转到带有www的域名。

服务器{

听80;

监听443 ssl

服务器名mysite.com;

return 301 $ scheme://www . my site . com $ request _ uri;

}

Http站点301跳转到https站点

服务器{

听80;

服务器名www.mysite.com;

return 301 https://www . my site . com $ request _ uri;

}

以上就是Nginx的重写和重定向的介绍。如果觉得有用,请多练习。好好保存这篇文章,你就不会迷路了。也希望大家能支持我们。

详解常用的nginx rewrite重写规则