真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

create()方法怎么在ThinkPHP中使用-創(chuàng)新互聯(lián)

今天就跟大家聊聊有關create()方法怎么在ThinkPHP中使用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

網(wǎng)站的建設成都創(chuàng)新互聯(lián)專注網(wǎng)站定制,經(jīng)驗豐富,不做模板,主營網(wǎng)站定制開發(fā).小程序定制開發(fā),H5頁面制作!給你煥然一新的設計體驗!已為成都火鍋店設計等企業(yè)提供專業(yè)服務。

php有什么用

php是一個嵌套的縮寫名稱,是英文超級文本預處理語言,它的語法混合了C、Java、Perl以及php自創(chuàng)新的語法,主要用來做網(wǎng)站開發(fā),許多小型網(wǎng)站都用php開發(fā),因為php是開源的,從而使得php經(jīng)久不衰。

自動驗證是ThinkPHP模型層提供的一種數(shù)據(jù)驗證方法,可以在使用create創(chuàng)建數(shù)據(jù)對象的時候自動進行數(shù)據(jù)驗證。

原理:

create()方法收集表單($_POST)信息并返回,同時觸發(fā)表單自動驗證,過濾非法字段,

在控制器中使用create()方法,(返回值為true/false),會自動觸發(fā)模型類中的$_validate屬性(為父類Model中的方法,在子類Model中重寫),在$_validate中自定義驗證規(guī)則(驗證規(guī)則下面會詳細說明),當create()方法沒有數(shù)據(jù)即返回值為false時,通過$xxx對象->getError();獲取并返回錯誤信息!

使用自動驗證必須按照以下規(guī)則格式定義:

protected $_validate = array(  
 array(驗證字段1,驗證規(guī)則,錯誤提示,[驗證條件,附加規(guī)則,驗證時間]), 
 array(驗證字段2,驗證規(guī)則,錯誤提示,[驗證條件,附加規(guī)則,驗證時間]),
  ......
);

其中驗證字段,驗證規(guī)則,錯誤提示是必填項,驗證條件,附加規(guī)則,驗證時間為可選!

驗證字段(必填):表單字段。

驗證規(guī)則(必填):require 字段必須、email 郵箱、url URL地址、number 數(shù)字,還可以結合附加規(guī)則使用。

錯誤提示(必填):驗證失敗時返回的提示信息。

驗證條件(可選):有0,1,2三種,0:_POST中存在的字段驗證,默認;1:驗證規(guī)則定義了就必須驗證;2:值不為空時驗證.

附加規(guī)則:

regex正則驗證,定義的驗證規(guī)則是一個正則表達式(默認)
function函數(shù)驗證,定義的驗證規(guī)則是一個函數(shù)名
callback方法驗證,定義的驗證規(guī)則是當前模型類的一個方法
confirm驗證表單中的兩個字段是否相同,定義的驗證規(guī)則是一個字段名
equal驗證是否等于某個值,該值由前面的驗證規(guī)則定義
notequal驗證是否不等于某個值,該值由前面的驗證規(guī)則定義(3.1.2版本新增)
in驗證是否在某個范圍內(nèi),定義的驗證規(guī)則可以是一個數(shù)組或者逗號分割的字符串
notin驗證是否不在某個范圍內(nèi),定義的驗證規(guī)則可以是一個數(shù)組或者逗號分割的字符串(3.1.2版本新增)
length驗證長度,定義的驗證規(guī)則可以是一個數(shù)字(表示固定長度)或者數(shù)字范圍(例如3,12 表示長度從3到12的范圍)
between驗證范圍,定義的驗證規(guī)則表示范圍,可以使用字符串或者數(shù)組,例如1,31或者array(1,31)
notbetween驗證不在某個范圍,定義的驗證規(guī)則表示范圍,可以使用字符串或者數(shù)組(3.1.2版本新增)
expire驗證是否在有效期,定義的驗證規(guī)則表示時間范圍,可以到時間,例如可以使用 2012-1-15,2013-1-15 表示當前提交有效期在2012-1-15到2013-1-15之間,也可以使用時間戳定義
ip_allow驗證IP是否允許,定義的驗證規(guī)則表示允許的IP地址列表,用逗號分隔,例如201.12.2.5,201.12.2.6
ip_deny驗證IP是否禁止,定義的驗證規(guī)則表示禁止的ip地址列表,用逗號分隔,例如201.12.2.5,201.12.2.6
unique驗證是否,系統(tǒng)會根據(jù)字段目前的值查詢數(shù)據(jù)庫來判斷是否存在相同的值,當表單數(shù)據(jù)中包含主鍵字段時unique不可用于判斷主鍵字段本身

