ログインに追加の条件を付与する「userScope」

ユーザ登録」の続きです。
ユーザ登録後、activate(statusを0に設定するを)せずに「仮登録」のままで、正しいusernameとpasswordでログインを試したところ認証に引っかかってくれました。

CakePHP 2.x版はこちらをどうぞ
ログインに追加の条件を付与する「scope」

この1行をbeforeFilter()に追加して下さい。
これで「ログインするには、この条件も必要とする => Userモデルのstatusが0である必要がある」となります。

// users_controller.php
function beforeFilter(){
    $this->Auth->userScope = array('User.status' => '0');
}

その条件専用のエラーメッセージを返したい

と思ったのですが、どうやらloginの処理とひとまとまりにされているようで、エラーメッセージは "$this->Auth->loginError"に集約されるようです。(違っていたら、ご指摘いただければと)

詳しくは、【cake\libs\controller\components\auth.php】のfunction identifyを参照

どうしてもそれ専用のものを出したかったら、別に確認する処理を追加すればいいのですが、そこまではいたらず。
(**この条件に引っかかるとパスワードがブランクに置き換えられるようです。)
userScope

  • このエントリーをはてなブックマークに追加

関連記事

no image

validateErrors と validationErrors

CakePHP試験中に気付いたことがあって、メモです。 $this->validateErrors自身バリデーション処理している 今まで、save時にバリデーションエラーメッセージををログに出力し

Cookieログイン

今回は、「keep me logged in」などログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcook

no image

Debugkitをインストール

CakePHPのデバッグツールとしてはデファクトスタンダードといってもいいDebugkitをインストールしました。 ダウンロード CakePHP 1.3用 https://github.com

no image

ビルトインされたバリデーションルール

CakePHP標準で多くのバリデーションルールが搭載されています。 ソース:/cake/libs/validation.php email / maxLength / minLength /

no image

recursive設定によるfind()性能改善

CakePHPでは、モデルにアソシエーションを設定している場合、recursive(=>joinする階層)はデフォルトで0に設定されています。「recursiveゼロ」の意味するところとは、「1跨ぎま

no image

独自のバリデーションルール

CakePHPで組み込みバリデーションをつくる方法は色々あります。 参考:Data Validation — CakePHP Cookbook v1.3 documentation 上記リンク内に

コントローラ内でバリデーション処理を呼び出す

通常、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。 バリデーシ

複数データベースの追加と切替

CakePHPで複数のデータベースに切替を行うということがあると思います。(個人的にはあまりない) 今回、CakePHPからWordpressのデータベースへの接続を行う機会があったので設定を試して

no image

Htmlヘルパー

ソース:\cake\libs\view\helpers\html.php charset / 文書の文字コードを設定する <?php echo $this->Html-

no image

シンプルに設置できる数字Captcha「MathCaptcha」

スパム防止などで利用されているCaptchaですが、数字版で使えるものがないか探してみました。 この「MathCapthca」は非常にシンプルに設置できるのはいいですが、やっぱりクエスチョンの部分は

Comment

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

*

PAGE TOP ↑