レンタルサーバー・自宅サーバー設定・構築のヒント
レンタルサーバー・自宅サーバー設定・構築のヒント - レンタルサーバー・自宅サーバーの設定・構築情報を公開しています。

.htaccessで特定のホストからのアクセスを拒否する(2)

2010年11月21日 2015年5月17日
apache access denied

今回は、「.htaccessで特定のホストからのアクセスを拒否する」の続きです。

ここでの話は、FreeBSDもCentOSも関係なく、apacheの設定です。
一般的に、リダイレクトやアクセス規制(制限や拒否など)を行うときに、.htaccessを使います。

その中でも、今回は、アクセス規制、それもスパムや負荷の高いクローラー(検索ロボット)などのアクセス拒否を行うための設定を紹介します。

特定の検索ロボット(クローラー)からのアクセスを拒否する

.htaccessで、検索ロボット(クローラー)を拒否するように設定を行ってみましょう。
一般的に検索ロボット(クローラー)を拒否する場合は、robots.txtを用います。
例えば、以下の例は、中国の検索サイト百度を拒否するrobots.txtの設定例です。

user-agent: Baiduspider
disallow: /

user-agent: BaiduImagespider
disallow: /

user-agent: BaiduMobaider
disallow: /

百度では、3つのユーザエージェント名で検索ロボット(クローラー)が動作しています。 そのため、その3つを指定することで、アクセス禁止することができると百度のサイトには記載があります。

しかし、実際にいろいろと試しみると、なかなか、アクセスをやめてくれません。

そこで、ここでは、,htaccessを使って特定のホスト(ユーザエージェント)からのアクセスを拒否する設定をしてみます。
ここでは、/var/www/html/.htaccessを編集してみます。

/var/www/html/.htaccessを編集すると、/var/www/html/配下のすべてのディレクトリが影響を受けます。
SetEnvIf User-Agent "[Bb]aidu" deny_ref
Order Allow,Deny
Allow from all
Deny from env=deny_ref

例えば、上記のように設定すれば、ユーザエージェント名Baidu or baidu という名前を含むアクセスをすべて拒否します。
※ここで注意すべきは、ここでの“[Bb]aidu”指定は、正規表現であり、該当する文字列がヒットした場合は、すべて同一アクセスとみなされる点です。

このチェックにヒットした場合、実際には、HTTPステータスコード 403 が返ります。

SetEnvIf attribute regex env-value
の順で指定します。

  • attributeには、

    HTTP リクエストヘッダフィールド(詳細は、RFC 2616 参照)

    • Accept

    • Accept-Charset

    • Accept-Encoding

    • Accept-Language

    • Authorization

    • Expect

    • From

    • Host

    • If-Match

    • If-Modified-Since

    • If-None-Match

    • If-Range

    • If-Unmodified-Since

    • Max-Forwards

    • Proxy-Authorization

    • Range

    • Referer

    • TE

    • User-Agent

    か、もしくは、以下の項目を設定できます。

    • Remote_Host

      – リクエストを行なっているクライアントのホスト名 (もしあれば)

    • Remote_Addr

      – リクエストを行なっているクライアントの IP アドレス

    • Server_Addr

      – リクエストを受け取ったサーバの IP アドレス (2.0.43 以降のみ)

    • Request_Method

      – 使用されているメソッド名 (GET, POST など)

    • Request_Protocol

      – リクエストが行なわれたプロトコルの名前とバージョン (例えば、”HTTP/0.9″, “HTTP/1.1” など。)

    • Request_URI

      – URL のスキームとホストの後の部分。 追加の情報として、クエリーストリングにマッチさせる場合については RewriteCond ディレクティブを参照してください。

  • regexには、

    attribute で指定した情報をテストするための正規表現可能な文字列を指定することができます。

  • env-valueには、

    先のattribute regex のテスト結果が真(true)の場合、env-value で指定した環境変数に値が設定されます。
    特に何か特別な値などを設定したい場合は、

    SetEnvIf User-Agent "[Bb]aidu" deny_ref=1

    のように=を使って代入することもできます。

ご利用のブラウザは、広告ブロック(AdBlockなど) が適用となっていませんか?
このサイトでは、コンテンツの一部が非表示、あるいは、コメント、お問い合わせの投稿ができない検索ができないことがあります。


関連記事 :

Nginx でdeny(アクセス拒否 : 403 )するには

前回、「Nginx でリダイレクト ( rewrite ) するには」でnginx におけるリダイレクトについて簡単に解説しました。 今回 ...

.htaccessで外部からの画像ファイルアクセスを拒否する

今回は、「.htaccessで特定のホストからのアクセスを拒否する(2)」の続きです。 ここでの話は、FreeBSDもCentOSも関係な ...

