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

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

ただいまの
回答率

88.80%

CakePHP3で管理者とユーザーそれぞれでログイン

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 2,525

anotenka

score 7

 前提・実現したいこと

cakePHP3.6で管理システムを作っています。
管理者用のログイン画面とパートナー用のログイン画面の2つの認証が必要です。
3.xではAppController.phpで一括でAuthの設定をしなければならないとのことで
ifでadminだったらEmpoyeesモデル、それ以外Usersモデルで認証するよう設定してみたつもりですが
Usersの方はテストユーザーでログインができ、
Employeesの方はログインすることができませんでした。

Controllerが間違っているのか、routesのやり方が間違っているのかわかりません。

2つのテーブルを使った認証を実装するための手順や設定などがあれば教えていただきたいです。
宜しくお願い致します。

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

 該当のソースコード

AppController

<?php

namespace App\Controller;

use Cake\Controller\Controller;
use Cake\Event\Event;


class AppController extends Controller
{

     public function initialize()
     {
     parent::initialize();
     if ($this->request->prefix == 'admin') {
         $this->loadComponent('Flash');
         $this->loadComponent('Auth', [
           'loginRedirect' => [
               'controller' => 'Employees',
               'action' => 'main'
           ],
           'logoutRedirect' => [
               'controller' => 'Employees',
               'action' => 'login'
           ],
           'authenticate' => [
               'Form' => [
                 'fields' => [
                   'username' => 'employee_no',
                   'password' => 'password'
                 ]
               ]
           ],
           'authError' => 'ログインできませんでした。ログインしてください。'
         ]);
         $this->Auth->sessionKey = 'Admin';
     } else {
         $this->loadComponent('Flash');
         $this->loadComponent('Auth', [
           'loginRedirect' => [
               'controller' => 'Users',
               'action' => 'main'
           ],
           'logoutRedirect' => [
               'controller' => 'Users',
               'action' => 'login'
           ],
           'authenticate' => [
               'Form' => [
                 'fields' => [
                   'username' => 'user',
                   'password' => 'password'
                 ]
               ]
           ],
           'authError' => 'ログインできませんでした。ログインしてください。'
         ]);
}
}
}


/Controller/Admin/
EmployeesController.php

<?php
namespace App\Controller\Admin;

use App\Controller\AppController;
use Cake\Event\Event;
use Cake\Controller\Component\AuthComponent;


class EmployeesController extends AppController
{

  public function isAuthorized($employee)
   {
       if (isset($employee['role']) && $employee['role'] === 'admin') {
           return true;
       }
       return false;
   }

    public function beforeFilter(Event $event)
    {
        parent::beforeFilter($event);
        $this->Auth->allow(['add','logout','login']);

        $this->Auth->config('authenticate', [
        AuthComponent::ALL => ['userModel' => 'Employees'],
        'Basic',
        'Form'
        ]);
    }

public $paginate = [
    'limit' => 50,
    'order' => [
        'Employees.id' => 'asc'
    ]
];

public function main()
{
    $employees = $this->paginate($this->Employees);
    $this->set(compact('employees'));
    $this->set('_serialize',['employees']);

}

    public function index()
    {
        $employees = $this->paginate($this->Employees);

        $this->set(compact('employees'));
    }

//中略

public function login()
{
    if($this->request->is('post')){
       $employee = $this->Auth->identify();
       if ($employee){
          $this->Auth->setUser($employee);
          return $this->redirect($this->Auth->redirectUrl());
       }
       $this->Flash->error(__('ユーザーIDかパスワードが間違っています。'));
    }
}

public function logout()
{
    $this->request->session()->destroy();
    return $this->redirect($this->Auth->logout());
}

}


/Controller/
UsersController.php

<?php
namespace App\Controller;

use App\Controller\AppController;
use Cake\Event\Event;


class UsersController extends AppController
{
  public function initialize()
  {
    parent::initialize();

    $this->loadComponent('Auth', [
                'authorize' => ['Controller'],

            ]);
          }

  public function beforeFilter(Event $event)
{
          parent::beforeFilter($event);
          $this->Auth->allow(['add','logout','login']);//ログイン前でも参照できるページ

      }

  public $paginate = [
      'limit' => 50,
      'order' => [
          'Users.id' => 'asc'
      ]
  ];

