(メール・URL・電話・郵便・IP) データ バリデーション
今回は、プロフィール情報に使用されるデータに絞ったバリデーションルールです。
バリデーションルール
以下の5つのバリデーションルールがコアに用意されています。
- email メールアドレス
- url URL
- postal 郵便番号
- phone 電話番号
- ip IPアドレス
email (メールアドレス)
email(string $check, boolean $deep = false, string $regex = null)
第2引数$deepがtrueの場合、getmxrrもしくはcheckdnsrrもしくはgethostbynamelを使用してドメインの有無まで検証してくれます。第3引数$regexに正規表現を使用してドメインを限定してくれます。
public $validate = array(
'mailaddress' => array(
'rule' => array( 'email'),
// 'rule' => array( 'email', true), // ドメイン有無を検証
// 'rule' => array( 'email', true, '\gmail.com\'), // gmail.comのみ許可
'message' => 'メールアドレスを入力して下さい。',
'allowEmpty' => true // 空白許可
),
);
url (URL)
url(string $check, boolean $strict = false)
http(s), ftp(s), file, news, gopherをサポート。第2引数$strict がtrueの場合、http://などプロトコルまで求めます。
public $validate = array(
'website' => array(
// プロトコルまで必要なし
'rule' => array( 'url'), // kwski.net
// プロトコルまで必要
// 'rule' => array( 'url', true), // http://kwski.net
'message' => 'URLを入力して下さい。',
'allowEmpty' => true
),
);
postal (郵便番号)
アメリカ(us)、カナダ(ca)、イギリス(uk)、イタリア(it)、ドイツ(de)、ベルギー(be)の郵便番号のフォーマットが用意されているだけなので、日本版につくってみましょう。正規表現が使用できるcustomルールを使用します。
public $validate = array(
'postal' => array(
// ハイフン必須
'rule' => array( 'custom', '/^[0-9]{3}-[0-9]{4}$/'),
// ハイフンがあってもなくてもいい
// 'rule' => array( 'custom', '/^[0-9]{3}[\s-]?[0-9]{4}$/'),
'message' => 'postal error',
'allowEmpty' => true
),);
CakePHP Localized pluginを参考にさせてもらいました。こちらのプラグインをインストールすれば、日本用の郵便番号のルールが使用できます。
phone (電話番号)
アメリカの電話番号フォーマットを検証 になるので、こちらも日本用にcustomを使用してつくってみましょう。電話番号は、様々なパターンがあると思うので、正規表現内の数字を変えつつ調整してもらったほうがいいと思います。
下の例では、
0xxx-xxxx-yyyy (xの個数は可変)
になります。
public $validate = array(
'phone' => array(
// ハイフン必須
'rule' => array( 'custom', '/^(0\d{1,4}-\d{1,4}-\d{4})$/'),
// ハイフンがあってもなくてもいい
// 'rule' => array( 'custom', '/^(0\d{1,4}[\s-]?\d{1,4}[\s-]?\d{4})$/'),
'message' => 'phone error',
'allowEmpty' => true
),
);
こちらもCakePHP Localized pluginに日本版が用意されています。
ip (IPアドレス)
ip(string $check, string $type = 'both')
第2引数$typeで、両方、IPv4のみ、IPv6のみを制限できます。
public $validate = array(
'defaulgateway' => array(
'rule' => array( 'ip', 'both'), // 両方OK
// 'rule' => array( 'ip', 'IPv4'), // IPv4のみOK
// 'rule' => array( 'ip', 'IPv6'), // IPv6のみOK
'message' => 'IPアドレスを入力して下さい。',
'allowEmpty' => true
),
);
関連記事
-
-
ネストしたリストを出力「nestedList」
DBやJSONからデータを取得して、そのデータをもとにメニュー表示などネストしたリストを出力させたい場合に「nestedList」が便利です。 ヘルパーに渡すデータは連想配列である必要があります。(
-
-
コントローラ内でバリデーション処理を呼び出す
CakePHPでは、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。
-
-
多言語サイト向けに翻訳ファイルを使って翻訳を行う
CakePHPには、翻訳をビヘイビアを使用する方法と翻訳ファイルを使用する方法の2つがあるそうです。(他にもあるのかな?) 今回は、翻訳ファイルを使用して言語の切り替えを行い、その言語設定をCook
-
-
ログローテーション
CakePHP 2.xではbootstrap.php内にあらかじめアプリケーションログの設定が書かれています。2.xで日付ごとにログファイルが切り替わるよう設定してみました。 日ごとにログを切り替え
-
-
Js/Cssファイルの読み込みや出力する方法
CakePHPのHTMLヘルパーにはjsファイルやcssファイルを読み込むためのメソッドが用意されています。ファイルを読み込むのに加えて、出力先を複数指定できるようになっています。 また、インライン
-
-
CakeEmailでメール送信(@gmail)
CakePHP 2になって追加されたクラスCakeEmailがシンプルに使えます。これを使用してメール送信を行う処理を実装してみました。 CakeEmailクラスの読み込み /app/Config
-
-
selectボックスを実装
今まで、selectボックスのgroupを作成するのにSet::Combineを使用していましたが、意外と簡単にできることに気付いてしまったので、ご紹介。(自分だけ知らなかったことに気付いた と言った
-
-
日付・時間のバリデーション
日付や時刻に関するバリデーションは以下のルールがビルトインされています。 date 日付 time 時刻 datetime 日時 (m:「月」を数字表記 / M:「月」を英語表記)
-
-
バリデーション前後に処理を追加できる「beforeValidate」「afterValidate」
CakePHPでは、「beforeValidate」「afterValidate」というバリデーション処理の前後で追加の処理を実装できるコールバック関数が用意されています。 beforeVali
-
-
Formヘルパーのinputタグのdiv/labelなどの設定
Formヘルパーのinputではデフォルトでは以下のようにdivで囲われて、labelが付与されて出力されます。 CSSのフレームワークなどであらかじめ決まったスタイルがある場合に便利に作られていま


Comment
(メール・URL・電話・郵便・IP) データ バリデーション https://t.co/j3uyNVyypi
CakePHP 2.x | (メール・URL・電話・郵便・IP) データ バリデーション http://t.co/VOcYi6lxWL