当前位置:Gxlcms > php框架 > ThinkPHP框架表单验证操作方法

ThinkPHP框架表单验证操作方法

时间:2021-07-01 10:21:17 帮助过:12人阅读

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

一、静态验证

(1)在Home/Controller/路径下新建Index控制器。IndexController

 IndexController.class.php页面

注意:静态定义方式因为必须定义模型类,所以只能用D函数实例化模型

     create方法是对表单提交的POST数据进行自动验证

  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. class IndexController extends Controller {
  5. public function yanzheng(){
  6. $u= D("users");//造一个子类对象
  7. if(empty($_POST)){
  8. $this->show();
  9. }else{
  10. if($u->create()){//验证
  11. echo"验证通过";
  12. }else{
  13. echo $u->getError();//获取错误信息
  14. }
  15. }
  16. }
  17. }

 (2)在view/Index文件夹下做yanzheng.html页面

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <title>无标题文档</title>
  6. <script src="__ROOT__/Public/js/jquery-3.2.0.min.js"></script>
  7. </head>
  8. <body>
  9. <h1>验证界面</h1>
  10. <form action="__ACTION__" method="post">
  11. <div>用户名:<input type="text" name="uid" /></div>
  12. <div>密码:<input type="password" name="pwd1"/></div>
  13. <div>确认密码:<input type="password" name="pwd2"/></div>
  14. <div>年龄:<input type="text" name="age"/></div>
  15. <div>邮箱:<input type="text" name="Email"/></div>
  16. <div><input type="submit" value="验证" /></div>
  17. </form>
  18. </body>
  19. </html>

 效果图:

(3)在Model层写静态验证的验证:(路径如图)

UsersModel.class.php

  1. <?php
  2. namespace Home\Model;
  3. use Think\Model;
  4. class UsersModel extends Model{
  5. //添加验证条件
  6. protected $_validate = array(
  7. array("uid","require","用户名不能为空!"), //默认情况下用正则进行验证
  8. array("pwd1","require","密码不能为空!"),
  9. array("pwd2","require","密码不能为空!"),
  10. array("pwd2","pwd1","两次输入的密码不一致",0,"confirm"), // 验证确认密码是否和密码一致
  11. array("age","18,50","年龄不在范围内",0,"between"),
  12. array("Email","email","邮箱格式不正确"),
  13. );
  14. }

 依次验证效果图:

当全部为空时,点击验证

会跳转

输入用户名,其他不输入时,会跳转

两次密码输入不一致时,会提示;年龄不在范围内会提示;邮箱格式不正确时会提示;

 

输入正确格式内容后

 二、动态验证

(1)  IndexController.class.php页面

  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. class IndexController extends Controller {
  5. public function yz(){
  6. $u= M("users");//造一个父类对象
  7. if(empty($_POST)){
  8. $this->show();
  9. }else{
  10. $rules = array(
  11. array("uid","require","用户名不能为空!"),
  12. );
  13. if($u->validate($rules)->create()){//验证
  14. $this->ajaxReturn("ok","eval");
  15. }else{
  16. $this->ajaxReturn("no","eval");
  17. }
  18. }
  19. }

 (2) yz.html页面:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <title>无标题文档</title>
  6. <script src="__ROOT__/Public/js/jquery-3.2.0.min.js"></script>
  7. </head>
  8. <body>
  9. <h1>验证界面</h1>
  10. <form action="__ACTION__" method="post">
  11. <div><input type="text" name="uid" id="uid" /><span id="ts"></span></div>
  12. <div><input type="submit" value="验证" /></div>
  13. </form>
  14. </body>
  15. <script type="text/javascript">
  16. $("#uid").blur(function(){
  17. var uid = $(this).val();
  18. $.ajax({
  19. url:"__ACTION__",
  20. data:{uid:uid},
  21. type:"POST",
  22. dataType:"TEXT",
  23. success: function(data){
  24. if(data.trim()=="ok")
  25. {
  26. $("#ts").html("验证通过");
  27. }
  28. else
  29. {
  30. $("#ts").html("用户名不能为空");
  31. }
  32. }
  33. });
  34. })
  35. </script>
  36. </html>

 看一下效果:

 当文本框失去焦点时:

当文本框有内容时,再失去焦点:

以上所述是小编给大家介绍的ThinkPHP框架表单验证操作方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

人气教程排行