   public function main()
   {
       $users = $this->paginate($this->Users);
       $this->set(compact('users'));
       $this->set('_serialize',['users']);

   }
   public function index()
   {
                    $users = $this->paginate($this->Users);
                     if ($this->request->is('post')) {
                         $requestData = $this->request->data();
                         $conditions = [];
                         if (!empty($requestData['find_user'])) {
                             $conditions['user like'] = '%'.$requestData['find_user'].'%';
                         }
                         if (!empty($requestData['authority_code'])) {
                             $conditions['authority_code like'] = '%'.$requestData['authority_code'].'%';
                         }
                         $users = $this->Users->find()
                            ->where($conditions);
                     }
                     $this->set('msg', null);
                     $this->set('users', $users);
                     $users = $this->paginate($this->Users);
    }

public function login()
{
    if($this->request->is('post')){
       $user = $this->Auth->identify();
       if ($user){
          $this->Auth->setUser($user);
          return $this->redirect($this->Auth->redirectUrl());
       }
       $this->Flash->error(__('ユーザーIDかパスワードが間違っています。'));
    }
}

    public function logout()
    {
        $this->request->session()->destroy();
        return $this->redirect($this->Auth->logout());
    }

    public function isAuthorized($employee = null)
   {
     // todo..
        return true;
   }
}


routes.php

<?php


use Cake\Core\Plugin;
use Cake\Routing\RouteBuilder;
use Cake\Routing\Router;
use Cake\Routing\Route\DashedRoute;



Router::defaultRouteClass(DashedRoute::class);

Router::scope('/', function (RouteBuilder $routes) {


    $routes->connect('/users/', ['controller' => 'Users', 'action' => 'login']);
    $routes->connect('/partners/', ['controller' => 'partners', 'action' => 'login']);
    $routes->connect('/employees/', ['controller' => 'employees', 'action' => 'login']);


    $routes->connect('/pages/*', ['controller' => 'Pages', 'action' => 'display','index']);
    $routes->connect('/admin/employees', ['controller' => 'Employees', 'action' => 'login', 'prefix' => 'admin']);


    $routes->fallbacks(DashedRoute::class);
});
Router::prefix('admin', function ($routes) {
  $routes->fallbacks('DashedRoute');
});
plugin::routes();


/template/Admin/Employees/
login.ctp

<div class="login_form">
    <?= $this->Form->create() ?>
    <fieldset>
        <legend><?= __('管理システム') ?></legend>
        <?= $this->Form->control('employee_no', ['label' => '社員番号']) ?>
        <?= $this->Form->control('password', ['label' => 'パスワード']) ?>
    <div class="log_b"><?= $this->Form->button(__('ログイン','true')) ?>
    <a class="button" href="/admin/employees/login" target="login">終了</a></div>
    <?= $this->Form->end() ?>
    </fieldset>
</div>
<br>
<?= $this->Flash->render() ?>


/template/Users/
login.ctp

<div class="login_form">
    <?= $this->Form->create(false, array('div' => 'false', 'label' => 'false')) ?>
    <fieldset>
        <legend><?= __('管理システム') ?></legend>
        <?= $this->Form->control('user', ['label' => '社員番号']) ?>
        <?= $this->Form->control('password', ['label' => 'パスワード']) ?>
    <div class="log_b"><?= $this->Form->button(__('ログイン','true')) ?>
    <a class="button" href="/users/login" target="login">終了</a></div>
    <?= $this->Form->end() ?>
    </fieldset>
</div>
<br>
<?= $this->Flash->render() ?>

 試したこと

route.phpでadminの設定
AppControllerにAuth認証の設定

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

cakePHP3.6
PHP 7.2.7

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

同じようなprefixで認証を分ける実装をしたことがあります。$this->Auth->sessionKey = 'Admin';でセッションを分けており、ルーティングもよさそうだと思いました。

1点、Authコンポーネントの設定でEmpoyeesモデルの指定がないのが気になりました

           'authenticate' => [
               'Form' => [
                 'userModel' => 'Empoyees' // これを追加
                 'fields' => [
                   'username' => 'employee_no',
                   'password' => 'password'
                 ]
               ]
           ],

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/08/24 19:02

    アドバイス頂いたとおりに直し、細かいミスなども修正したら
    無事にログインまで実装できました!
    教えて下さり本当にありがとうございました。

    キャンセル

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

  • ただいまの回答率 88.80%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る