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

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

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

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

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

Authentication

Authentication(認証)は正当性を認証する為の工程です。ログイン処理等で使われます。

Q&A

解決済

1回答

1711閲覧

cakephp4 にて認証時、認証しているユーザーを複数にする方法を教えてください。

applepai

総合スコア3

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

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

Authentication

Authentication(認証)は正当性を認証する為の工程です。ログイン処理等で使われます。

0グッド

0クリップ

投稿2020/08/12 07:52

cakephp4 にて認証時、認証しているユーザーを複数にする方法を教えてください。

cakephp4にて、認証した時、複数のユーザを認証できるようにしたいです。

複数のユーザーでログインした際、認証が最初にログインしたユーザー1人しか認識されないです。
認証するユーザを複数にし、ログアウトする際もユーザー事に個別でログアウトしたいです。

何か参考になるもの、アドバイス等を教えてもらえますか。

コントローラ側にて

UsersController

1public function login() 2 { 3 $this->Authorization->skipAuthorization(); 4 5 $this->request->allowMethod(['get', 'post']); 6 $result = $this->Authentication->getResult(); 7 // regardless of POST or GET, redirect if user is logged in 8 if ($result->isValid()) { 9 // redirect to /articles after login success 10 $redirect = $this->request->getQuery('redirect', [ 11 'controller' => 'Articles', 12 'action' => 'index', 13 ]); 14 15 return $this->redirect($redirect); 16 } 17 // display error if user submitted and authentication failed 18 if ($this->request->is('post') && !$result->isValid()) { 19 $this->Flash->error(__('Invalid username or password')); 20 } 21 } 22 23 public function logout() 24 { 25 $this->Authorization->skipAuthorization(); 26 27 $result = $this->Authentication->getResult(); 28 // regardless of POST or GET, redirect if user is logged in 29 if ($result->isValid()) { 30 $this->Authentication->logout(); 31 return $this->redirect(['controller' => 'Users', 'action' => 'login']); 32 } 33 return $this->redirect(['controller' => 'Users', 'action' => 'login']); 34 }

Application.php にて

Application

1 2public function getAuthenticationService(ServerRequestInterface $request): AuthenticationServiceInterface 3 { 4 $authenticationService = new AuthenticationService([ 5 'unauthenticatedRedirect' => '/users/login', 6 'queryParam' => 'redirect', 7 ]); 8 9 $service = new AuthenticationService(); 10 11 // Define where users should be redirected to when they are not authenticated 12 $service->setConfig([ 13 'unauthenticatedRedirect' => '/users/login', 14 'queryParam' => 'redirect', 15 ]); 16 17 18 // identifiers を読み込み、email と password のフィールドを確認します 19 //テスト 20 $fields = [ 21 IdentifierInterface::CREDENTIAL_USERNAME => 'email', 22 IdentifierInterface::CREDENTIAL_PASSWORD => 'password' 23 ]; 24 25 $service->loadAuthenticator('Authentication.Session'); 26 $service->loadAuthenticator('Authentication.Form', [ 27 'fields' => $fields, 28 'loginUrl' => '/users/login' 29 ]); 30 31 $service->loadIdentifier('Authentication.Password', compact('fields')); 32 33 return $service; 34}

試したこと

$result = $this->Authentication->getResult();
$user = $result->getData();
で認証が最初の1人しかされていないことを確認。

ログイン認証等は下記のCookbook cmsチュートリアルの通り作成しています。
https://book.cakephp.org/4/en/tutorials-and-examples.html

補足情報(FW/ツールのバージョンなど)

cakephp4.1.2
php7.2.32
認証は authentication
承認は authorization を使用しています。
(cakephp4から AuthComponent が非推奨となった為、
AuthComponentを使用しないようにしています。)

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2020/08/12 08:22 編集

もう少し具体的に事例を説明していただきたいです。 例えば、AさんがログインしているときにBさんがログインしたらどうなるとか。 テストのやり方も気になります。同じwebブラウザでタブを開いて複数ユーザーをテストしているのであれば、悪いことは言わないので、複数のwebブラウザ(Edge, Firefox, Chromeなどを同時起動して別々のユーザーでアクセスする)を使うようにしてテストしてみてください。
applepai

2020/08/12 08:48

大変失礼致しました。情報の不備等指摘ありがとうございます。 同一プラウザでタブを複数ユーザーをテストしていました。 同一プラウザChrome にて 先にAさんがログインし、後にBさんがログインしたら Chrome ではA さんの認証のみ認識しています。 同一プラウザEdge にて 先にBさんがログインし、後にCさんがログインしたら Edge では B さんの認証のみ認識しています。 それぞれ別プラウザにて先に chrome で Aさん  後に Edge で Bさん がログインしたら、 それぞれ chrome では Aさんを認識し、 Edge では Bさんを認識しています。
guest

回答1

0

自己解決

cakephp4側の問題ではなくテスト時の問題でした。

何となくでしか分からなかったですが、
今回cakephp にて php セッション認証使ったログイン認証を使用しています。
プラウザにてセッションID はクッキーに保持していた為、同一プラウザでタブを開いた場合、
認証が1つしか認識でない状態となっていた。

違うプラウザにて認証したら、そのプラウザ事にセッションIDがクッキーに保持される?

今回は、テスト時異なるプラウザを混ぜてテストしなかった事と、
php、phpセッションの理解が足りないことが分かりました。

また、質問への回答が来るまでこのことに気付けませんでした。
回答してくださった方本当にありがとうございます。

投稿2020/08/12 09:26

applepai

総合スコア3

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問