前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nginx之Http模块系列之brower模块

Nginx之Http模块系列之brower模块

作者头像
yxxhero
发布2022-05-31 19:26:59
3730
发布2022-05-31 19:26:59
举报
文章被收录于专栏:DevOps充电宝

Nginx之Http模块系列之browser模块

browser模块主要作用是根据http请求头中"User-Agent"的值,以浏览器的特征字符来判断新旧浏览器,并生成对应的变量,以供后续的请求处理逻辑来使用。

1. 简介

ngx_http_browser_module模块,通过判断"User-Agent"请求头的值,来生成变量,以供后续的请求逻辑处理。

2.内置变量列表

  • $modern_browser 如果浏览器被标识为现代浏览器,则等于modern_browser_value指令设置的值;
  • $ancient_browser 如果浏览器被识别为古老浏览器,则等于Ancient_browser_value指令设置的值;
  • $msie 如果浏览器被识别为MSIE,不区分任何版本,则等于1;

3.配置示例

现代浏览器的识别逻辑配置:

代码语言:javascript
复制
modern_browser_value "modern.";

# modern_brower指定何种浏览器以及对应的版本被视为现代浏览器, 配置格式后续介绍

modern_browser msie      5.5;
modern_browser gecko     1.0.0;
modern_browser opera     9.0;
modern_browser safari    413;
modern_browser konqueror 3.0;

当浏览器被判断为现代浏览器时,modern_browser变量等于"modern.",即modern_browser_value配置的变量。
index index.${modern_browser}html index.html;

古老浏览器的兼容判断:

代码语言:javascript
复制
modern_browser msie      5.0;
modern_browser gecko     0.9.1;
modern_browser opera     8.0;
modern_browser safari    413;
modern_browser konqueror 3.0;

modern_browser unlisted;

# ancient_browser配置何种子串被识别为古老浏览器
ancient_browser Links Lynx netscape4;

# 当浏览器被识别为古老浏览器,ancient_browser为1; 在此处可以做兼容处理或者给用户直接以提示,提示更新或者更换现代浏览器;

if ($ancient_browser) {
    rewrite ^ /ancient.html;
}

4.配置格式

代码语言:javascript
复制
Syntax: ancient_browser string ...;
Default:    —
Context:    http, server, location

配置"User-Agent"头有何种子串时,被判断为古老浏览器,特殊子串"netscape4"等价于正则表达式: ^Mozilla/[1-4]

代码语言:javascript
复制
Syntax: ancient_browser_value string;
Default:    
ancient_browser_value 1;
Context:    http, server, location

当识别为古老浏览器时,$ancient_browser变量的值,即默认为1;

代码语言:javascript
复制
Syntax: modern_browser browser version;
modern_browser unlisted;
Default:    —
Context:    http, server, location

配置何种浏览器何种版本时,判定为现代浏览器。browser取值:msie, gecko, opera, safari, konqueror. 版本定义格式为X, X.X, X.X.X, 或者X.X.X.X. ,每个格式的最大值分别为: 4000, 4000.99, 4000.99.99, and 4000.99.99.99。 unlisted为特殊字符串,配置当浏览器都未出现在来modern_browser和ancient_browser匹配范围里,则被视为现代浏览器。否则被视为古老浏览器。如果请求头中未提供"User-Agent"头,则被视为未出现匹配列表中。

代码语言:javascript
复制
Syntax: modern_browser_value string;
Default:    
modern_browser_value 1;
Context:    http, server, location

当识别为现代浏览器时,$modern_browser变量的值,默认为1;

4.总结

ngx_http_browser_module提供了浏览器兼容的判断机制,使我们在做新旧浏览器兼容处理时更为优雅,与高效,同学们可以在实际需求中多加运用,将业务逻辑中的浏览器版本抽离出来,使得业务更像业务,无需考虑其他。 - END -

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-03-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 DevOps充电宝 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Nginx之Http模块系列之browser模块
  • 1. 简介
  • 2.内置变量列表
  • 3.配置示例
  • 4.配置格式
  • 4.总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档