WEB应用

Nginx内容替换模块http_substitutions_filter_module及实用案例分享

Jager · 12月18日 · 2016年 · · 2324次已读

说到 Nginx 的内容替换功能,大部分人应该都听说过 Nginx 内置的的 subs_filter 替换模块,但是这个模块有个缺憾,就是只能替换一次,而且还不支持正则表达式,这就有些鸡肋了。Nginx内容替换模块http_substitutions_filter_module及实用案例分享

不过,我们可以集成一个第三方的替换模块:ngx_http_substitutions_filter_module,来实现我们的各种需求。

经过测试,这个模块至少有如下实用功能:

①、支持多次替换

②、支持正则替换

③、支持中文替换

Ps:略有遗憾的是,这个替换不能使用到 if 判断模块内,否则就超神了。。。

下面,简单介绍下 ngx_http_substitutions_filter_module 的安装实用以及一些实用案例。

一、编译集成

和所有 Nginx 非内置模块一样,添加模块需要在编译的时候指定模块源码包来集成。当然,Tengine 可以使用动态模块加载的功能,这里就不细说了。

①、下载模块源码包并解压,最后列出目录位置备用

[root@MyServer ~]# wget -O ngx_http_substitutions_filter_module-master.zip https://github.com/yaoweibin/ngx_http_substitutions_filter_module/archive/master.zip
[root@MyServer ~]# unzip ngx_http_substitutions_filter_module-master.zip
[root@MyServer ~]# cd ngx_http_substitutions_filter_module-master && pwd 
/root/ngx_http_substitutions_filter_module-master

github 手动下载地址:https://github.com/yaoweibin/ngx_http_substitutions_filter_module/

②、在服务器上执行 nginx -V 查看当前  Nginx 编译参数,比如:

[root@MyServer ~]# /usr/local/nginx/sbin/nginx  -V
Tengine version: Tengine/2.1.2 (nginx/1.6.2)
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-4) (GCC) 
TLS SNI support enabled
configure arguments: --prefix=/usr/local/nginx --with-http_v2_module --with-http_ssl_module --with-http_gzip_static_module --with-http_realip_module --add-module=../ngx_cache_purge-2.3 --with-http_sub_module

③、加上模块参数,重新编译 Nginx

找到服务器上原来安装时留下的 Nginx 源码目录(如果没有请重新下载并解压,此处不赘述),进入目录后,在第②步中的参数基础上新增集成替换模块(请注意前面需要加上  ./configure ):

./configure [+原有参数+] --add-module=/root/ngx_http_substitutions_filter_module-master/

例如:

./configure --prefix=/usr/local/nginx --with-http_v2_module --with-http_ssl_module --with-http_gzip_static_module --with-http_realip_module --add-module=../ngx_cache_purge-2.3 --with-http_sub_module --add-module=/root/ngx_http_substitutions_filter_module-master/

再往后,则是 make 以及平滑升级,请参考之前的文章完成:

Nginx 在线服务状态下平滑升级或新增模块的详细操作记录

正确完成后,Nginx 就具备内容替换功能了。

二、使用说明

模块的 github 主页其实已经有了很详细的说明了,这里就简单的做下搬运工。

使用示例:

location / {
    subs_filter_types text/html text/css text/xml; 
    subs_filter st(\d*).example.com $1.example.com ir;
    subs_filter a.example.com s.example.com;
    subs_filter http://$host https://$host;
}

从 github 给出的使用示例来看,这个模块涉及 2 个指令:

* subs_filter_types

subs_filter_types 语法: subs_filter_types mime-type [mime-types]

默认: subs_filter_types text/html

适用: http, server, location

subs_filter_types 是用来指定替换文件类型的 默认仅仅替换 text/html 类型的文件。

 

* subs_filter

subs_filter 语法: subs_filter source_str destination_str [gior]

默认: none

适用: http,server,location

subs_filter 是用来替换文本的,可以使用正则

g(默认):替换匹配项。

i  :区分大小写的匹配

o : 只匹配发现的第一个。

r  : 正则匹配。

三、案例分享

①、全站 https

有了这个功能,要实现全站 https 也就是非常简单了,只要把本站的 http://协议代码全部替换成 https 即可。当然,替换时要注意匹配范围,免得把不支持 https 的外链也一起替换了。。。

比如,将如下代码添加到网站 Nginx 配置内即可完成替换

