htaccessについて。

htaccessでアクセス制限をかけたいのですが、ディレクトリ単位ではなく、以下のような場合にもかけることができますか?

http://xxx.xxx.xxx/aaa.php?id=1
にはアクセス制限をかけたいが、
http://xxx.xxx.xxx/aaa.php?id=2や、
http://xxx.xxx.xxx/aaa.php?id=11にはかけたない
ということはできるのでしょうか?

回答の条件
  • URL必須
  • 1人2回まで
  • 登録:2006/12/25 15:56:43
  • 終了:2006/12/26 17:59:18

回答(3件)

id:b-wind No.1

b-wind回答回数3344ベストアンサー獲得回数4402006/12/25 16:05:25

ポイント27pt

一般的には出来ないと考えます。

http://httpd.apache.org/docs/2.0/ja/sections.html

php ファイル側でやるほうが自然ですね。


ただ、mod_rewrite を使えば出来なくもないです。

RewriteEngine On
RewriteCond %{QUERY_STRING} id=1
RewriteRule .* - [FL]

この設定は説明のために簡素化してあるのでそのままは使用しないほうが良いと思います。

http://www.net-newbie.com/trans/mod_rewrite.html

id:dingding

ありがとうございます。

2006/12/26 11:02:19
id:x31 No.2

x31回答回数106ベストアンサー獲得回数12006/12/25 16:31:39

id:dingding

ありがとうございます。

リンク先を見たのですが、ファイル単位まではわかるのですが、クエリ文字までの指定でもいけるのでしょうか?

2006/12/26 11:04:48
id:esecua No.3

esecua回答回数510ベストアンサー獲得回数102006/12/26 17:10:25

ポイント26pt

やはりPHPでの処理が一番かと思います。

PHPでは基本認証を実装することができるので(http://www.komonet.ne.jp/~php/program/ninsho/chap2.htm)あとは引数からアクセスさせるかさせないかを処理すればよいかと。

スクリプトの上側に以下を加えます。

if ($_GET['id'] === "1")
{

//BASIC認証を開始
//もしBASIC認証が失敗した場合die()などを使用し表示させない。

} else {

//idが1以外の場合

}

間違っていたらごめんなさい。

id:dingding

やはりプログラムに手を入れる必要があるんですね。

ありがとうございました。

2006/12/26 17:59:00

コメントはまだありません

この質問への反応(ブックマークコメント)

「あの人に答えてほしい」「この質問はあの人が答えられそう」というときに、回答リクエストを送ってみてましょう。

これ以上回答リクエストを送信することはできません。制限について

絞り込み :
はてなココの「ともだち」を表示します。
回答リクエストを送信したユーザーはいません