PHP(超文本預處理器)可用於小型網站的搭建,當用戶須要註冊登陸是,須要與後臺數據庫進行匹配合格才能註冊和登陸,傳統的方式步驟繁多,須要先鏈接數據庫再用sql語句進行插入。javascript
<?php header("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)進行表單自動驗證:php
控制器中使用表單靜態驗證:html
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>"; } }
模板中列出須要驗證的字段:java
<?php namespace Home\Model; use Think\Model; class UserModel extends Model{ protected $tableName ='user'; protected $_validate=array( //進行靜態驗證 //array(驗證字段1,驗證規則,錯誤提示,[驗證條件,附加規則,驗證時間]), array('username','require','用戶名必填!'), array('username','','賬號名稱已經存在!',0,'unique',1), array('repassword','password','兩次密碼不一致!',0,'confirm'), array('qq','require','qq必填!'), array('qq','','賬號名稱已經存在!',0,'unique',1), array('class','require','班級必填!'), array('j_verify','require','驗證碼必須!'), ); } ?>
這裏以註冊爲例,登陸相似,若驗證錯誤,則運用$this->error($data->getError(),'Member/member',3);表單靜態驗證使用很方便。mysql