.htaccessで特定のホストからのアクセスを拒否する

今回は、apacheのアクセス規制です。 ここでの話は、FreeBSDもCentOSも関係なく、apacheの設定です。 一般的に、リダ ...

Nginxのproxyでキャッシュを削除する方法

前回「Nginx をリバースプロキシ(キャッシュ) として使ってみた」では、 nginxをリバースプロキシサーバーとして使ってみま ...

サーバーの負荷を下げるために.htaccessで画像ファイルを別サーバーへリダイレクトしてみる

以前の記事「.htaccessで外部からの画像ファイルアクセスを拒否する」では、画像ファイルの直リンクを拒否するやり方を簡単に解説してみました。 ...



コメントを投稿 :

お名前 *

メールアドレス *
( メールアドレスが公開されることはありません。)

サイトアドレス

コメント *

* 印の項目は、入力が必要な項目です。




最近投稿の記事

[ 画像提供元 : Amazon ] 先日、1TBのディスクの入れ替え時にバックアップをとろうとディスクコピーを行いました。 その際 ...

Windows で Linux ファイルシステム Ext4 のディスクをマウントするには? Ext3Fsd が、おそらく、最も簡単なツール ...

今回は、Windows で Compass を使ってみました。 Compass とは、 Sass(サス、Syntactica ...

今回は、Anti Adblock を使ってみました。 Anti Adblock とは、 そもそも Adblock という ウェブ ...

デスクトップ環境でない サーバーで、Webページのキャプチャー画像をコマンドで撮る には、wkhtmltoimage, CutyCapt ...


さくらのVPS 全プラン リニューアルです。(石狩(北海道)も選択可)


root権限ありで ¥685 / 月 ~ と非常にリーズナブルな CPU 1(core)の 512 プランから、 最高 CPU 10(core), メモリ 32(GB), SSD容量 800(GB) までとプランが充実。
ディスクは、SSDとHDDの選択が可能になった他、データセンターは人気の東京、石狩(北海道)となりました。

また、どのプランでも好きなOSが選べます
( CentOS, Fedora, Scientific Linux, FreeBSD, Ubutu, Debian )

管理人もおすすめのVPSです。
試用期間がありますから、一度、お試しを!!

詳しくは、http://vps.sakura.ad.jp/さくらのVPSのサイトへ へどうぞ!!

カテゴリ


Serverman@VPS 完全1ヶ月無料 キャンペーン実施中です。


Serverman@VPS 完全1ヶ月無料 キャンペーン実施中です。
最近、スワップにも対応した Serverman@VPS は、かなりリーズナブルかもです。

  • メモリ1GB~2GBのEntryプラン :月額:490円
  • メモリ2MB~4GBのStandardプラン :月額:980円
  • メモリ4GB~8GBのProプラン :月額:1,980円

新規申し込みで1ヶ月間完全無料となるキャンペーンを実施中です。
Serverman@VPSの特徴は、安さとIPv6対応です。また、初期設定費0円もポイントです。

IPv6でちょっと遊んでみたい方には、おすすめかもしれませんね。最低利用期間もありませんから、気に入らないときは即解約もできます。

Serverman@VPSの詳細については、 http://dream.jp/vps/ Serverman@VPSのサイトへへどうぞ。



KVM採用 ConoHa VPSは、時間単位で借りれる便利なVPSです。


ConoHa VPS は、初期設定費0円最低利用期間無し時間単位で清算可能、 さらに、Web APIを使って自動化を図ることもできる便利なVPSです。

海外サーバー設置も可能で、ローカル接続にも対応と、かなり、機能豊富なサーバーです。

新規ユーザ登録で、クーポンもらえますから、まずは、お試しですね。

ConoHa VPSの詳細については、
http://www.conoha.jp/ へどうぞ。

KVM採用 お名前.com VPS(KVM) 2G プラン 初期設定費無料 キャンペーン 実施です。


メモリ2GBプラン CPU:3core、Disk:200GB
月額:1,153円から (初期設定:1,680円0円)

さくらのVPSがリニューアルされてもなんのその。
1GBメモリ / 2Core を ¥834 – の格安価格で提供中です!
間違いなくスペックからすると割安感ありです。
年間割引時の途中解約で返金がないのは、 ちょっと残念ですが、それでもこの割安感は魅力です。

まずは、お試しですね。

お名前.com VPS(KVM)の詳細については、
http://www.onamae-server.com/vps/ へどうぞ。(お試し期間が15日あります。)



  • ソーシャルブックマーク

  • はてなブックマークへ追加するはてな登録数
ページトップへ
Time : 0.1967 [s]