亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP YII框架開發(fā)小技巧之模型(models)中rules自定義驗證規(guī)則

 更新時間:2015年11月16日 14:14:16   投稿:mrr  
yii的models中rules部分是一些表單的驗證規(guī)則,對于表單驗證有幫助,在相應(yīng)的視圖(views)里面添加了表單,在表單被提交之前程序都會自動先來這里面的規(guī)則里驗證,只有通過對其有效的限制規(guī)則后才能被提交,可以很有效地保證表單安全和信息的有效性

YII的models中的rules部分是一些表單的驗證規(guī)則,對于表單驗證十分有用,在相應(yīng)的視圖(views)里面添加了表單,在表單被提交之前程序都會自動先來這里面的規(guī)則里驗證,只有通過對其有效的限制規(guī)則后才能被提交,可以很有效地保證表單安全和信息的有效性。還是給大家具體說明一下:

以下是視圖(views)部分的簡單代碼:

<?php $form=$this->beginWidget('CActiveForm', array( 
  'id'=>'tag-form', 
  'enableAjaxValidation'=>false, 
)); ?> 
  <div class="row"> 
    <?php echo $form->labelEx($model,'tagname'); ?> 
    <?php echo $form->textField($model,'tagname',array('size'=>20,'maxlength'=>32)); ?> 
  </div> 
  <div class="row"> 
    <?php echo $form->labelEx($model,'tagtype'); ?> 
    <?php echo $form->radioButtonList($model,'tagtype'array(1=>"普通TAG",2=>"系統(tǒng)默認TAG"),array('separator'=>'','labelOptions'=>array('class'=>'tagtypelabel'))); ?> 
  </div> 
  <?php echo $form->errorSummary($model); ?> 
  <div class="row buttons"> 
    <?php echo CHtml::submitButton($model->isNewRecord ? '添加' : '修改'); ?> 
  </div> 
<?php $this->endWidget(); ?> 

模型(models)中rules部分的簡單代碼:

public function rules() 
{ 
  return array( 
    array('tagname,tagtype', 'required'), 
    array('tagtype', 'numerical', 'integerOnly'=>true), 
    array('tagname', 'length', 'max'=>32), 
    array('tagname', 'match', 'pattern'=>'/^[\x{4e00}-\x{9fa5}A-Za-z0-9]+$/u', 
        'message'=>'標簽不合法,必須為漢字、字母或者數(shù)字!'), 
    array('tagname', 'checktagname', 'on'=>'create,update'),//插入TAG時檢查是否已經(jīng)存在該tag 
    array('tagid, tagname, tagtype', 'safe', 'on'=>'search'), 
  ); 
} 

系統(tǒng)默認有這些驗證規(guī)則:

boolean : CBooleanValidator 的別名, 確保屬性的值是CBooleanValidator::trueValue 或 CBooleanValidator::falseValue . 
captcha : CCaptchaValidator 的別名,確保了特性的值等于 CAPTCHA 顯示出來的驗證碼. 
compare : CCompareValidator 的別名, 確保了特性的值等于另一個特性或常量. 
email : CEmailValidator 的別名,確保了特性的值是一個有效的電郵地址. 
default : CDefaultValueValidator 的別名, 為特性指派了一個默認值. 
exist : CExistValidator 的別名, 確保屬性值存在于指定的數(shù)據(jù)表字段中. 
file : CFileValidator 的別名, 確保了特性包含了一個上傳文件的名稱. 
filter : CFilterValidator 的別名, 使用一個filter轉(zhuǎn)換屬性. 
in : CRangeValidator 的別名, 確保了特性出現(xiàn)在一個預(yù)訂的值列表里. 
length : CStringValidator 的別名, 確保了特性的長度在指定的范圍內(nèi). 
match : CRegularExpressionValidator 的別名, 確保了特性匹配一個正則表達式. 
numerical : CNumberValidator 的別名, 確保了特性是一個有效的數(shù)字. 
required : CRequiredValidator 的別名, 確保了特性不為空. 
type : CTypeValidator 的別名, 確保了特性為指定的數(shù)據(jù)類型. 
unique : CUniqueValidator 的別名, 確保了特性在數(shù)據(jù)表字段中是唯一的. 
url : CUrlValidator 的別名, 確保了特性是一個有效的路徑.

基本上還是比較全面的,一般的都夠用了,但是還是有時候有的驗證需要自定義。就以上面的代碼為例,我們在添加TAG時需要檢查系統(tǒng)之前是否已經(jīng)存在這個TAG,如果存在則不讓用戶添加。這個就需要在添加之前去查詢數(shù)據(jù)庫,看該TAG是否已經(jīng)存在,這里我們就需要自定一個驗證規(guī)則了。

關(guān)鍵有一下兩個步驟:

1、在rules中 添加代碼:array('tagname', 'checktagname', 'on'=>'create,update'),//插入TAG時檢查是否已經(jīng)存在該tag

注:我在其中用了 'on'=>'create,update',所以這個驗證規(guī)則之對create,update場景生效

2、在該模型(models)中添加驗證函數(shù):

