首页  >  文章  >  后端开发  >  php中传统验证的实例教程

php中传统验证的实例教程

零下一度
零下一度原创
2017-06-23 14:26:191258浏览

      PHP(超文本预处理器)可用于小型网站的搭建,当用户需要注册登录是,需要与后台数据库进行匹配合格才能注册和登录,传统的方式步骤繁多,需要先连接数据库再用sql语句进行插入。

<?phpheader("Content-type: text/html; charset=utf-8");$conn =mysqli_connect("localhost","root","");if (!$conn){      echo "<script>alert('连接失败!');history.go(-1);</script>";
    } 
mysqli_select_db($conn,"liuyanban");mysqli_query($conn,'SET NAMES utf8');$password=$_POST['password'];$username=$_POST['username'];$face="yellow.png";$result=mysqli_query($conn,"SELECT username from user1 where username = '$username'");  
$a=mysqli_num_rows($result);if($a)
{       
      echo "<script language=javascript>alert('用户名已存在!');location.href='reg.html'</script>";
}else{     
       $sql = mysqli_query($conn,"INSERT INTO user1(username,password,face)VALUES('1' ,'2','yellow.png')");      if($sql)
      {           echo "<script language=javascript>alert('注册成功!');location.href='login.html'</script>";
      }      else  {echo "<script>alert('注册失败!');location.href='reg.html'</script>";
      }
}?>

    以上是一个原生php注册实例,需要用mysqli_select_db()、mysqli_query()等函数先进行数据库连接,同时只有通过mysqli_query()函数才能执行sql语句,最后通过if语句进行类别判断和其他一系列限制操作。在原生php阶段实用性比较高,便于理解,过程很清晰,但是在一个项目工程中用这样的语句代码编写不便于相互交流,非常繁重复杂,所以需要运用thinkphp框架搭建项目才能使编码人员相互可以对接,也便于后期代码的修改和功能的添加。那么这里就不赘述框架详细了,所以在thinkphp框架下mvc模式中运用控制器(C)和模型(M)进行表单自动验证:

控制器中使用表单静态验证:

 public function doreg(){              $data=D('user');              $d=array();                  $d['username']=$_POST['username'];                  $d['password']=$_POST['password'];                  $d['time']=date("Y-m-d H:i:s",time());                  $d['qq']=$_POST['qq'];                  $d['class']=$_POST['class'];                  $mess=$data->create();                  if (!$mess){       //表单自动验证$this->error($data->getError(),'Member/member',3);
                  }else{$data->add();echo "<script language=javascript>alert('注册成功!');location.href='member.html'</script>";
                      }
                  }

 

 模板中列出需要验证的字段:

<?php 
namespace Home\Model;use Think\Model;class UserModel extends Model{       protected $tableName =&#39;user&#39;;     protected $_validate=array(                                  //进行静态验证
          //array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),array(&#39;username&#39;,&#39;require&#39;,&#39;用户名必填!&#39;),array(&#39;username&#39;,&#39;&#39;,&#39;帐号名称已经存在!&#39;,0,&#39;unique&#39;,1),array(&#39;repassword&#39;,&#39;password&#39;,&#39;两次密码不一致!&#39;,0,&#39;confirm&#39;),array(&#39;qq&#39;,&#39;require&#39;,&#39;qq必填!&#39;),array(&#39;qq&#39;,&#39;&#39;,&#39;帐号名称已经存在!&#39;,0,&#39;unique&#39;,1),array(&#39;class&#39;,&#39;require&#39;,&#39;班级必填!&#39;),array(&#39;j_verify&#39;,&#39;require&#39;,&#39;验证码必须!&#39;),);
         
    }?>

这里以注册为例,登录类似,若验证错误,则运用$this->error($data->getError(),'Member/member',3);表单静态验证使用很方便。

以上是php中传统验证的实例教程的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn