首頁 >php框架 >ThinkPHP >ThinkPHP框架表單驗證介紹

ThinkPHP框架表單驗證介紹

尚
轉載
2020-05-12 09:30:043103瀏覽

ThinkPHP框架表單驗證介紹

對註冊到test表的表單進行驗證 

在註冊之前要對表單進行驗證:

使用者名稱非空驗證,兩次輸入密碼必須一致即相等驗證,年齡在18~50之間即範圍驗證,郵箱格式正規驗證。

自動驗證是ThinkPHP模型層提供的一種資料驗證方法,可以在使用create建立資料物件的時候自動進行資料驗證。

資料驗證可以進行資料類型、業務規則、安全判斷等方面的驗證操作。

資料驗證有兩種方式:

  • 靜態方式:在模型類別裡面透過$_validate屬性定義驗證規則。

  • 動態方式:使用模型類別的validate方法動態建立自動驗證規則。

無論是什麼方式,驗證規則的定義是統一的規則,定義格式為:

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

驗證欄位(必須)

需要驗證的表單字段名稱,這個字段不一定是資料庫字段,也可以是表單的一些輔助字段,例如確認密碼和驗證碼等等。有個別驗證規則和欄位無關的情況下,驗證欄位是可以隨意設定的,例如expire有效期限規則是和表單欄位無關的。如果定義了欄位對應的話,這裡的驗證欄位名稱應該是實際的資料表欄位而不是表單欄位。

驗證規則(必須)

要進行驗證的規則,需要結合附加規則,如果在使用正規驗證的附加規則情況下,系統也內建了一些常用正規驗證的規則,可以直接作為驗證規則使用,包括:require 欄位必須、email 信箱、url URL位址、currency 貨幣、number 數字。

提示訊息(必須)

用於驗證失敗後的提示訊息定義

驗證條件(可選)

包含以下幾種情況:

  • self::EXISTS_VALIDATE 或0 存在欄位就驗證(預設)

  • self ::MUST_VALIDATE 或1 必須驗證

  • self::VALUE_VALIDATE或2 值不為空的時候驗證 

#附加規則(可選)

配合驗證規則使用,包含以下一些規則:  

ThinkPHP框架表單驗證介紹

驗證時間(可選)

  • self::MODEL_INSERT或1新增資料時候驗證

  • #self::MODEL_UPDATE或2編輯資料時候驗證

  • #self::MODEL_BOTH或3全部情況下驗證(預設)

這裡的驗證時間需要注意,並非只有這三種情況,你可以根據業務需要增加其他的驗證時間。

驗證有兩種方式:靜態驗證與動態驗證。

一、靜態驗證 

在模型類別裡面預先定義好模型的自動驗證規則,我們稱為靜態定義。

驗證時要在test表的Model裡面加驗證條件:新建testModel.class.php,在模型類別裡面定義了$_validate屬性如下:

