ホームページ >バックエンド開発 >PHPチュートリアル >ThinkPHP の create() メソッドの自動検証について

ThinkPHP の create() メソッドの自動検証について

不言
不言オリジナル
2018-06-08 15:55:511809ブラウズ

次に、ThinkPHP の create() メソッドの自動検証の例を示します。内容がとても良かったので、参考としてシェアさせていただきます。

自動検証は、ThinkPHP モデル層によって提供されるデータ検証方法であり、create を使用してデータ オブジェクトを作成するときにデータ検証を自動的に実行できます。

原則:

##create() メソッドは、フォーム ($_POST) 情報を収集して返します。同時に、フォームの自動検証をトリガーし、不正なフィールドをフィルタリングします。

コントローラーで create() メソッドを使用すると (戻り値は true/false)、モデル クラスの $_validate 属性が自動的にトリガーされます (これは、親クラス Model、サブクラス Rewrite in Model) で、create() メソッドにデータがなく戻り値が false の場合、$_validate で検証ルールをカスタマイズします (検証ルールについては後で詳しく説明します)。エラーメッセージ!

自動検証の使用は、次のルール形式に従って定義する必要があります:

protected $_validate = array(  
 array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]), 
 array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]),
  ......
);

ここで検証フィールド、検証ルール、エラー プロンプトは必須です。検証条件、追加ルール、および検証時間はオプションです。

検証フィールド (必須): フォームフィールド。

検証ルール (必須): 必須フィールドには、電子メール アドレス、URL URL アドレス、および番号を含める必要があります。追加のルールと組み合わせて使用​​することもできます。

エラー プロンプト (必須): 検証が失敗した場合に返されるプロンプト メッセージ。

検証条件 (オプション): 0、1、2 の 3 つのタイプがあります。0: _POST に存在するフィールド検証、デフォルト。1: 検証ルールが定義されている場合は検証が必要です。値は空ではありません。検証、定義済み 検証ルールは正規表現です (デフォルト)

function 関数検証、定義済みの検証ルールは関数名です

callbackconfirmequalnotequal##in 定義された検証ルールは、配列またはカンマ区切りの文字列にすることができます。notin特定の範囲内にあるかどうかを検証します。特定の範囲内では、定義された検証ルールは配列またはカンマ区切りの文字列 (バージョン 3.1.2 の新機能) length検証の長さ、定義 検証ルールは、数値 (固定長を表す) または数値の範囲 (たとえば、3,12 は長さの範囲を表す) にすることができます。 3 から 12 までの長さ) betweenValidation range 、定義された検証ルールは範囲を表し、1、31、または 1、31 などの文字列または配列を使用できます。 array(1,31)notbetween検証は特定の範囲内にありません。定義された検証ルールは範囲を表します。文字列または配列を使用できます (新機能)バージョン 3.1.2) expire 有効期間内であるかどうかを検証します。定義された検証ルールは、その時点までの時間範囲を示します。たとえば、2012-1-15、2013-1-15 を使用して、現在の送信有効期間が 2012-1-15 から 2013-1-15 までであることを示すこともできます。また、タイムスタンプ定義 IP が許可されているかどうかを確認します。定義された検証ルールは、201.12.2.5,201.12.2.6 のように、カンマで区切られた許可された IP アドレスのリストを表します。 IP が禁止されているかどうかを確認します。定義された検証ルールは、201.12.2.5,201.12.2.6## のように、カンマで区切られた禁止された IP アドレスのリストを表します。 #unique 一意であるかどうかを確認するために、システムはフィールドの現在の値に基づいてデータベースにクエリを実行し、フォーム データに同じ値が存在するかどうかを判断します。主キー フィールドが含まれています。unique を使用して主キー フィールド自体を決定することはできません

验证时间(可选):共有1,2,3三种,1:新增数据时候验证;2:编辑数据时候验证;3:全部情况下验证(默认);也可以可以根据业务需要增加其他的验证时间

下面附上代码:以注册为例

前台页面比较简单,代码就不贴出来了,下面是前台注册界面截图

控制器代码:

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

  //两个逻辑:收集,展示
  if (!empty($_POST)) {
  
  //create()方法收集表单($_POST)信息并返回,同时触发表单自动验证,过滤非法字段
  $date = $user->create();
  //通过create()方法的返回值$date判断验证是否成功
  if ($date) { //返回实在数据的时候才进行添加
   //implode()把数组变为字符串
   $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);
  }
  }
  //调用view视图
  $this->display();
 }

模型类代码:

class UserModel extends Model{
 
 //是否批量处理验证,批量获取全部的错误验证信息
 protected $patchValidate = true; //默认为false

 //自动验证定义
 protected $_validate = array(

  //array(字段,验证规则,错误提示,验证条件,附加规则,验证时间)
  //①用户名验证,不能为空
  array('username','require','用户名不能为空'),
  array('username','','该用户名已经被占用','0','unique'),
  //②密码验证,不为空
  array('password','require','密码不能为空'),
  //③验证确认密码,必须填写,与密码保持一致
  array('password2','require','确认密码必须填写'),
  array('password2','password','两次密码保持一致',0,'confirm'),
  //④邮箱验证
  array('user_email','email','邮箱格式不正确',2),
  //⑤qq验证,数字组成,5-12位
  array('user_qq','number','qq必须是数字'),
  array('user_qq','5,12','位数在5-12位之间',0,'length'),
  //⑥学历验证,必须选一个
  array('user_xueli','2,5','学位必须选择一个',0,'between'),
  //⑦爱好验证,必须选择二个以上
  //因为爱好返回的是数组,附加规则中没有可以直接用的规则,所以需自定义方法,用callback方法验证
  array('user_hobby','check_hobby','爱好必须选两项或以上',1,'callback'),
  );

 //定义方法进行爱好验证
 //参数$arg代表被验证的表单信息
 function check_hobby($arg)
 {
  //判断数组长度是否大于2
  if (count($arg)<2) {
   return false; //会自动输出验证错误信息
  }
  return true;
 }
}

把验证的错误信息在模板中给展示出来(部分代码)

<td style="width:13%; text-align: right;">
 <label for="User_username" class="required">用户名 
 <span>*</span></label>
</td>

<td style="width:87%;">
 <input class="inputBg" size="25" name="username" id="User_username" type="text" value="" />     
 <span style="color:red;"><{$error.username|default:""}></span>
</td>

结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

对THINKPHP的addAll支持的最大数据量的分析

关于ThinkPHP CURD方法之table方法

关于ThinkPHP利用getlist方法实现数据搜索功能的分析

メソッド検証、定義された検証ルールが現在のモデル クラスのメソッドである
2 つのメソッドが一致しているかどうかを検証します。フォーム内のフィールド 同じです。定義された検証ルールはフィールド名
であり、特定の値と等しいかどうかを検証します。この値は、以前の検証ルール
以前の検証ルール (バージョン 3.1.2 の新機能) で定義された特定の値と等しくないかどうかを検証します。
# を使用することもできます。 ##ip_allow
ip_deny

以上がThinkPHP の create() メソッドの自動検証についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。