PHPのORマッパ Propel のvalidationで値の検証する
スポンサーリンク
PHPのORマッパ Propel
で生成したPHPのクラスでは、値の検証(validation)を行うことができます。
例えば、下記の値チェックを行うことができます。
schema.xml
schema.xmlにvalidatorのタグを記述します。
uidがセットされているか?
schema.xmlを更新したら、再度、propel-gen を実行します。
それでは、自動生成された値チェックを利用してみます。
オブジェクトのvalidate関数を呼ぶだけでチェックができます。
propelは、schema.xmlに制限のルールを記述するだけで、簡単にバリデーションできて、便利です。結構、自分で値チェックのコードを書くのは、面倒ですよね、書くのも、テストも。
で生成したPHPのクラスでは、値の検証(validation)を行うことができます。
例えば、下記の値チェックを行うことができます。
- 文字数がオーバーしていないか?
- ちゃんと値はセットされているか?
- 数値が指定されているか?
schema.xml
schema.xmlにvalidatorのタグを記述します。
uidがセットされているか?
<rule name="required" message="uid is required." />
uidの長さは、多すぎないか?
<rule name="maxLength" message="uid can be no larger than ${value} in size" />
${value}は、columnのuid部分で指定したsize="150"の値が参照されます。
<?xml version="1.0" encoding="ISO-8859-1" standalone="no"?>
<database name="miniblog" defaultIdMethod="native">
<table name="blog">
<column name="id" type="BIGINT" primaryKey="true" autoIncrement="true" />
<column name="uid" type="VARCHAR" size="150" required="true" />
<validator column="uid">
<rule name="maxLength" message="uid can be no larger than ${value} in size" />
<rule name="required" message="uid is required." />
</validator>
<column name="body" type="VARCHAR" size="500" required="true" />
<validator column="body">
<rule name="maxLength" message="body can be no larger than ${value} in size" />
<rule name="required" message="body is required." />
</validator>
<column name="create_at" type="TIMESTAMP" defaultExpr="CURRENT_TIMESTAMP" />
</table>
</database>
schema.xmlを更新したら、再度、propel-gen を実行します。
propel . propel . insert-sql
それでは、自動生成された値チェックを利用してみます。
オブジェクトのvalidate関数を呼ぶだけでチェックができます。
<?php
$blog = new Blog();
$blog->setUid('User1');
$blog->setBlog('blog message 1.');
if ($blog->validate()) {
// 値チェックがOKなのでDBへ保存する
$blog->save();
} else {
// エラー
$validationFailuresArray = $blog->getValidationFailures();
foreach ($validationFailuresArray as $v) {
echo $v->getMessage(), PHP_EOF;
}
}
?>
propelは、schema.xmlに制限のルールを記述するだけで、簡単にバリデーションできて、便利です。結構、自分で値チェックのコードを書くのは、面倒ですよね、書くのも、テストも。
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12