public function checktagname($attribute,$params){ 
  $oldtag = Tag::model()->findByAttributes(array('tagname'=>$this->tagname)); 
  if($oldtag->tagid > 0){ 
    $this->addError($attribute, '該TAG已經(jīng)存在!'); 
  } 
} 

其中需要說明的是:

(1)該驗證函數(shù)的參數(shù)必須是($attribute,$params),不能缺少其中任何一個;

(2)$this->addError($attribute, '該TAG已經(jīng)存在!');這個是你想要在視圖中輸出的錯誤提示信息。

就是這么簡單,有了這個方法,表單驗證的各種想要的規(guī)則就都可以自定義了。

下面給大家介紹Yii自定義驗證規(guī)則

最簡單的定義驗證規(guī)則的方法是在使用它的模型(model)內(nèi)部定義。

比方說,你要檢查用戶的密碼是否足夠安全.

通常情況下你會使用 CRegularExpression 方法驗證,但為了本指南,我們假設(shè)不存在此驗證方法.

首先在模型(model)中添加兩個常量

const WEAK = 0;
const STRONG = 1;然后在模型(model)的 rules 方法中設(shè)置:

/**
 * @return array validation rules for model attributes.
 */
public function rules()
{
  return array(
    array('password', 'passwordStrength', 'strength'=>self::STRONG),
  );
}

確保你寫的規(guī)則不是一個已經(jīng)存在的規(guī)則,否則將會報錯.

現(xiàn)在要做的是在模型(model)中創(chuàng)建一個名稱為上面填寫的規(guī)則的方法(即 passwordStrength)。

/**
 * check if the user password is strong enough
 * check the password against the pattern requested
 * by the strength parameter
 * This is the 'passwordStrength' validator as declared in rules().
 */
public function passwordStrength($attribute,$params)
{
  if ($params['strength'] === self::WEAK)
    $pattern = '/^(?=.*[a-zA-Z0-9]).{5,}$/'; 
  elseif ($params['strength'] === self::STRONG)
    $pattern = '/^(?=.*\d(?=.*\d))(?=.*[a-zA-Z](?=.*[a-zA-Z])).{5,}$/'; 
    
  if(!preg_match($pattern, $this->$attribute))
   $this->addError($attribute, 'your password is not strong enough!');
}

剛才創(chuàng)建的方法需要兩個參數(shù):* $attribute 需要驗證的屬性* $params 在規(guī)則中自定義的參數(shù)

在模型的 rules 方法中我們驗證的是 password 屬性,所以在驗證規(guī)則中需要驗證的屬性值應(yīng)該是 password.

在 rules 方法中我們還設(shè)置了自定義的參數(shù) strength,它的值將會放到 $params 數(shù)組中.

你會發(fā)現(xiàn)在方法中我們使用了 CModel::addError().

添加錯誤接受兩個參數(shù):第一個參數(shù)是在表單中顯示錯誤的屬性名,第二個參數(shù)時顯示的錯誤信息 。

完整的方法:繼承 CValidator 類

如果你想把規(guī)則使用在多個模型(model)中,最好的方法時繼承 CValidator 類。

繼承這個類你可以使用像 CActiveForm::$enableClientValidation (Yii 1.1.7 版本后可用) 類似的其他功能。

創(chuàng)建類文件

首先要做的是創(chuàng)建類文件.最好的方法時類的文件名和類名相同,可以使用 yii 的延遲加載(lazy loading)功能。

讓我們在應(yīng)用(application)的擴展(extensiions)目錄(在 protected 文件夾下)下新建一個文件夾.

將目錄命名為: MyValidators

然后創(chuàng)建文件: passwordStrength.php

在文件中創(chuàng)建我們的驗證方法

class passwordStrength extends CValidator
{
  public $strength;
  private $weak_pattern = '/^(?=.*[a-zA-Z0-9]).{5,}$/';
  private $strong_pattern = '/^(?=.*\d(?=.*\d))(?=.*[a-zA-Z](?=.*[a-zA-Z])).{5,}$/';
...
}

在類中創(chuàng)建屬性,此屬性為在驗證規(guī)則中使用的參數(shù).

CValidator 會自動根據(jù)參數(shù)來填充這些屬性.

我們也創(chuàng)建了兩個其他的屬性,它們?yōu)?preg_match 函數(shù)使用的正則表達式.

現(xiàn)在我們應(yīng)該重寫父類的抽象方法(abstract method) validateAttribute

/**
 * Validates the attribute of the object.
 * If there is any error, the error message is added to the object.
 * @param CModel $object the object being validated
 * @param string $attribute the attribute being validated
 */
protected function validateAttribute($object,$attribute)
{
  // check the strength parameter used in the validation rule of our model
  if ($this->strength == 'weak')
   $pattern = $this->weak_pattern;
  elseif ($this->strength == 'strong')
   $pattern = $this->strong_pattern;
  // extract the attribute value from it's model object
  $value=$object->$attribute;
  if(!preg_match($pattern, $value))
  {
    $this->addError($object,$attribute,'your password is too weak!');
  }
}

上面的方法我認為就不用解釋了.當然你也可以在 if 的條件中使用常量,我推薦使用.

相關(guān)文章

最新評論