欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Yii框架表單模型和驗證用法

 更新時間:2016年05月20日 12:00:40   作者:yanhui_wei  
這篇文章主要介紹了Yii框架表單模型和驗證用法,結(jié)合實例形式分析了Yii表單模型的原理及驗證器的使用技巧,需要的朋友可以參考下

本文實例講述了Yii框架表單模型和驗證用法。分享給大家供大家參考,具體如下:

表單模型CFormModel絕大部分繼承CModelCModel,由于表模型數(shù)據(jù)不需要持久化,所以主要在驗證操作上。下面以框架腳手架生成的網(wǎng)站登錄為例說明表單模型。

//模型中的驗證規(guī)則
public function rules()
{
  return array(
    array('username, password', 'required'),
    array('rememberMe', 'boolean'),
    array('password', 'authenticate'),
  );
}

$model=new LoginForm;//創(chuàng)建一個登錄表單模型
$model->attributes=$_POST['LoginForm'];//傳入登錄數(shù)據(jù)
CModel->setAttributes($values,$safeOnly=true)//調(diào)用CModel的setter方法
//返回model中relues中定義的安全數(shù)據(jù),經(jīng)過下面的調(diào)用流程獲取一個驗證器集合
//每個驗證器由CValidator::createValidator($rule[1],$this,$rule[0],array_slice($rule,2))
CModel->getValidators()
->createValidators()
->rules()
CModel->validate();//遍歷驗證器執(zhí)行驗證

驗證器內(nèi)部實現(xiàn)

表單模型核心部分在驗證上,下面探討其實現(xiàn)方式。

YII框架中驗證以獨立組件集合的形式存在,CValidator是所有驗證器的基類。還是以登錄驗證為例。rules方法中包含required、boolean、authenticate三個驗證器

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;
}

創(chuàng)建驗證器流程

1、獲取屬性(array $attributes)和使用場景(array $on)
2、判斷驗證器是否存在model中,如果存在創(chuàng)建一個內(nèi)聯(lián)驗證器CInlineValidator,如果不存在,執(zhí)行第3步
3、如果驗證器是框架自帶的導(dǎo)入自帶驗證器,否則導(dǎo)入外部驗證器,然后實例化并賦值。

當(dāng)觸發(fā)validate()時候,可能產(chǎn)生的錯誤將被存儲在model中,可以通過調(diào)用 CModel::getErrors() 和CModel::getError() 提取這些錯誤信息

PS:小編在這里推薦一款本站的php格式化美化的排版工具幫助大家在以后的PHP程序設(shè)計中進行代碼排版:

php代碼在線格式化美化工具:http://tools.jb51.net/code/phpformat

更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結(jié)》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php日期與時間用法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家基于Yii框架的PHP程序設(shè)計有所幫助。

相關(guān)文章

  • CodeIgniter配置之config.php用法實例分析

    CodeIgniter配置之config.php用法實例分析

    這篇文章主要介紹了CodeIgniter配置之config.php用法,結(jié)合實例形式詳細的分析了CodeIgniter中配置文件config.php的參數(shù)含義及具體使用技巧,需要的朋友可以參考下
    2016-01-01
  • php獲取漢字首字母的函數(shù)

    php獲取漢字首字母的函數(shù)

    本文介紹用php實現(xiàn)漢字轉(zhuǎn)化為首字母的方法,主要功能是:功能明確,易于修改維護和擴展; 英文的字串:不變返回(包括數(shù)字);中文字符串:返回拼音首字符; 中英混合串: 返回拼音首字符和英文
    2013-11-11
  • Laravel框架實現(xiàn)model層的增刪改查(CURD)操作示例

    Laravel框架實現(xiàn)model層的增刪改查(CURD)操作示例

    這篇文章主要介紹了Laravel框架實現(xiàn)model層的增刪改查(CURD)操作,結(jié)合實例形式分析了Laravel框架模型model層進行數(shù)據(jù)庫的增刪改查操作具體實現(xiàn)技巧,需要的朋友可以參考下
    2018-05-05
  • PHP 下載文件時如何自動添加bom頭及解釋BOM頭和去掉bom頭的方法

    PHP 下載文件時如何自動添加bom頭及解釋BOM頭和去掉bom頭的方法

    在utf-8編碼文件中BOM在文件頭部,占用三個字節(jié),用來標示該文件屬于utf-8編碼,現(xiàn)在已經(jīng)有很多軟件識別bom頭,但是還有些不能識別bom頭,比如PHP就不能識別bom頭,這也是用記事本編輯utf-8編碼后執(zhí)行就會出錯的原因了
    2016-01-01
  • php制作簡單模版引擎

    php制作簡單模版引擎

    模板引擎(這里特指用于Web開發(fā)的模板引擎)是為了使用戶界面與業(yè)務(wù)數(shù)據(jù)(內(nèi)容)分離而產(chǎn)生的,它可以生成特定格式的文檔,用于網(wǎng)站的模板引擎就會生成一個標準的HTML文檔。
    2016-04-04
  • 對laravel的csrf 防御機制詳解,及form中csrf_token()的存在介紹

    對laravel的csrf 防御機制詳解,及form中csrf_token()的存在介紹

    對laravel的csrf 防御機制詳解,及對laravel的csrf 防御機制詳解,及form中csrf_token()的存在介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • CI框架網(wǎng)頁緩存簡單用法分析

    CI框架網(wǎng)頁緩存簡單用法分析

    這篇文章主要介紹了CI框架網(wǎng)頁緩存簡單用法,結(jié)合實例形式分析了CI框架網(wǎng)頁緩存的原理,以及開啟緩存、刪除緩存等操作技巧,需要的朋友可以參考下
    2018-12-12
  • 深入理解php printf() 輸出格式化的字符串

    深入理解php printf() 輸出格式化的字符串

    下面小編就為大家?guī)硪黄钊肜斫鈖hp printf() 輸出格式化的字符串。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • Linux中用PHP判斷程序運行狀態(tài)的2個方法

    Linux中用PHP判斷程序運行狀態(tài)的2個方法

    這篇文章主要介紹了Linux中用PHP判斷程序運行狀態(tài)的2個方法,需要的朋友可以參考下
    2014-05-05
  • PHP中實現(xiàn)中文字串截取無亂碼的解決方法

    PHP中實現(xiàn)中文字串截取無亂碼的解決方法

    這篇文章主要介紹了PHP中實現(xiàn)中文字串截取無亂碼的解決方法,直接使用PHP函數(shù)substr截取中文字符可能會出現(xiàn)亂碼,下面跟隨腳本之家小編一起看看具體解決方法吧
    2018-05-05

最新評論