今回はURIに特定の文字列を含むリクエストをブロックするルールを作成して実際にブロックされるか確認してみましょう。検知する文字列は”test.txt”にします。
目次
Conditionの作成
1.AWS WAFのコンソール画面にて [ String and regex matching ] をクリックします。
2.[ Create condition ] をクリックします。
data:image/s3,"s3://crabby-images/4bbf1/4bbf16db2084b73f3bae6c187c4d7dc3728bf41d" alt=""
3.「Name」には任意の名前を入力します。 今回は ”test_txt”とします。「Filter settings」内の「Part of the request to filter on」でリクエスト内のフィルターをかける部分を「URI」にします。次に「Matching type」を「Contains」にし、「Transformation」は「None」にします。最後に「Value in match」に “test.txt”と入力したら [Add filter] をクリックします。
data:image/s3,"s3://crabby-images/08fa6/08fa61c324f0d4a5813ea9517f4b380fe73914bc" alt=""
4.入力が完了しましたら最後に [ Add filter ] をクリックしてConditionを追加します。「Filters in this string match condition」へのフィルター追加が確認できましたら [ Create ] をクリックして作成します。
data:image/s3,"s3://crabby-images/d9673/d96736df7095d4233e560e3e6d7baecfbbe40f1e" alt=""
これでConditionの作成ができました。
Ruleの作成
1.メニューから[ Rules ]をクリックします。
data:image/s3,"s3://crabby-images/31460/314608f30ab7dd84c71e47029257b59fdf795e17" alt=""
2.Rules設定画面が表示されたら [ Create rule ] をクリックし、Rule(“TEST_TXT_RULE”)の作成を行います。
data:image/s3,"s3://crabby-images/bfe49/bfe4997b075693584af65a69216c2884c9e802af" alt=""
3.先ほど、作成したCondition(“test_txt”)を設定します。「What a requests」リクエストがConditionと一致している場合に適用する「does」、一致していない場合に適用する「does not」を選択します。
data:image/s3,"s3://crabby-images/5a928/5a92803926072c2349ddae2374677c818ca216c8" alt=""
4.フィルタリングの種類を「match at least one of filters in the string match condition」にします。Conditionの一覧から該当するCondition(“test_txt”)を選択して追加を確認したら [ Create ] をクリックします。
data:image/s3,"s3://crabby-images/2e1b1/2e1b17bfb50b06ea09eadeb2d0b5607419cfffe8" alt=""
これでRuleの作成が完了しました。
ACL( Access Control List )への追加
1.[ Web ACLs ] をクリックします。先程作成した Rule を追加したいACLをクリックします。 私は“RULE_TEST”というWeb ACLにします 。
data:image/s3,"s3://crabby-images/c986a/c986a89cb3704a07b42e489a2d183ee9339bedb0" alt=""
2.[ Rules ] のタブをクリックして、[ Edit web ACL ] をクリックします。[ Rules ] のプルダウンで今回作成したRuleを選択し、[ Add rule to web ACL ] をクリックすると「If a request matches all the conditions in a rule, take the corresponding action」に追加されます。今回はブロックをしたいため「Action」は「Block」をチェックします。
data:image/s3,"s3://crabby-images/b1be5/b1be5588490ef6065964611178dee5ae0c0c765d" alt=""
3.続いて「Default action」を「Allow」にチェックをいれ [ Update ] をクリックします。Default actionは検知対象外のリクエストを「許可」または「拒否」どちらにするかを設定する項目になりますのでここを「Block」にするとRuleで許可されたリクエスト以外は全てブロックされてしまいます。ご注意ください。
data:image/s3,"s3://crabby-images/1ed92/1ed92ec9d063446f198ba8cf3d5cf1fe2dc8aeec" alt=""
これでWeb ACLにRuleを追加できました。
data:image/s3,"s3://crabby-images/a4d68/a4d684545f2589e40c4d1293f77cfed3442fb432" alt=""
では実際にテストを行ってみます。このRuleを適用した状態でブラウザで「http://example.com」へアクセスすると以下の画面が表示されます。example.com は環境に応じて適宜変更してください。下記のような画面が出てきたので、問題なくアクセスできました。
data:image/s3,"s3://crabby-images/4b90a/4b90a5150ea50607665b283896fde96407943ddb" alt=""
では次に「http://example.com/test.txt」にアクセスしてみると “403” のエラーが返ってきました。
data:image/s3,"s3://crabby-images/116e7/116e78327d0894504ecfd319d4c00f959bb9c4f5" alt=""
このようにルールを設定すると即時で適用され、ブロックすることができます。とても簡単なルールですが、AWS WAFでURIに特定の文字列が含まれるリクエストをブロックする方法をご紹介しました。WAFに興味のある方は是非一度試してみてください。
data:image/s3,"s3://crabby-images/a5262/a5262f86bd2c6d357c6d731cf54453500c106458" alt=""