こんにちは、簡単なログインシステムを作っています。
やりたいのは以下に示したパスワードポリシーに基づき、パスワードチェックを行うことです。
- 桁数チェック: 6文字以上 32文字以下
- 文字チェック:英字のみ、数字のみでも可
- 記号の使用自体は可とし、使える文字種は、!@#$%^&*()_+-=[]{};:?,.
Cakephp3の認証を使ってログイン機能を実装しましたが、Cakephp3のValidationを使うとハッシュ化されたパスワードがValidationされてしまい、32文字を超え、正常に動きませんでした。(他のフィールドは上手くチェックされています。)
php
// UsersTabel.phpの一部 public function validationDefault(Validator $validator) { $validator ->scalar('password') ->notEmpty('password',__('パスワードを入力してください。')); ->lengthBetween('password', [6, 32], __('最小6~最大32桁数で入力してください。')); ->add('password', 'alphaNumeric', [ 'rule' => ['custom','/^(?=.*[0-9])(?=.*[A-Za-z])(?=.*[!@#$%^[\]\&*()+-={};:?,._]$/i'], 'message' => '半角英数字のみで入力してください。' ]); }
そこで、パスワードのみBootstrapのValidatorを使うという方法で試してみましたが、やはり正常に動きませんでした。正規表現式を消すと動きますが、正規表現式を入れるとSubmitボタンが押せなくなります。
Javascript
//Add.ctpなどのビューファイルの一部(BootstrapValidator.jsと.cssはCDNでリンク。) <script type="text/javascript"> $(function() { $('form').bootstrapValidator({ live: 'enabled', feedbackIcons: { valid: 'glyphicon glyphicon-ok', invalid: 'glyphicon glyphicon-remove', validating: 'glyphicon glyphicon-refresh' }, fields: { password: { validators: { notEmpty: { message: 'パスワードは必須項目です' }, stringLength: { message: '6~32文字以内で入力してください', min: 6, max: 32 }, regexp: { message: '半角英数字と記号を入力してください', regexp: /^[a-zA-Z0-9!@#$%^&*()_+-=[]{};:?,.]+$/ } } } } }); }); </script>
質問は、2つです。
0.Cakephp3のValidationを使い、上記のパスワードポリシーに基づき、Validationできる方法はありませんか?例えば、モデル(UsersTabel.php)ではなくてコントローラー(UsersController.php)でValidationをするとハッシュ化される前にできそうですが…公式サイトを色々みた結果、モデルのないフォームというものが気になりますがあまり理解できませんでした。
0. 半額英数字と記号「!@#$%^&*()_+-=[]{};:?,.」のみ入力制限する正規表現式の正しい書き方を教えていただけますでしょうか。自分が書いたものは以下のようです。
Javascript
/^[a-zA-Z0-9!@#$%^&*()_+-=[]{};:?,.]+$/
どうそよろしくお願いいたします。
まだ回答がついていません
会員登録して回答してみよう