百搜论坛欢迎您的加入!
adimg adimg
 
昨日:篇  今日:篇   总帖:篇   会员:
博主最大Lv63   
ThinkPHP框架表单验证介绍     

对注册到test表的表单进行验证

在注册之前要对表单进行验证:

用户名非空验证,两次输入密码必须一致即相等验证,年龄在18~50之间即范围验证,邮箱格式正则验证。

自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证。

数据验证可以进行数据类型、业务规则、安全判断等方面的验证操作。

数据验证有两种方式:

  • 静态方式:在模型类里面通过$_validate属性定义验证规则。

  • 动态方式:使用模型类的validate方法动态创建自动验证规则。

无论是什么方式,验证规则的定义是统一的规则,定义格式为:

1

2

3

4

5

array(

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

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

......

);

验证字段 (必须)

需要验证的表单字段名称,这个字段不一定是数据库字段,也可以是表单的一些辅助字段,例如确认密码和验证码等等。有个别验证规则和字段无关的情况下,验证字段是可以随意设置的,例如expire有效期规则是和表单字段无关的。如果定义了字段映射的话,这里的验证字段名称应该是实际的数据表字段而不是表单字段。

验证规则 (必须)

要进行验证的规则,需要结合附加规则,如果在使用正则验证的附加规则情况下,系统还内置了一些常用正则验证的规则,可以直接作为验证规则使用,包括:require 字段必须、email 邮箱、url URL地址、currency 货币、number 数字。

提示信息 (必须)

用于验证失败后的提示信息定义

验证条件 (可选)

包含下面几种情况:

  • self::EXISTS_VALIDATE 或者0 存在字段就验证(默认)

  • self::MUST_VALIDATE 或者1 必须验证

  • self::VALUE_VALIDATE或者2 值不为空的时候验证

附加规则 (可选)

配合验证规则使用,包括下面一些规则:

1.jpg

验证时间(可选)

  • self::MODEL_INSERT或者1新增数据时候验证

  • self::MODEL_UPDATE或者2编辑数据时候验证

  • self::MODEL_BOTH或者3全部情况下验证(默认)

这里的验证时间需要注意,并非只有这三种情况,你可以根据业务需要增加其他的验证时间。

验证有两种方式:静态验证与动态验证。

一、静态验证

在模型类里面预先定义好该模型的自动验证规则,我们称为静态定义。

验证时要在test表的Model里面加验证条件:新建testModel.class.php,在模型类里面定义了$_validate属性如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

<?php

namespace Home\Model;

use Think\Model;

class testModel extends Model

{

    //静态验证

    protected $_validate = array(   

        array('uid','require','用户名不能为空'),       

        array('pwd','require','密码不能为空'),

        array('repwd','pwd','确认密码不正确',1,'confirm'),

        array('age','18,50','年龄必须在18-50岁之间',1,'between'),

        array('email','email','邮箱格式不正确'),

     

    );   

     

}

定义好验证规则后,就可以在使用create方法创建数据对象的时候自动调用:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

<?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:

1

2

3

4

5

6

7

8

9

10

11

<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方法:

2.jpg

二、动态验证

如果采用动态验证的方式,就比较灵活,可以根据不同的需要,在操作同一个模型的时候使用不同的验证规则,例如上面的静态验证方式可以改为:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

<?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('uid','require','用户名不能为空')

            );

            //调用validate()加入验证规则

            $r = $model->validate($rules)->create();//若验证失败返回false,成功返回注册的test表数组信息

            //var_dump($r);

            if(!$r)

            {

                echo $model->getError(); //若验证失败则输出错误信息   

            }

            else

            {

                $model->add();   

            }

             

        }   

    }

我们还可以在表单后面直接显示错误提示,这就要用到ajax。以验证用户名非空为例:

在模板ZhuCe.html中:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

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

</head>

 

<body>

<form action="__ACTION__" method="post">

<div>用户名:&nbsp;<input type="text" name="uid" id="uid" /> <span id="ts"></span></div><br />

<div>密码:&nbsp;&nbsp;<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>年龄:&nbsp;&nbsp;<input type="text" name="age" id="age" /> <span id="nts"></span></div><br />

<div>邮箱:&nbsp;&nbsp;<input type="text" name="email" id="email" /> <span id="ets"></span></div><br />

<div>姓名:&nbsp;&nbsp;<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='color:green'>"+data+"</span>";

                }

                else

                {

                    str = "<span style='color:red'>"+data+"</span>";   

                }

                 

                $("#ts").html(str);

                }

            });       

        })

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

//验证用户名非空

    function Yhm()

    {

        $model = D("test");   

        $rules = array(

                array('uid','require','用户名不能为空')

            );

             

            if(!$model->validate($rules)->create())

            {

                $fh = $model->getError();

                $this->ajaxReturn($fh,'eval');  //ajax返回数据,默认返回json格式,eval返回字符串,因为dataType是TEXT,所以用eval格式

            }

            else

            {

                $fh = "OK";   

                $this->ajaxReturn($fh,'eval');

            }

    }

请求ZhuCe方法:

3.jpg

其他验证也是类似的方法,提交相应数据到对应方法,使用相应的验证规则。

推荐教程:《TP5

以上就是ThinkPHP框架表单验证介绍的详细内容

 0  已被阅读了1035次  楼主 2020-06-23 10:17:07
回复列表

回复:ThinkPHP框架表单验证介绍

联系站长 友链申请桂ICP备19000949号-1     桂ICP备19000949号-1
您的IP:3.145.93.136,2024-05-08 08:00:20,Processed in 0.04111 second(s).
免责声明: 本网不承担任何由内容提供商提供的信息所引起的争议和法律责任。
Powered by HadSky 7.12.9
已有0次打赏
(0) 分享
分享
取消
免责声明
1、本站资源,均来自网络,版权归原作者,所有资源和文章仅限用于学习和研究目的 。
2、不得用于商业或非法用途,否则,一切责任由该用户承担 !
如果觉得本文还不错请点个赞或者打赏点轻币哦~
拒绝伸手党,拿走请回复,尊重楼主,尊重你我他~

侵权删除请致信 E-Mail:207882320@qq.com