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

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

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

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

Q&A

解決済

1回答

765閲覧

cakephp Authでユーザーのログイン認証を設定

退会済みユーザー

退会済みユーザー

総合スコア0

CakePHP

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

0グッド

0クリップ

投稿2019/07/22 11:03

編集2019/07/23 00:48

Organizationsテーブルのlogin_idとpasswordでログイン。

Organizationsテーブル

html

1<!-- ! メイン ============================== --> 2<main class="bg_yellow"> 3 <section id="login" class="page_login"> 4 <div class="container"> 5 <div class="area_cnt"> 6 <?= $this->Form->create() ?> 7 <ul class="list_login"> 8 <li> 9 <div class="head"> 10 <p class="ttl">ID</p> 11 </div> 12 <div class="cnt"> 13 <div class="wrap_input"> 14 <?= $this->Form->control('login_id', ['type' => 'text', 'label' => false, 'placeholder' => 'ログインID']); ?> 15 </div> 16 </div> 17 </li> 18 <li> 19 <div class="head"> 20 <p class="ttl">PASSWORD</p> 21 </div> 22 <div class="cnt"> 23 <div class="wrap_input"> 24 <?= $this->Form->control('password', ['label' => false, 'placeholder' => 'パスワード']) ?> 25 </div> 26 </div> 27 </li> 28 </ul> 29 <div class="btnarea_center"> 30 <?= $this->Form->button(__('LOGIN'), ['escape' => false, 'class' => 'btn_line_large']) ?> 31 </div> 32 <?= $this->Form->end() ?> 33 </div> 34 </div> 35 </section> 36</main>

php

1<?php 2namespace App\Controller; 3 4use Cake\Controller\Controller; 5use Cake\Event\Event; 6 7class AppController extends Controller 8{ 9 public function initialize() 10 { 11 parent::initialize(); 12 13 $this->loadModel('Organizations'); 14 15 $this->loadComponent('Common'); 16 17 $this->loadComponent('RequestHandler', [ 18 'enableBeforeRedirect' => false, 19 ]); 20 21 $this->loadComponent('Flash'); 22 23 //ログイン状態設定 24 $this->loadComponent('Auth', [ 25 'authenticate' => [ 26 'Form' => [ 27 'userModel' => 'Organizations', 28 'fields' => [ 29 'username' => 'login_id', 30 'password' => 'password' 31 ] 32 ] 33 ], 34 'loginAction' => [ 35 'controller' => 'Pages', 36 'action' => 'login' 37 ], 38 'loginRedirect' => [ 39 'controller' => 'Pages', 40 'action' => 'index' 41 ], 42 'unauthorizedRedirect' => $this->referer(), // 未認証時、元のページを返します。 43 'authError' => 'ログインが必要です。' 44 ]); 45 46 // ログインユーザーを変数に入れておく 47 $loginOrganization = $this->Auth->user(); 48 if($loginOrganization){ 49 $loginOrganization = $this->Organizations->get($loginOrganization['id']); 50 } 51 } 52}

php

1<?php 2namespace App\Controller; 3 4use Cake\Core\Configure; 5use Cake\Http\Exception\ForbiddenException; 6use Cake\Http\Exception\NotFoundException; 7use Cake\View\Exception\MissingTemplateException; 8 9class PagesController extends AppController 10{ 11 public function initialize() 12 { 13 parent::initialize(); 14 $this->Auth->allow(['index', 'login']); 15 $this->loadModels('Organizations'); 16 } 17 18 public function index() 19 { 20 21 } 22 23 // ログイン 24 public function login() 25 { 26 $this->set('title', 'ログイン'); 27 if ($this->request->is('post')) { 28 $data = $this->request->getData(); 29 $organization = $this->Auth->identify(); 30debug($organization); 31exit; 32 if ($organization) { 33 $this->Auth->setUser($organization); 34// $this->Flash->success(__('ログインしました')); 35 return $this->redirect(['controller' => 'Pages', 'action' => 'index']); 36 // クッキーの継続時間を2週間に設定 37 setcookie(LOGIN_PASSPORT_NAME, $passport, LOGIN_DURATION, '/'); 38 return $this->redirect($this->Auth->redirectUrl()); 39 } 40// $this->Flash->error(__('ログインIDもしくはパスワードが間違っています')); 41 return $this->redirect([]); 42 } 43 } 44} 45

falseが返ってきてしまいます...

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

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

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

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

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

yukikp

2019/07/22 11:06

各処理ステップで値をvar_dump()(必要ならdie();も追加)して、各ステップで値がどうなってるか、想定通りのパスを進んでいるか、確認してみるといいですよ。
m.ts10806

2019/07/23 00:45

コードブロック冒頭はファイル名ではなく言語名を入れてください ```php
guest

回答1

0

ベストアンサー

パスワードはハッシュ化してください。
通常、フレームワークでは平文パスワードは使えないと思います。

CREATE TABLE users (

id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY, username VARCHAR(50), **password VARCHAR(255),** role VARCHAR(20), created DATETIME DEFAULT NULL, modified DATETIME DEFAULT NULL

);

それでは、新しいユーザーを登録できるようにする必要があります。ユーザーネームとパスワードを保存し、 そしてさらに重要なこととして、パスワードがデータベースないに平文で保存されないようにパスワードを ハッシュ化しましょう

投稿2019/07/23 00:49

m.ts10806

総合スコア80850

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

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

退会済みユーザー

退会済みユーザー

2019/07/23 00:53

回答ありがとうございます。直接、user情報をデータベースに書き込む時にパスワードのハッシュ化は可能ですか?
m.ts10806

2019/07/23 00:54

可能か不可能で言えば可能です。 ですが、フレームワークを通して認証しているのであれば、フレームワークの仕組みを通してハッシュ化→データ保存するのが確実です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問