• Stars
    star
    606
  • Rank 73,958 (Top 2 %)
  • Language
    Perl
  • Created over 12 years ago
  • Updated almost 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

a filter module which can do both regular expression and fixed string substitutions for nginx
nginx_substitutions_filter
    *Note: this module is not distributed with the Nginx source.
    Installation instructions can be found below.*

  Description
    nginx_substitutions_filter is a filter module which can do both regular
    expression and fixed string substitutions on response bodies. This
    module is quite different from the Nginx's native Substitution Module.
    It scans the output chains buffer and matches string line by line, just
    like Apache's mod_substitute
    (<http://httpd.apache.org/docs/trunk/mod/mod_substitute.html>).

  Example
    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;
    }

  Directives
    *   subs_filter_types

    *   subs_filter

   subs_filter_types
    syntax: *subs_filter_types mime-type [mime-types] *

    default: *subs_filter_types text/html*

    context: *http, server, location*

    *subs_filter_types* is used to specify which content types should be
    checked for *subs_filter*, in addition to *text/html*. The default is
    only *text/html*.

    This module just works with plain text. If the response is compressed,
    it can't uncompress the response and will ignore this response. This
    module can be compatible with gzip filter module. But it will not work
    with proxy compressed response. You can disable the compressed response
    like this:

    proxy_set_header Accept-Encoding "";

   subs_filter
    syntax: *subs_filter source_str destination_str [gior] *

    default: *none*

    context: *http, server, location*

    *subs_filter* allows replacing source string(regular expression or
    fixed) in the nginx response with destination string. The variables 
    in matching text is only avaiable under fixed string mode, which means 
    the matching text could not contain variables if it is a regular 
    expression. Substitution text may contain variables. More than one 
    substitution rules per location is supported. 
    The meaning of the third flags are:

    *   *g*(default): Replace all the match strings.

    *   *i*: Perform a case-insensitive match.

    *   *o*: Just replace the first one.

    *   *r*: The pattern is treated as a regular expression, default is
        fixed string.

   subs_filter_bypass
    syntax: *subs_filter_bypass $variable1 ...*

    default: *none*

    context: *http, server, location*

    You can specify several variables with this directive. If at least one
    of the variable is not empty and is not equal to '0', this substitution
    filter will be disabled.

  Installation
    To install, get the source with subversion:

    git clone
    git://github.com/yaoweibin/ngx_http_substitutions_filter_module.git

    and then compile nginx with the following option:

    ./configure --add-module=/path/to/module

  Known issue
    *   Can't substitute the response header.

  CHANGES
    Changes with nginx_substitutions_filter 0.6.4 2014-02-15

    *   Now non-200 response will work

    *   added the subs_filter_bypass directive

    Changes with nginx_substitutions_filter 0.6.2 2012-08-26

    *   fixed a bug of buffer overlap

    *   fixed a bug with last zero buffer

    Changes with nginx_substitutions_filter 0.6.0 2012-06-30

    *   refactor this module

    Changes with nginx_substitutions_filter 0.5.2 2010-08-11

    *   do many optimizing for this module

    *   fix a bug of buffer overlap

    *   fix a segment fault bug when output chain return NGX_AGAIN.

    *   fix a bug about last buffer with no linefeed. This may cause segment
        fault. Thanks for Josef Fröhle

    Changes with nginx_substitutions_filter 0.5 2010-04-15

    *   refactor the source structure, create branches of dev

    *   fix a bug of small chunk of buffers causing lose content

    *   fix the bug of last_buf and the nginx's compatibility above 0.8.25

    *   fix a bug with unwanted capture config error in fix string
        substitution

    *   add feature of regex captures

    Changes with nginx_substitutions_filter 0.4 2009-12-23

    *   fix many bugs

    Changes with nginx_substitutions_filter 0.3 2009-02-04

    *   Initial public release

  Reporting a bug
    Questions/patches may be directed to Weibin Yao, [email protected].

  Copyright & License
    This module is licensed under the BSD license.

    Copyright (C) 2014 by Weibin Yao <[email protected]>.

    All rights reserved.

    Redistribution and use in source and binary forms, with or without
    modification, are permitted provided that the following conditions are
    met:

    *
          Redistributions of source code must retain the above copyright

        notice, this list of conditions and the following disclaimer.

    *
          Redistributions in binary form must reproduce the above copyright

        notice, this list of conditions and the following disclaimer in the
        documentation and/or other materials provided with the distribution.

    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
    IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
    TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
    PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
    HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
    SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
    TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
    PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
    LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
    NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

More Repositories

1

nginx_tcp_proxy_module

add the feature of tcp proxy with nginx, with health check and status monitor
C
1,641
star
2

nginx_ajp_module

support AJP protocol proxy with Nginx
Perl
246
star
3

nginx_syslog_patch

add the full syslog feature to Nginx
Perl
132
star
4

nginx_limit_speed_module

limit the total speed from the specific user
C
107
star
5

nginx_limit_access_module

support to deny specific variable with HTTP POST interface
Perl
70
star
6

nginx_http_recaptcha_module

support google's reCAPTCHA with Nginx
Perl
54
star
7

nginx_http_oauth_module

support oauth client with nginx
Perl
32
star
8

captcha_server

captcha_server
Java
26
star
9

nginx_secure_cookie_module

add the secure cookie
Perl
23
star
10

nginx_cross_origin_module

add the support for cross-origin resource sharing protocol: http://www.w3.org/TR/cors/
Perl
21
star
11

aho_corasick_state_machine

Use Aho-Corasick state machine to string matching(C language, under BSD License)
C
18
star
12

nginx_upstream_keepalive_patch

Patch for upstream HTTP protocol keepalive
Perl
17
star
13

nginx-sticky-module

clone from http://code.google.com/p/nginx-sticky-module/
C
15
star
14

mod_tcache

Memory cache module for Nginx
C
13
star
15

nginx_session_store_module

add the session support for Nginx
C
8
star
16

parse_domain

parse the domain and get the Top Level Domain
C
6
star
17

nginx_http_redis_module

fork from nginx_http_redis_module_0.3.4
C
5
star
18

squid_gzip

add the gzip feature to squid-2.7 on the fly
Perl
4
star
19

chinese_text_filter

Process the Chinese text stuff
Ruby
3
star
20

mguesser

language detection, fork from http://www.mnogosearch.org/guesser/
C
3
star
21

regex_test

test the performance and feature with some regex librarys
2
star
22

libcharguess

clone from http://sourceforge.net/projects/libcharguess/
C
2
star
23

zh_conversion

map between traditional and simplified words
Ruby
2
star
24

nginx_if_contain_patch

This a patch for our private use.
2
star
25

super_http_benchmark_test

a more stress and simple HTTP test tool
C
1
star
26

ruby_example

private ruby experimental examples
C
1
star
27

yaoweibin.ruhoh.com

a blog
Ruby
1
star
28

test

test
Vim Script
1
star
29

yaoweibin_html5_slides

yaoweibin html5 slides (steal from http://code.google.com/p/html5slides/)
JavaScript
1
star
30

yaoweibin.github.com

My homepage
1
star
31

statistic_game

statistic_game
Ruby
1
star