iptablesでstringモジュールを使う


知らなかったのだけど、iptablesのstringモジュールを使うと文字列で色々処理することができるらしいです。

例えば”/hoge.php”というアクセスを遮断したい場合。
通常Webサーバーや.htaccessなどを使うことが多いと思いますが、iptablesでも遮断することができました。

こんな感じで設定できます。

$ sudo /sbin/iptables -I INPUT -m string --algo bm --string "/hoge.php" -j DROP

保存しておきたければ、下記を実行すると良いと思います。

$ sudo /sbin/service iptables save

設定後はこんな風になります。

% sudo iptables -nL
Chain INPUT (policy ACCEPT)
target     prot opt source               destination
DROP       all  --  0.0.0.0/0            0.0.0.0/0           STRING match "/hoge.php" ALGO name bm TO 65535

実際にこれで/hoge.phpへアクセスしたところ、タイムアウトして、接続できませんでした。
他にも使い所がありそうなので使っていきたいですね。