<?php
namespace Home\Model;
use Think\Model;
class testModel extends Model
{
    //静态验证
    protected $_validate = array(    
        array(&#39;uid&#39;,&#39;require&#39;,&#39;用户名不能为空&#39;),        
        array(&#39;pwd&#39;,&#39;require&#39;,&#39;密码不能为空&#39;),
        array(&#39;repwd&#39;,&#39;pwd&#39;,&#39;确认密码不正确&#39;,1,&#39;confirm&#39;),
        array(&#39;age&#39;,&#39;18,50&#39;,&#39;年龄必须在18-50岁之间&#39;,1,&#39;between&#39;),
        array(&#39;email&#39;,&#39;email&#39;,&#39;邮箱格式不正确&#39;),
    
    );    
    
}

定義好驗證規則後,就可以在使用create方法建立資料物件的時候自動呼叫:

<?php
namespace Home\Controller;
use Home\Controller\CheckController;
class ZhuCeController extends CheckController
{
    function ZhuCe()
    {
        //静态验证,不能在后面直接显示,必须全部通过验证才能注册
        $cw = "";
        if(!empty($_GET))
        {
            $cw = $_GET["cw"];    
        }
        if(empty($_POST))
        {
            $this->assign("error",$cw);
            $this->display();
        }
        else
        {
            $model = new \Home\Model\testModel();
            //$model = D("test");    //动态验证可以用D方法
             
            if(!$model->create())
            {                
                $e = $model->getError();
                $url = "ZhuCe/cw/{$e}";
                $this->error("注册失败!",$url,1);
            }
            else
            {
                $model->add();    
            }

範本ZhuCe.html:

<body>
<form action="__ACTION__" method="post">
<div>用户名:<input type="text" name="uid" id="uid" /> </div><br />
<div>密码:<input type="text" name="pwd" id="pwd" /></div><br />
<div>确认密码:<input type="text" name="repwd" id="repwd" /> </div><br />
<div>年龄:<input type="text" name="age" id="age" /> </div><br />
<div>邮箱:<input type="text" name="email" id="email" /> </div><br />
<div>姓名:<input type="text" name="name" /></div><br />
<div><{$error}></div>   <!--显示错误信息-->
<input type="submit" value="注册" />
</form>

請求ZhuCe方法:

ThinkPHP框架表單驗證介紹

二、動態驗證

如果採用動態驗證的方式,就比較靈活,可以根據不同的需要,在操作同一個模型的時候使用不同的驗證規則,例如上面的靜態驗證方式可以改為:

<?php
namespace Home\Controller;
use Home\Controller\CheckController;
class ZhuCeController extends CheckController
{
    function ZhuCe()
    {        
        if(empty($_POST))
        {            
            $this->display();
        }
        else
        {
            //$model = new \Home\Model\testModel();
            $model = D("test");    //动态验证可以用D方法            
            //动态验证
            $rules = array(
                array(&#39;uid&#39;,&#39;require&#39;,&#39;用户名不能为空&#39;)
            );
            //调用validate()加入验证规则
            $r = $model->validate($rules)->create();//若验证失败返回false,成功返回注册的test表数组信息
            //var_dump($r);
            if(!$r)
            {
                echo $model->getError(); //若验证失败则输出错误信息    
            }
            else
            {
                $model->add();    
            }
            
        }    
    }

我們也可以在表單後面直接顯示錯誤提示,這就要用到ajax。以驗證使用者名稱非空為例:

在範本ZhuCe.html中:

<script src="../../../../../jquery-1.11.2.min.js"></script>  
</head>

<body>
<form action="__ACTION__" method="post">
<div>用户名: <input type="text" name="uid" id="uid" /> <span id="ts"></span></div><br />
<div>密码:  <input type="text" name="pwd" id="pwd" /> <span id="pts"></span></div><br />
<div>确认密码:<input type="text" name="repwd" id="repwd" /> <span id="rpts"></span></div><br />
<div>年龄:  <input type="text" name="age" id="age" /> <span id="nts"></span></div><br />
<div>邮箱:  <input type="text" name="email" id="email" /> <span id="ets"></span></div><br />
<div>姓名:  <input type="text" name="name" /></div><br />
<!--<div><{$error}></div> -->  <!--显示错误信息-->
<input type="submit" value="注册" />
</form>
</body>
</html>
<script type="text/javascript">
$(document).ready(function(e) {
    $("#uid").blur(function(){
        var uid = $(this).val();
        $.ajax({
            
            url:"__CONTROLLER__/Yhm",  <!--提交到方法,而不是页面-->
            data:{uid:uid},   <!--因为做的是表单验证,所以提交时要与表单name值一致,相当于提交表单 -->
            type:"POST",
            dataType:"TEXT",   <!--返回数据类型要与ajaxReturn中的参数对应,TEXT对应eval-->
            success: function(data){
                //alert(data);
                var str = "";
                if(data.trim()=="OK")
                {
                    str = "<span style=&#39;color:green&#39;>"+data+"</span>";
                }
                else
                {
                    str = "<span style=&#39;color:red&#39;>"+data+"</span>";    
                }
                
                $("#ts").html(str);
                }
            });        
        })

在ZhuCe控制器中再做一個Yhm方法:

//验证用户名非空
    function Yhm()
    {
        $model = D("test");    
        $rules = array(
                array(&#39;uid&#39;,&#39;require&#39;,&#39;用户名不能为空&#39;)
            );
            
            if(!$model->validate($rules)->create())
            {
                $fh = $model->getError();
                $this->ajaxReturn($fh,&#39;eval&#39;);  //ajax返回数据,默认返回json格式,eval返回字符串,因为dataType是TEXT,所以用eval格式
            }
            else
            {
                $fh = "OK";    
                $this->ajaxReturn($fh,&#39;eval&#39;);
            }
    }

請求ZhuCe方法:

ThinkPHP框架表單驗證介紹

其他驗證也是類似的方法,提交對應資料到對應方法,使用對應的驗證規則。

推薦教學:《TP5

以上是ThinkPHP框架表單驗證介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除