(メール・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 ), );
関連記事
-
hasOne アソシエーション
hasOneアソシエーションはテーブル間で1つのレコードに対して他のテーブルに紐付くレコードが1つの場合にjoinする場合に使用します。 CakePHPのドキュメントにならってUserモデルとP
-
radioボタンを実装
Radioボタンの実装は、セレクトボックスとほぼ同じです。 個人的にはラジオボタンをすすんで使用することは少ないのですが、2択くらいの選択肢であれば非常に便利ですよね。 今回は、その実装方法 デモ
-
Cookieログイン
今回は、ログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcookieメソッドのラッパー)メソッドはwr
-
アップロードファイルのバリデーションルール
CakePHP 2.2や2.3になってファイルアップロードに対するルールがコアバリデーションに追加されているようで、まとめてみました。 コアバリデーション 関連しそうなルールは以下の4つの
-
数値系バリデーション
CakePHP 2になっていくつか数値用バリデーションルールが追加されています。 数値用 (コア)バリデーション decimal - 十進数であること numeric - 数値であること
-
独自のバリデーションルールを作成
CakePHPで組み込みバリデーションルールをつくる方法は、正規表現を定義する方法と独自メソッドを定義する方法の2つがあるようです。 参考 Custom Validation Rules 正規
-
CSS/JSをひとまとめにして軽量化するプラグイン「Minify plugin for CakePHP」
「Minify plugin for CakePHP」は、インクルードするCSSもしくはJSファイルをひとまとめにしてキャッシュ化してくれるプラグインです。 導入 ダウンロード・解凍し
-
CakeEmailでメール送信(@gmail)
CakePHP 2になって追加されたクラスCakeEmailがシンプルに使えます。これを使用してメール送信を行う処理を実装してみました。 CakeEmailクラスの読み込み /app/Config
-
入力文字列の長さ(文字数)をバリデーション
CakePHP 2には、コアバリデーションに文字列の長さを検証する関数が用意されています。 文字列長(コア)バリデーション minLength - 最小文字数以上であること maxLengt
-
HttpSocketを使用してリクエスト送信
CakePHPには、Webサービスへのリクエスト送信のためのHttpSocketクラスが用意されています。 HttpSocket get HTTP GETリクエストを発行します。デモ H
Comment
(メール・URL・電話・郵便・IP) データ バリデーション https://t.co/j3uyNVyypi
CakePHP 2.x | (メール・URL・電話・郵便・IP) データ バリデーション http://t.co/VOcYi6lxWL