YIIフレームワーク解析ノート3:フォームモデルと検証


フォームモデルCFOrmModelのほとんどはCModelCModelを継承しています.テーブルモデルデータは永続化する必要がないため、主に検証操作に使用されます.次に、フレームワーク足場で生成されたWebサイトのログインを例にフォームモデルを説明します.
// 
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()を呼び出すことでこれらのエラー情報を抽出できます.