码迷,mamicode.com
首页 > 其他好文 > 详细

Nginx Rewrite的应用-根据访问平台做简单跳转

时间:2016-04-10 10:25:54      阅读:281      评论:0      收藏:0      [点我收藏+]

标签:nginx   rewrite   http_user_agent   

Nginx Rewrite的应用-根据访问平台做简单跳转



Rewrite模块简介

   Rewrite最主要的作用就是对URL进行重写,即重定向。举个简单的例子,我们用电脑打开淘宝显示出的页面与手机打开显示出的页面,或者是IE与Chrome浏览器打开的页面,有着特别大的差别,这就是使用了Rewrite模块,为用户提供最合适的页面。


Rewrite的配置

一. 在配置之前请先安装好Nginx。不会安装的同学请看我之前写过的Nginx的编译安装
二. 下面我们来编辑Nginx的主配置文件:

[root@code ~]# vim /usr/local/nginx/conf/nginx.conf

在server段加入如下内容:

if ($http_user_agent ~ Mobile){
rewrite ^(.*)$ /Mobile/$1 break;
}
if ($http_user_agent ~ Chrome){
rewrite ^(.*)$ /Chrome/$1 break;
}
if ($http_user_agent ~ like){
rewrite ^(.*)$ /IE/$1 break;
}
if ($http_user_agent ~ Gecko){
rewrite ^(.*)$ /Firefox/$1 break;
}

这段代码是判断用户使用的是什么平台访问的,并根据平台的不同将请求的资源重定向到特定的URL。

三. 下面定义访问页面

1.为Mobile定制的访问页面
[root@code ~]# mkdir -p /usr/local/nginx/html/Mobile/
[root@code ~]# echo “This is Mobile Page” > /usr/local/nginx/html/Mobile/test.html

2.为Chrome定制的访问页面
[root@code ~]# mkdir -p /usr/local/nginx/html/Chrome/
[root@code ~]# echo “This is Chrome Page” > /usr/local/nginx/html/Chrome/test.html

3.为IE定制的访问页面
[root@code ~]# mkdir -p /usr/local/nginx/html/IE/
[root@code ~]# echo “This is IE Page” > /usr/local/nginx/html/IE/test.html

4.为Firefox定制的访问页面
[root@code ~]# mkdir -p /usr/local/nginx/html/Firefox/
[root@code ~]# echo “This is Firefox Page” > /usr/local/nginx/html/Firefox/test.html

5.启动服务或重启服务
启动:[root@code ~]# /usr/local/nginx/sbin/nginx
重启:[root@code ~]# /usr/local/nginx/sbin/nginx -s reload


使用不同平台进行测试

  • 1.使用手机进行测试

技术分享技术分享

  • 2.使用Chrome进行测试

技术分享技术分享

  • 3.使用Firefox进行测试

技术分享技术分享

  • 4.使用IE进行测试

技术分享

技术分享

测试都没有问题,我们用不同的平台访问同一个资源的时候,访问到的是经过重定向之后,特定给我们这个平台的页面。


配置参数详解

一. $http_user_agent

$http_user_agent是Nginx自带的内置变量,它能够将用户的请求报文头部的浏览器或平台信息记录到变量中,并输出到访问日志中。

二. Mobile、Chrome、like、Gecko

Nginx通过将用户的请求报文头部的浏览器或平台信息记录到变量中,输出到日志的结果就是它们,即访问者的浏览器或平台信息。

1.Mobile 这个是我通过用手机访问Nginx,查看日志后获得的$http_user_agent对应的信息。
2.Chrome 这个是Chrome浏览器的。
3.like 这个是IE浏览器的。可能是Nginx版本的问题,IE的$http_user_agent信息在以前通常是MSIE,但在nginx-1.9.9版本中却变成了like
4.Gecko这个是Firefox浏览器的,同样在以前通常是Firefox

三. 下面是Nginx的日志信息

[root@code ~]# tail /data/logs/nginx/access.log
192.168.1.243 – – [26/Mar/2016:23:56:01 +0800] “GET / HTTP/1.1” 304 0 “-” “Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.75 Safari/537.36”
192.168.1.243 – – [26/Mar/2016:23:56:17 +0800] “GET / HTTP/1.1” 200 612 “-” “Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0”
192.168.1.243 – – [26/Mar/2016:23:57:04 +0800] “GET / HTTP/1.1” 200 612 “-” “Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) likeGecko”
192.168.1.230 – – [26/Mar/2016:23:58:34 +0800] “GET / HTTP/1.1” 200 612 “-” “Mozilla/5.0 (iPhone; CPU iPhone OS 9_2_1 like Mac OS X) AppleWebKit/601.1.46 (KHTML, like Gecko) Version/9.0 Mobile/13D15 Safari/601.1”

浏览器或平台信息/后面的是它的版本,同样我们还可以根据版本进行重定向的控制,在这里我就不一一细说了。如果想知道Nginx更多的内置变量,请访问Nginx Embedded Variables


本文出自 “地球有危险” 博客,请务必保留此出处http://779834367.blog.51cto.com/7182184/1762247

Nginx Rewrite的应用-根据访问平台做简单跳转

标签:nginx   rewrite   http_user_agent   

原文地址:http://779834367.blog.51cto.com/7182184/1762247

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!