YIIフレームワーク解析ノート3:フォームモデルと検証
フォームモデルCFOrmModelのほとんどはCModelCModelを継承しています.テーブルモデルデータは永続化する必要がないため、主に検証操作に使用されます.次に、フレームワーク足場で生成されたWebサイトのログインを例にフォームモデルを説明します.
フォームモデルのコア部分は検証上、以下でその実現方法を検討する.
YIIフレームワークでは、CValidatorがすべてのベリファイアのベースクラスである独立したコンポーネントの集合として存在することを検証します.やはりログイン検証を例に挙げます.rulesメソッドにはrequired、boolean、authenticateの3つの検証器が含まれています
1、プロパティの取得(array$attributes)、シーンの使用(array$on)
2.ベリファイアがmodelに存在するかどうかを判断し、インラインベリファイアCInlineValidatorを作成し、存在しない場合は第3ステップを実行する
3.ベリファイアがフレームワークに付属している場合は、外部ベリファイアをインポートし、インスタンス化して値を割り当てます.
validate()がトリガーされると、発生する可能性のあるエラーがmodelに格納され、CModel::getErrors()およびCModel::getError()を呼び出すことでこれらのエラー情報を抽出できます.
//
public function rules()
{
return array(
array('username, password', 'required'),
array('rememberMe', 'boolean'),
array('password', 'authenticate'),
);
}
$model=new LoginForm;//
$model->attributes=$_POST['LoginForm'];//
CModel->setAttributes($values,$safeOnly=true)// CModel setter
// model relues ,
// CValidator::createValidator($rule[1],$this,$rule[0],array_slice($rule,2))
CModel->getValidators()
->createValidators()
->rules()
CModel->validate();//
ベリファイア内部実装フォームモデルのコア部分は検証上、以下でその実現方法を検討する.
YIIフレームワークでは、CValidatorがすべてのベリファイアのベースクラスである独立したコンポーネントの集合として存在することを検証します.やはりログイン検証を例に挙げます.rulesメソッドにはrequired、boolean、authenticateの3つの検証器が含まれています
public static function createValidator($name,$object,$attributes,$params=array())
{
if(is_string($attributes))
$attributes=preg_split('/[\s,]+/',$attributes,-1,PREG_SPLIT_NO_EMPTY);
if(isset($params['on']))
{
if(is_array($params['on']))
$on=$params['on'];
else
$on=preg_split('/[\s,]+/',$params['on'],-1,PREG_SPLIT_NO_EMPTY);
}
else
$on=array();
if(method_exists($object,$name))
{
$validator=new CInlineValidator;
$validator->attributes=$attributes;
$validator->method=$name;
if(isset($params['clientValidate']))
{
$validator->clientValidate=$params['clientValidate'];
unset($params['clientValidate']);
}
$validator->params=$params;
if(isset($params['skipOnError']))
$validator->skipOnError=$params['skipOnError'];
}
else
{
$params['attributes']=$attributes;
if(isset(self::$builtInValidators[$name]))
$className=Yii::import(self::$builtInValidators[$name],true);
else
$className=Yii::import($name,true);
$validator=new $className;
foreach($params as $name=>$value)
$validator->$name=$value;
}
$validator->on=empty($on) ? array() : array_combine($on,$on);
return $validator;
}
ベリファイアプロセスの作成1、プロパティの取得(array$attributes)、シーンの使用(array$on)
2.ベリファイアがmodelに存在するかどうかを判断し、インラインベリファイアCInlineValidatorを作成し、存在しない場合は第3ステップを実行する
3.ベリファイアがフレームワークに付属している場合は、外部ベリファイアをインポートし、インスタンス化して値を割り当てます.
validate()がトリガーされると、発生する可能性のあるエラーがmodelに格納され、CModel::getErrors()およびCModel::getError()を呼び出すことでこれらのエラー情報を抽出できます.