質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

4929閲覧

CakePHP3で特定のコントローラのみBasic認証をかけたいです

ssk

総合スコア332

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2017/04/29 05:26

編集2017/04/29 05:31

php

1// /webroot/.htaccess 2 3<FilesMatch "^\hoges$"> 4AuthUserFile http://localhost/test/webroot/.htpasswd 5AuthName "Please enter your ID and password" 6AuthType Basic 7require valid-user 8</FilesMatch>

https://blogs.yahoo.co.jp/nhkpt100/59503613.html
↑こちらを参考に実装しました。情報が古いかもしれませんが、、

cakephp3で特定のコントローラーのみBasic認証を行いたいです。
本番環境はXサーバーです。

###追記

class SampleController extends AppController { public function beforeFilter() { parent::beforeFilter(); //Basic認証 $this->autoRender = false; $loginId = 'hoge'; $loginPassword = 'hogehoge'; if (!isset($_SERVER['PHP_AUTH_USER'])) { header('WWW-Authenticate: Basic realm="Please enter your ID and password"'); header('HTTP/1.0 401 Unauthorized'); die("id / password Required"); } else { if ($_SERVER['PHP_AUTH_USER'] != $loginId || $_SERVER['PHP_AUTH_PW'] != $loginPassword) { header('WWW-Authenticate: Basic realm="Please enter your ID and password"'); header('HTTP/1.0 401 Unauthorized'); die("Invalid id / password combination. Please try again"); } } $this->autoRender = true; }

http://www.p-nt.com/technicblog/archives/2
↑こちらの方法ではBasic認証自体は表示されるのですが、ユーザ名とパスワードを入れても、ページが表示されません。(開発環境ではうまくいきましたが、Xサーバーではダメでした。)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

XサーバーはFastCGIなので、PHP_AUTH_USERなどが使えません。
公式ページから引用。

FastCGIが有効となる環境では、通常のCGI動作とは使用できる環境変数が一部異なっています。
プログラム上でBasic認証などに使用する、下記の環境変数の取得が行えません。

PHP_AUTH_PW
PHP_AUTH_USER

.htaccessの記述ですが、二行目のAuthUserFileの記述が変です。サーバー内のパス情報です。

<FilesMatch "^hoges$"> AuthUserFile /path/to/.htpasswd AuthName "Please enter your ID and password" AuthType Basic require valid-user </FilesMatch> ```のように.htpasswdまでのパスを書きます。ウェブから参照できない場所に置くようにしてください。 また、正規表現も何故`h`をエスケープしているのか分かりませんので、バックスラッシュは要らないと思います。 これでうまく行くんですかね?ちょっとやってみてください。 追記 --- サーバー内のパスが分からないときは、`phpinfo.php`っていうファイルを作って、以下のようにして、ブラウザからアクセスしてみてください。その中に、いろいろ書いてあります。 ```php <?php phpinfo();

投稿2017/04/29 08:57

編集2017/04/29 10:42
shi_ue

総合スコア4437

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ssk

2017/04/29 10:09 編集

ありがとうございます。前進することができました。 http://localhost/hoge/briefing にアクセスすると500のエラーができようになりました。 /webroot/.htaccessの中身 <IfModule mod_rewrite.c> RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^ index.php [L] </IfModule> <FilesMatch "^briefing$"> AuthUserFile /webroot/.htpasswd AuthName "Please enter your ID and password" AuthType Basic require valid-user </FilesMatch> AuthUserFile /webroot/.htpasswd の書き方が間違っているのでしょうか、、
ssk

2017/04/29 10:18

require valid-user ↑こちらを削除したところ、エラーはなくなりました。 しかし、ベーシック認証が求められずページが表示されてしまいます。。
ssk

2017/04/29 10:25

度々申し訳ございません。 本番環境で試したところ、ベーシック認証は求めらるようになりました。 しかし、ユーザ名とパスワードを入力すると500のエラーが表示されてしまいます。
shi_ue

2017/04/29 10:38

実際のパスとかが分からないので、なんとも言えないですね。 Xサーバーはログとか見られないんですか?
ssk

2017/04/29 11:17

エラーログを辿って、実装することができました。 サーバーパネルから一度、全体にBasic認証にかけ ファイルを置いてある場所、パスなどを確認しました。 Xサーバーのエラーログを見ることは頭にありませんでした。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問