フォーム入力¶
説明¶
form-input-nginx-module - application/x-www-form-urlencoded
でエンコードされたHTTP POST および PUTリクエストボディを読み込み、リクエストボディ内の引数をパースしてNGINX変数に入れます。
このモジュールはngx_devel_kit (NDK)モジュールに依存します。
インストール
- nginx.orgからNGINXソースコードを取得します。
- GitHub simpl-it/ngx_devel_kit repositoryからngx_devel_kit source コードを取得します。
- ソースコードを解凍しこのモジュールを使ってNGINXをビルドします。
$ wget 'http://sysoev.ru/nginx/nginx-0.8.28.tar.gz'
$ tar -xzvf nginx-0.8.28.tar.gz
$ cd nginx-0.8.28/
$ git-clone http://github.com/simpl-it/ngx_devel_kit.git
$ git-clone http://github.com/calio/form-input-nginx-module.git
$ ./configure --add-module=/somepath/form-input-nginx-module --add-module=/somepath/ngx_devel_kit
$ make -j2
$ make install
使い方
set_form_input $variable;
set_form_input $variable argument;
set_form_input_multi $variable;
set_form_input_multi $variable argument;
例:
#nginx.conf
location /foo {
set_form_input $data; # "data"フィールドに$dataを読み込みます
set_form_input $foo foo; # "foo"フィールドを$fooに読み込みます
}
location /bar {
set_form_input_multi $data; # 全ての"data"フィールドを$dataに読み込みます
set_form_input_multi $foo data; # 全ての"data"を$fooに読み込みます
array_join ' ' $data; # ここで$dataは文字列です
array_join ' ' $foo; # ここで$fooは文字列です
}
互換性¶
NGINXの以下のバージョンがこのモジュールで動作するはずです:
- 0.8.x <= 0.8.41 (最後にテストされたバージョンは0.8.43です)
- 0.7.x (最後にテストされたバージョンは0.7.67です)
Copyright & License¶
Copyright (c) 2010, Taobao Inc., Alibaba Group ( http://www.taobao.com/market/global/index_new.php ).
Copyright (c) 2010, calio <vipcalio@gmail.com>.
このモジュールはBSDライセンスの条件でライセンスされます。
修正の如何に関係なくソースおよびバイナリ形式での再配布および使用は以下の条件に合う限り許可されます:
- 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.
- Neither the name of the Taobao Inc. nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
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.
変更ログ¶
form-input-module v0.0.2での変更
set_form_input_multi
のサポートPUT
メソッドをサポート
form-input-module v0.0.1での変更
set_form_input
のサポート