PHP(超文本预处理器)可用于小型网站的搭建,当用户需要注册登录是,需要与后台数据库进行匹配合格才能注册和登录,传统的方式步骤繁多,需要先连接数据库再用sql语句进行插入。
php" id="highlighter_952052">
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
|
<?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)进行表单自动验证:
控制器中使用表单静态验证:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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 >";
}
}
|
模板中列出需要验证的字段:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<?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);表单静态验证使用很方便。
以上这篇老生常谈php中传统验证与thinkphp框架(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。