数値系バリデーション

CakePHP 2になっていくつか数値用バリデーションルールが追加されています。

数値用 (コア)バリデーション

  • decimal - 十進数であること
  • numeric - 数値であること
  • naturalNumber - 自然数(正の整数)であること
  • range - 数値の範囲(超え・未満)であること
  • comparison - 大・小・一致・不一致の比較に合致すること

5つともnotEmptyとなるので、必須としない場合は'allowEmpty' => trueを追加する必要があります。

decimal

十進数であることであることを検証します。

decimal(integer $check, integer $places = null, string $regex = null)
小数点以下の桁数を限定する場合は第2引数($places)で指定します。
第3引数で正規表現を指定した場合は、優先してそれを使用してバリデーションが行われます。

public $validate = array(
    'height' => array(
        'rule' => array( 'decimal', 2),  // 小数点以下桁数を限定
        'message' => '小数点以下2桁まで入力して下さい。',
        'allowEmpty' => true             // 空白許可
    ),
);

2.4.6 以降 localeconvから各国の「桁区切り文字」・「小数点(文字)」を取得し、それぞれ"空文字"、"カンマ"へ置換してバリデーションを行うようになりました。

numeric

数値であることを検証します。

numeric(string $check)
is_numericを使用して数値であることを検証します。なので、数値だけでなく16進数なども通ります。

public $validate = array(
    'cars' => array(
        'rule'    => 'numeric',
        'message' => 'Please supply the number of cars.',
        'allowEmpty' => true             // 空白許可
    )
);

naturalNumber

自然数(正の整数)であることを検証します。 (2.2 以降)

naturalNumber(mixed $check, boolean $allowZero = false)
第2引数($allowZero)で0(ゼロ)を許可(true)するか否か(false)を設定できます。

public $validate = array(
    'wheels' => array(
        'rule'    => 'naturalNumber',
        'message' => 'Please supply the number of wheels.',
        'allowEmpty' => true             // 空白許可
    ),
    'airbags' => array(
        'rule'    => array( 'naturalNumber', true),  // 0(ゼロ)を許可
        'message' => 'Please supply the number of airbags.',
        'allowEmpty' => true             // 空白許可
    ),
);

range

数値が設定された範囲内であることを検証します。

range(string $check, integer $lower = null, integer $upper = null)
第2引数($lower)に最小値、第3引数($upper)に最大値を設定して下さい。
バリデーションは、$lower超え、$upper未満となり、$lower・$upperの場合はエラーとなります。

public $validate = array(
    'number' => array(
        'rule'    => array( 'range', -1, 11),  // マイナス1より大きく11より小さい
        'message' => 'Please enter a number between 0 and 10',
        'allowEmpty' => true             // 空白許可
    )
);

comparison

数値の大小の比較を行い検証を行います。
comparison(mixed $check1, string $operator = null, integer $check2 = null)
第2引数($operator)に比較方法を指定います。
'is greater' (~より大きい)、'is less' (~より小さい)、'greater or equal' (~以上)、'less or equal' (~以下)、'equal to' (~と等しい)、'not equal' (~と等しくない)


Validationユーティリティ:/lib/Cake/Utility/Validation.php
Models > Data Validation
  • このエントリーをはてなブックマークに追加

関連記事

(メール・URL・電話・郵便・IP) データ バリデーション

今回は、プロフィール情報に使用されるデータに絞ったバリデーションルールです。 バリデーションルール 以下の5つのバリデーションルールがコアに用意されています。 email メールアドレス

複数ファイルアップロードフォーム

CakePHP 2.0からはHTML5が標準でサポートとなり、複数ファイルアップロードのためのフォーム記述が容易になりました。 View (ビュー) 配列 Array (

日付・時間のバリデーション

日付や時刻に関するバリデーションは以下のルールがビルトインされています。 date 日付 time 時刻 datetime 日時 (m:「月」を数字表記 / M:「月」を英語表記)

バリデーションエラーメッセージの取得

CakePHP 2.xになってバリデーションエラー時に返却されるメッセージのデータ形式が変更になったようです。1.3系では、ひとつのフィールドに対して返却されるメッセージは一つのルールのみですが、2.

ハッシュ関数の選択とハッシュ化処理

CakePHPでは、ログイン時にはpasswordを自動的にハッシュ化して認証を行ってくれますが、そのパスワードを登録する際は、明示的にハッシュ化する必要があります。 ハッシュ関数の選択 ハッ

多言語サイト向けに翻訳ファイルを使って翻訳を行う

CakePHPには、翻訳をビヘイビアを使用する方法と翻訳ファイルを使用する方法の2つがあるそうです。(他にもあるのかな?) 今回は、翻訳ファイルを使用して言語の切り替えを行い、その言語設定をCook

ユーザ登録(仮登録・メール・本登録)

以前1.3版で投稿した「ユーザ登録」処理の2.x版を作成しました。フローは同じで以下のようにします。 1. メールアドレス・パスワードでユーザ登録 2. この時点では仮登録として、本登録用のU

ログローテーション

CakePHP 2.xではbootstrap.php内にあらかじめアプリケーションログの設定が書かれています。2.xで日付ごとにログファイルが切り替わるよう設定してみました。 日ごとにログを切り替え

Js/Cssファイルの読み込みや出力する方法

CakePHPのHTMLヘルパーにはjsファイルやcssファイルを読み込むためのメソッドが用意されています。ファイルを読み込むのに加えて、出力先を複数指定できるようになっています。 また、インライン

CSS/JSをひとまとめにして軽量化するプラグイン「Minify plugin for CakePHP」

「Minify plugin for CakePHP」は、インクルードするCSSもしくはJSファイルをひとまとめにしてキャッシュ化してくれるプラグインです。 導入 ダウンロード・解凍し

Comment

Message

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

*

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

    PAGE TOP ↑