ログインに追加の条件を付与する「userScope」
「ユーザ登録」の続きです。
ユーザ登録後、activate(statusを0に設定するを)せずに「仮登録」のままで、正しいusernameとpasswordでログインを試したところ認証に引っかかってくれました。
ログインに追加の条件を付与する「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
関連記事
-
CakePHP 1.3 インストール
使い古されている手ではありますが、表題の件とレンタルサーバへの配置方法などにも使えますので参考にしていただけたらと思います。 まずはレンタルサーバでCakePHPを動作させる CakePHPア
-
validateErrors と validationErrors
CakePHP試験中に気付いたことがあって、メモです。 $this->validateErrors自身バリデーション処理している 今まで、save時にバリデーションエラーメッセージををログに出力し
-
Debugkitをインストール
CakePHPのデバッグツールとしてはデファクトスタンダードといってもいいDebugkitをインストールしました。 ダウンロード CakePHP 1.3用 https://github.com
-
Sessionコンポーネント
ソース: /cake/libs/controller/components/session.php read read($name = null) セッションの情報を読み込みます。 $
-
コントローラ内でバリデーション処理を呼び出す
通常、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。 バリデーシ
-
ビルトインされたバリデーションルール
CakePHP標準で多くのバリデーションルールが搭載されています。 ソース:/cake/libs/validation.php email / maxLength / minLength /
-
ログローテーション
CakePHP1.3では標準ではログはタイプごとに出力されるだけで、定期的なローテーションを行ってくれません。放っておくとひたすら1つのファイルにアペンドされていきます。app/tmp/logs以下に
-
recursive設定によるfind()性能改善
CakePHPでは、モデルにアソシエーションを設定している場合、recursive(=>joinする階層)はデフォルトで0に設定されています。「recursiveゼロ」の意味するところとは、「1跨ぎま
-
Cookieログイン
今回は、「keep me logged in」などログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcook
-
シンプルに設置できる数字Captcha「MathCaptcha」
スパム防止などで利用されているCaptchaですが、数字版で使えるものがないか探してみました。 この「MathCapthca」は非常にシンプルに設置できるのはいいですが、やっぱりクエスチョンの部分は
Comment
ログインに追加の条件を付与する「userScope」 http://t.co/WUqvfTM08b CakePHP 1.3