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

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

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

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

CakePHP

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

ログイン

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

Q&A

解決済

2回答

13999閲覧

cakePHP validationエラーメッセージが表示されない

satomi

総合スコア6

PHP

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

CakePHP

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

ログイン

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

0グッド

0クリップ

投稿2017/02/21 01:28

編集2017/02/21 01:36

###前提・実現したいこと
cakePHPでecサイトを作っています。
今はパスワード再設定画面を手掛けていて
パスワードを入力したときにvalidationをかけたいのですが、メッセージが表示されません。

###発生している問題・エラーメッセージ
パスワード再設定画面でvalidationをかけているのですが、
引っかかったときのエラーメッセージが出ません。
(メッセージが出ないだけで、validationにはちゃんと引っかかります)
参考書や色々なサイトを見る限り、view画面の方で

<?PHP $this->Form->error('モデル名.プロパティ名'); ?>

と記述すればできるとのことなので同じようにしてみたのですが表示されません、、。

以下ソースコードです。長くて申し訳ありませんが、よろしくお願い致します。

###該当のソースコード
【Model】
User.php…validation設定を行っているモデル

//パスワードが一致しているかをチェックするバリデータ public function confirm($check){ foreach ($check as $key => $value) { //カラムに値がなかったら(issetしてなかったら)falseを返す if(! isset($this->data[$this->name][$key.'_confirm'])){ return false; } //$valueの値と、そのカラムに_confirmを足した値が等しくなかったら //falseを返す(確認入力をさせる場合に使うチェック) if($value !== $this->data[$this->name][$key.'_confirm']){ return false; } } //入力が正しいことを確認したらtrueを返す return true; } public validate = [ 'password' => [ [ 'rule' => 'notBlank', 'message' => 'パスワードを入力してください。' ], [ 'rule' => ['custom','/^[(a-z)(A-Z)(0-9)]+$/'], 'message' => '半角英数字で入力してください。' ], [ 'rule' => 'confirm', 'message' => 'パスワードが一致していません。' ], [ 'rule' => ['between', 6, 32], 'message' => '6文字以上、32文字以下で入力して下さい。' ] ] ];

【Model】
ResetPassword.php…パスワード再設定の処理を行っているモデル

public function reissuePassword($activation_code,$password,$password_again) { if(is_null($activation_code) || is_null($password) || is_null($password_again)) { //引数が不正 assert(false); return -10; } App::import('Model', 'TransactionManager'); $transaction_manager = new TransactionManager(); //start transaction $transaction = $transaction_manager->begin(); $commit = false; try { $options = [ 'fields' => [ 'ResetPassword.user_id' ], 'conditions' => [ 'ResetPassword.activate_code' => $activation_code, ] ]; $rec = $this->find('first',$options); App::import('Model','User'); $user = new User(); $user->validate = [ 'password' => $user->validate['password'], ]; $user->set([ 'User' => [ 'user_id' => $rec['ResetPassword']['user_id'], 'password' => $password, 'password_confirm' => $password_again ] ]); if(! $user->validates()) { //バリデーションで引っかかった場合 return; } if(!$user->save()) { //トランザクション失敗 $commit = false; return -2; } $commit = true; return 1; return $result; } finally { if($commit) { if(! $transaction_manager->commit($transaction)) { //コミットが失敗したとき } else { $transaction_manager->rollback($transaction); } } } }

【Controller】
AuthController.php…ログイン、パスワード再発行などのサインイン全体を管理しているコントローラー。
ResetPasswordモデルのreissuePassword()を呼び出して結果を受け取っている。

public function reissue_password() { if(is_null(Hash::get($this->request->data,'password')) || is_null(Hash::get($this->request->data,'password_again'))) { $this->set('code',Hash::get($this->request->query,'code')); $this->render('reissue_password'); return; } $password = Hash::get($this->request->data,'password'); $password_again = Hash::get($this->request->data,'password_again'); $activation_code = Hash::get($this->request->data,'code'); $this->loadModel('ResetPassword'); $result = $this->ResetPassword->reissuePassword($activation_code,$password,$password_again); switch($result) { case 1: //パスワード再設定完了 $this->render('resetted_password'); break; case -10: //引数が不正なとき $this->redirectIllegalParameter(); break; case -2: //トランザクションエラー $this->redirectCriticalError(); break; } }

【View】
resetted_password.ctp…パスワード再設定画面

<?php $this->start('title'); ?>パスワード再設定<?php $this->end(); ?> パスワードを再設定します。 半角英数字で入力してください。 <?php echo $this->Form->create('User',['type' => 'post','url'=> ['controller' => 'auth','action' => 'reissue_password'],'novalidate' => true]); ?> <?php echo $this->Form->error('User.password'); ?> <?php echo $this->Form->password('password',['placeholder' => 'パスワードを入力','required' => false]); ?> <?php echo $this->Form->password('password_again',['placeholder' => 'パスワードを再入力','required' => false]); ?> <?php echo $this->Form->hidden('code',['value' => $code]); ?> <?php echo $this->Form->end('パスワードを再設定'); ?>

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

  • 言語:PHP5
  • フレームワーク:cakePHP 2.9
  • 実行環境: XAMP

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

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

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

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

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

domonr

2017/02/21 01:36

$this->[Model名]->validationErrors 等を使ってController内でエラーメッセージが出ているかどうかは確認できていますか?
turbgraphics200

2017/02/21 02:01

バリデーションで、foreachでループしてるけどループ必要なんだっけか?
guest

回答2

0

自己解決

ドコモン0501様、turbgraphics200様、icchi様、ご助言ありがとうございます。

①resetted_password.ctpにあるcreateヘルパーが

<?php echo $this->Form->create('User',['type' => 'post','url'=> ['controller' => 'auth','action' => 'reissue_password'],'novalidate' => true]); ?>

のようになっていて、モデル名とurlで指定しているコントローラー名が異なっていたためにパラメータがうまく送られていないようでしたので

<?php echo $this->Form->create(false,['type' => 'post','url'=> ['controller' => 'auth','action' => 'reissue_password'],'novalidate' => true]); ?>

へ変更しました。

②ResetPassword.php(パスワード再設定の処理を行っているモデル)でvalidationに引っかかった場合に

if(! $user->validates()) { //バリデーションで引っかかった場合 return; }

としているのですが、ただreturnしているだけで何の値も返していないため、メソッド呼び出しを行っているAuthControllerで処理結果が入らずにswitch文も通り抜けてしまうという初歩的なミスでした。

お手数おかけ致しました。(..)_

投稿2017/02/22 04:30

satomi

総合スコア6

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

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

0

推測ですが...
ResetPasswordモデルでnewした$userに対してvalidates()を実行しているので、バリデートの結果がView側に渡っていないのではないかと思います。

コントローラ側の$this->Userに対して値をsetして、validates()すれば、バリデート結果がView側に渡ると思います。もしくは、reissuePassword()側でnewした$userをreturnして、$this->Userに代入してもうまくいくかもしれません。

投稿2017/02/21 04:03

popobot

総合スコア6586

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問