驗證時間(可選):共有1,2,3三種,1:新增數(shù)據(jù)時候驗證;2:編輯數(shù)據(jù)時候驗證;3:全部情況下驗證(默認);也可以可以根據(jù)業(yè)務需要增加其他的驗證時間

下面附上代碼:以注冊為例

前臺頁面比較簡單,代碼就不貼出來了,下面是前臺注冊界面截圖

create()方法怎么在ThinkPHP中使用

控制器代碼:

//注冊
 public function register(){
  $user = new \Model\UserModel();

  //兩個邏輯:收集,展示
  if (!empty($_POST)) {
  
  //create()方法收集表單($_POST)信息并返回,同時觸發(fā)表單自動驗證,過濾非法字段
  $date = $user->create();
  //通過create()方法的返回值$date判斷驗證是否成功
  if ($date) { //返回實在數(shù)據(jù)的時候才進行添加
   //implode()把數(shù)組變?yōu)樽址?   $date['user_hobby'] = implode(',', $date['user_hobby']);
   $info = $user->add($date);
   if ($info) {
   
   //跳轉首頁   
   $this->redirect('Index/index');
   }
  }else{

   //把錯誤信息分配到前臺模板
   $error = $user->getError();
   $this->assign('error',$error);
  }
  }
  //調(diào)用view視圖
  $this->display();
 }

模型類代碼:

class UserModel extends Model{
 
 //是否批量處理驗證,批量獲取全部的錯誤驗證信息
 protected $patchValidate = true; //默認為false

 //自動驗證定義
 protected $_validate = array(

  //array(字段,驗證規(guī)則,錯誤提示,驗證條件,附加規(guī)則,驗證時間)
  //①用戶名驗證,不能為空
  array('username','require','用戶名不能為空'),
  array('username','','該用戶名已經(jīng)被占用','0','unique'),
  //②密碼驗證,不為空
  array('password','require','密碼不能為空'),
  //③驗證確認密碼,必須填寫,與密碼保持一致
  array('password2','require','確認密碼必須填寫'),
  array('password2','password','兩次密碼保持一致',0,'confirm'),
  //④郵箱驗證
  array('user_email','email','郵箱格式不正確',2),
  //⑤qq驗證,數(shù)字組成,5-12位
  array('user_qq','number','qq必須是數(shù)字'),
  array('user_qq','5,12','位數(shù)在5-12位之間',0,'length'),
  //⑥學歷驗證,必須選一個
  array('user_xueli','2,5','學位必須選擇一個',0,'between'),
  //⑦愛好驗證,必須選擇二個以上
  //因為愛好返回的是數(shù)組,附加規(guī)則中沒有可以直接用的規(guī)則,所以需自定義方法,用callback方法驗證
  array('user_hobby','check_hobby','愛好必須選兩項或以上',1,'callback'),
  );

 //定義方法進行愛好驗證
 //參數(shù)$arg代表被驗證的表單信息
 function check_hobby($arg)
 {
  //判斷數(shù)組長度是否大于2
  if (count($arg)<2) {
   return false; //會自動輸出驗證錯誤信息
  }
  return true;
 }
}

把驗證的錯誤信息在模板中給展示出來(部分代碼)


 用戶名 
 *



      
 <{$error.username|default:""}>

結果:

create()方法怎么在ThinkPHP中使用

看完上述內(nèi)容,你們對create()方法怎么在ThinkPHP中使用有進一步的了解嗎?如果還想了解更多知識或者相關內(nèi)容,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。


分享文章:create()方法怎么在ThinkPHP中使用-創(chuàng)新互聯(lián)
分享鏈接:http://weahome.cn/article/dgishc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部