location / { # 新增如下代码
    subs_filter http:// https:// gr; #将页面中的 http 链接全部替换为 https

②、CDN 域名替换

这个模块在 CDN 方面同样简单实用!比如,我们网站要用到七牛 CDN,不管是纯代码还是插件,那都是靠 PHP 代码来进行替换的,性能肯定就不如 Nginx 直接替换来的简单粗暴了。

location / { # 新增如下代码,将静态文件域名替换成七牛
    subs_filter https://zhang.ge/([^"\']*?)\.(jpg|png|js|css|jpeg|bmp) https://example.qiniudn.com/$1.$2 igr;

Ps:经测试,在使用正则模式时,不能使用 nginx 内置变量,比如:$host,否则会出现如下报错:

nginx: [emerg] match part cannot contain variable during regex mode in ***

③、解决前台暴露管理员账号风险

前段时间,看到有博客在说 WordPress 会在前台暴露管理员登陆账户的问题,然后给出了较为复杂的解决办法:通过修改 WordPress 内核函数来隐藏账户名。

修改内核函数,一般是非常无奈,没有其他解决方法的时候才会用到,所以,我看到这个问题第一件时间想到的办法就是替换。

使用 PHP 替换是非常简单的,参考博客之前分享的文章即可搞定:

WordPress 简单代码开启七牛 CDN 及集成七牛缩略图的方法

而对于本文来说,PHP 替换方案依然过于复杂,因为本文一行规则即可解决问题,比如将登录名 admin 替换为 null:

location / {
    # 替换管理员登录名 admin 为 null
    subs_filter  'author-admin' 'author-null';

其他登录名,请自行参考,若有多个登录名可以另起多行或使用正则表达式均可。

鉴于篇幅有限,就分享这三个实用技巧吧,其他就靠自己发掘了,比如镜像网站做内容替换什么的....

28 条回应
  1. 母婴B2B 2016-12-19 · 11:15

    感谢博主的分享!

  2. 腾讯分分彩 2016-12-20 · 21:11

    感谢博主的分享!

  3. 微部落博客 2016-12-21 · 13:28

    这个研究的有点深了,有点儿看不懂

  4. 网赚 2016-12-22 · 16:19

    学习了

  5. 龙笑天 2016-12-23 · 12:58

    [color=green]一脸蒙逼的进来 二脸蒙逼的出去...[/color]

  6. 凯哥自媒体 2016-12-23 · 14:21

    分享的不错,谢谢

  7. 手机蛙排名软件 2016-12-23 · 15:52

    这个案例受益匪浅呀,我学到了很多东西,感谢

  8. Zziv 2016-12-26 · 14:26

    不错

  9. 柒号淘金 2016-12-29 · 12:53

    你们这些技术大牛,哎看不明白

  10. 任务易 2016-12-29 · 13:53

    好多干货都被我收藏了 :neutral:

  11. 你懂的网址 2016-12-31 · 21:59

    不vu哦的文章,学习一下。

  12. 乐赚168 2017-1-2 · 15:15

    收藏了,感谢博主的分享

  13. 明月登楼的博客 2017-1-4 · 18:01

    催更了!博主!

    • avatar
      Jager 2017-1-4 · 19:50

      昨天才更新的。。

  14. 明月登楼的博客 2017-1-4 · 18:02

    汗,为啥这个输入评论的礼花特效在博主这里竟然是全屏震动呀!好牛X呀!求分享!

    • avatar
      Jager 2017-1-4 · 20:08

      不是你分享的代码吗。。。里面有个什么是否抖动的设置,把false改成true即可。

  15. 语录大全 2017-1-17 · 21:40

    这个很实用,可以增加安全系数。

  16. 杭州牛牛工作室 2017-1-29 · 21:49

    值得一看

  17. 淀粉包装秤 2017-1-31 · 16:02

    最美的不是下雨天,而是与你一起躲过雨的屋檐

  18. 不套路网赚 2017-2-1 · 13:10

    谢谢博主分享啊

  19. 杭州牛牛工作室 2017-2-2 · 18:20

    感谢分享

  20. 杭州牛牛工作室 2017-2-4 · 12:09

    赞一个

  21. 健康之路 2017-3-2 · 9:30

    签到成功!签到时间:上午9:29:05 :!: 评论好牛叉呀!激动。。,每日签到,生活更精彩哦~

  22. harries 2017-3-30 · 22:49

    曾经做过1年多的运维

  23. Win7en乐园 2017-4-3 · 13:02

    学习呀,蛮有用的。打个字,屏幕都了闪、 :arrow:

  24. 果趣网 2017-4-9 · 1:31

    签到成功!签到时间:上午1:29:47,每日签到,生活更精彩哦~

  25. 凯尚达 2017-4-21 · 16:23

    谢谢

  26. 宝宝计划客户端 2017-5-19 · 0:42

    这个很有用