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

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

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

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

ルーティング

ルーティングとは、TCP/IPネットワークにおいて、目的のホストまでパケットを送る為のパス選定のプロセスを言います。

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

Q&A

解決済

1回答

1228閲覧

Cakephp3 Controller、Template内でフォルダを階層に分けて、ログインをしたい

hagiwarasannnnn

総合スコア13

CakePHP

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

ルーティング

ルーティングとは、TCP/IPネットワークにおいて、目的のホストまでパケットを送る為のパス選定のプロセスを言います。

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

0グッド

0クリップ

投稿2020/10/21 21:46

編集2020/10/21 22:58

前提・実現したいこと

Controller、Templateをフォルダ分けして、ルーティングを変更しました。
その際、階層に分けたルーティングは正常に動いていると思うのですが、AppControllerに書いたログイン認証が機能していませんでした。

階層

Controller/
├AppControler
├LoginController
Admin/
├AppControler ←これが機能していない
├LoginManegerController
├TopManagerController

Template/
├Login
Admin/
├LoginManeger
├TopManagerController

※拡張子は省略しております。

発生している問題・エラーメッセージ

http://localhost/myapp/admin/loginManager
にアクセスは出来るのですが、
LoginManagerController内のloginメソッドに処理がとびません。
リロードがされるだけです。

また、
http://localhost/myapp/admin/TopManager
にアクセスを行うと、
http://localhost/myapp/admin/login/login?redirect=%2Fadmin%2FTopManager
にリダイレクトされ、
Error: LoginController could not be found. と表示されます。

該当のソースコード

routes.php に以下を追加

Router::prefix('admin', function (RouteBuilder $routes) { $routes->connect('/', ['controller' => 'Pages', 'action' => 'index']); $routes->fallbacks(DashedRoute::class); });

Admin/AppControler

<?php /** * CakePHP(tm) : Rapid Development Framework (https://cakephp.org) * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org) * * Licensed under The MIT License * For full copyright and license information, please see the LICENSE.txt * Redistributions of files must retain the above copyright notice. * * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org) * @link https://cakephp.org CakePHP(tm) Project * @since 0.2.9 * @license https://opensource.org/licenses/mit-license.php MIT License */ namespace App\Controller\Admin; use Cake\Controller\Controller; use Cake\Event\Event; /** * Application Controller * * Add your application-wide methods in the class below, your controllers * will inherit them. * * @link https://book.cakephp.org/3.0/en/controllers.html#the-app-controller */ class AppController extends Controller { /** * Initialization hook method. * * Use this method to add common initialization code like loading components. * * e.g. `$this->loadComponent('Security');` * * @return void */ public function initialize() { parent::initialize(); $this->loadComponent('RequestHandler', [ 'enableBeforeRedirect' => false, ]); $this->loadComponent('Flash'); $this->loadComponent('Auth', [ 'loginAction' => [ 'controller' => 'LoginManager', 'action' => 'login' ], 'loginRedirect' => [ 'controller' => 'TopManager', 'action' => 'index' ], 'logoutRedirect' => [ 'controller' => 'LoginManager', 'action' => 'logout' ], 'authenticate' => [ 'Form' => [ 'userModel' => 'Admin', 'fields' => [ 'username' => 'login_id', 'password' => 'password' ],'finder' => 'auth' ] ] ]); /* * Enable the following component for recommended CakePHP security settings. * see https://book.cakephp.org/3.0/en/controllers/components/security.html */ //$this->loadComponent('Security'); } // 共通処理 public function beforeFilter(Event $event) { } }

LoginManegerController

<?php namespace App\Controller\Admin; use Cake\ORM\TableRegistry; use Cake\Auth\DefaultPasswordHasher; use \Exception; use Cake\Event\Event; use Cake\Utility\Security; class LoginManagerController extends AppController { // 認証を通さないアクションを設定 public function beforeFilter(Event $event) { parent::initialize(); $this->Auth->allow(['index','login','logout']); } public function index() { } public function login(){ if ($this->request->is('post')) { $user = $this->Auth->identify(); if ($user) { $this->Auth->setUser($user); return $this->redirect($this->Auth->redirectUrl()); } } } public function logout() { } } ?>

LoginManager

<!DOCTYPE html> <html lang="ja"> <head> <?= $this->Html->charset() ?> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>管理者ログイン画面</title> <?= $this->Html->meta('icon') ?> <?= $this->Html->css('base.css') ?> <?= $this->Html->css('style.css') ?> <?= $this->Html->css('header.css') ?> <?= $this->fetch('meta') ?> <?= $this->fetch('css') ?> <?= $this->fetch('script') ?> </head> <body> <h1>管理者ログイン画面</h1> <?php echo $this->Form->create(); echo $this->Form->control('login_id',['type'=>'text','label'=>__('Login ID'),'id' => 'login_id', "maxlength"=>"255"]); echo $this->Form->control('password',['type'=>'password','label'=>__('Password'),'id' => 'password', "maxlength"=>"255"]); echo $this->Form->button('Login'); echo $this->Form->end(); ?> </body> </html>

Admin/配下の
AppControllerのログイン認証を正常に動かすには、
どのように修正すればよろしいでしょうか?

大変恐縮ですが、分かる方どなたか
アドバイスのほどよろしくお願いいたします。

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

cakephp3.7
php 7.2

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

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

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

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

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

guest

回答1

0

ベストアンサー

prefixルーティング内で認証を個別に設定するなら、ルーティングパラメーターに prefix を付けるようにします。

loginAction, loginRedirect, logoutRedirect などの指定はすべて、prefixパラメーターを付けて指定します。

php

1 'loginAction' => [ 2 'prefix' => 'admin', 3 'controller' => 'LoginManager', 4 'action' => 'login' 5 ],

また、一般ユーザーと管理者のように、認証に使用するモデル(userModel)が異なる場合は、セッションキーを変更しておくとよいでしょう。

php

1 'storage' => [ 2 'className' => 'Session', 3 'key' => 'Auth.Admin', // デフォルトは Auth.User 4 ],

AuthComponent 設定オプション - CakePHP 3.9

投稿2020/10/22 23:25

nojimage

総合スコア959

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問