遇到用户注冊等情况时。假设等用户输入全部信息,点击注冊button提交后。再验证输入是否正确,体验非常不好,并且非常浪费用户的时间,添加注冊成本,这里提供一个样例,演示了怎么使用ajax进行单步验证,使用thinkphp 3.2框架,环境WAMPServer 2.4。版本号PHP 5.4.16+ Apache 2.4.4+ MySql 5.6.12

一、数据库设计:

数据库名 thinkphp

表名 tp_user 当中tp_是表前缀。能够在config.php中定义,操作表的时候仅仅用user即可

CREATE TABLE IF NOT EXISTS `tp_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(30) NOT NULL,
`password` varchar(255) NOT NULL,
`email` varchar(50) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

二、页面设计

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvV2VMb3ZlU3VuRmxvd2Vy/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

三、HTML部分

view/Index/index.html

<form method="post" action="{:U('Index/register')}">
<div class="form-element">
<label class="left">用户名:</label>
<div>
<input type="text" name="username" id="username" value="" />
<div id="tooltip1" class="tooltip-info prompt">
<span class="tooltip-icon-border"></span>
<span class="tooltip-icon-bg"></span>
<span class="state"></span>
<span id="mess1" class="mess"></span>
</div>
</div>
</div>
<div class="form-section">
<div class="form-element">
<label>密码:</label>
<div>
<input type="password" name="password" id="password" value="" />
<div id="tooltip2" class="tooltip-info prompt">
<span class="tooltip-icon-border"></span>
<span class="tooltip-icon-bg"></span>
<span class="state"></span>
<span id="mess2" class="mess"></span>
</div>
</div>
</div>
<div class="form-element">
<label>确认密码:</label>
<div>
<input type="password" name="repassword" id="repassword" value="" />
<div id="tooltip22" class="tooltip-info prompt">
<span class="tooltip-icon-border"></span>
<span class="tooltip-icon-bg"></span>
<span class="state"></span>
<span id="mess22" class="mess"></span>
</div>
</div>
</div>
<div class="form-element">
<label>邮箱:</label>
<div>
<input type="text" name="email" id="email" value="" />
<div id="tooltip3" class="tooltip-info prompt">
<span class="tooltip-icon-border"></span>
<span class="tooltip-icon-bg"></span>
<span class="state"></span>
<span id="mess3" class="mess"></span>
</div>
</div>
</div>
</div>
<div>
<div>
<button type="submit" name="c12" id="submit1"
class="button-action large">注冊</button>
</div>
</div>
</form>

四、thinkphp自己主动验证

相关资料參考:http://doc.thinkphp.cn/manual/auto_validate.html

在UserModel定义验证规则

protected $_validate=array(
array('username','require','用户名不能为空!'),
array('username','','用户名已经存在',0,'unique',1),
array('username','/^[a-zA-Z][a-zA-Z0-9_]{1,19}$/','用户名不合法。'), array('email','require','邮箱不能为空!'),
array('email','email','邮箱格式不对!'),
array('email','','该邮箱已经注冊过!',0,'unique',1),
); protected $_auto = array(
array('password', 'md5', 1, 'function'), // 对password字段在新增的时候使md5函数处理
);

五、 使用ajax

用户输入username后。当输入框失去焦点时会触发blur事件。能够在这时候验证username输入是否正确

jQuery.post( url, [data], [callback], [type]
) :使用POST方式来进行异步请求

 參数:



url (String) : 发送请求的URL地址.



data (Map) : (可选) 要发送给server的数据。以 Keyalue 的键值对形式表示。

callback (Function) : (可选) 加载成功时回调函数(仅仅有当Response的返回状态是success才是调用该方法)。



type (String) : (可选)官方的说明是:Type of data to be sent。事实上应该为client请求的类型(JSON,XML,等等) 

$('#username').blur(
function() {
var username = $(this).val();
$.post("index.php/Home/Index/checkName", {
'username' : username//前一个username须要跟UserModel相应,即跟数据库字段相应
}, function(data) {
if (data == 0) {
error['username'] = 0;
$('#tooltip1').attr('class',
'tooltip-info visible-inline success');
} else {
error['username'] = 1;
$('#tooltip1').attr('class',
'tooltip-info visible-inline error');
$('#mess1').html(data);
}
})
});

password,反复password,邮箱验证类似

验证邮箱的时候须要注意,假设用户输入邮箱后,立马点击注冊button,这时候会同一时候运行注冊button的click事件,邮箱输入框的blur事件。因为邮箱验证是$.post是异步的,post还没有运行完,click事件里error['email']=1。不会运行$('#submit1').submit();所以这时候再设置一个标志error['submit'] = 0;0表示点击过注冊button,默觉得1,在邮箱blur回调函数中推断error['submit'] 是否等于0,即推断是否点击过,假设点击过。提交表单,假设没点击过,仅仅须要验证邮箱。

用户输入邮箱后。鼠标在屏幕上其它地方点击。仅仅运行blur,跟username。password情况一样。

六、server处理

public function checkName() {
$user = D ( 'user' );
if (! $user->create ()) {
exit ( $user->getError () );
} else {
echo 0;//这是回传给$.post的数据,相应上面的data
}
}

以上是单步验证username的方法。以下来看怎么把全部数据提交给server

七、 把全部数据提交给server

通过上面的html代码注意到这里用了一个form,以post方式提交表单。action指向server能处理的地址

点击注冊button时,先推断全部输入是否正确。假设正确,才运行提交表单

$('#submit1').click(function() {
if ($('#username').val() == '') {
$('#tooltip1').attr('class', 'tooltip-info visible-inline error');
$('#mess1').html("username不能为空!");
}
if ($('#password').val() == '') {
$('#tooltip2').attr('class', 'tooltip-info visible-inline error');
$('#mess2').html("密码不能为空!");
}
if ($('#repassword').val() == '') {
$('#tooltip22').attr('class', 'tooltip-info visible-inline error');
$('#mess22').html("确认密码不能为空!");
}
if ($('#email').val() == '') {
$('#tooltip3').attr('class', 'tooltip-info visible-inline error');
$('#mess3').html("邮箱不能为空!");
}
if (error['username'] == 1) {
var scroll_offset = $("#tooltip1").offset(); // 假设username验证失败。屏幕会滚动到username的位置。让用户又一次输入
$("body,html").animate({
scrollTop : scroll_offset.top
// 让body的scrollTop等于pos的top,就实现了滚动
}, 0);
return false;
} else if (error['password'] == 1) { return false;
} else if (error['email'] == 1) {
error['submit'] = 0;
return false;
} else {
$('#submit1').submit();
return true;
}
});

server端register方法接收全部数据,假设成功跳转到Home/index页面,假设失败。跳转到错误提示页面

public function register() {
$user = D ( 'user' );
if (! $user->create ()) {
dump ( $user->getError () );
}
$uid = $user->add (); if ($uid) {
$_SESSION ['username'] = $_POST ['username'];
$this->redirect ( 'Home/index' );
} else {
$this->error ( "注冊失败。" );
}
}

八、config.php配置

<?

php
return array(
/* 数据库配置 */
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => '127.0.0.1', // server地址
'DB_NAME' => 'thinkphp', // 数据库名
'DB_USER' => 'root', // username
'DB_PWD' => '123', // password
'DB_PORT' => '3306', // port
'DB_PREFIX' => 'tp_', // 数据库表前缀
);

源代码:http://download.csdn.net/detail/welovesunflower/8274521

Thinkphp+AJAX动态验证用户输入是否合法的更多相关文章

  1. 使用 jQuery Ajax 异步登录,并验证用户输入信息(maven)

    使用 jQuery Ajax 异步登录,并验证用户输入信息(maven) 本篇内容: (1)上一篇是使用同步的请求实现登录,并由 Servlet 决定登陆后下一步做哪些事情,本篇使用 jQuery A ...

  2. 表单验证:$tablePrefix(定义表前缀);$trueTableName = 'yonghu',找到真实表名(yonghu)表;create($attr,0)两个参数;批量验证(返回数组);ajax+动态验证表单

    *$tablePrefix是定义在Model中的,优先级大于配置文件中,如果项目中表前缀全部比如为"a_",并且在配置文件中定义了 'DB_PREFIX'=>'a_' 后期如 ...

  3. 每日学习心得:CustomValidator验证控件验证用户输入的字符长度、Linq 多字段分组统计、ASP.NET后台弹出confirm对话框,然后点击确定,执行一段代码

    2013-9-15 1.    CustomValidator验证控件验证用户输入的字符长度 在实际的开发中通常会遇到验证用户输入的字符长度的问题,通常的情况下,可以写一个js的脚本或者函数,在ASP ...

  4. 一般处理程序生成简单的图片验证码并通过html验证用户输入的验证码是否正确

    一般处理程序生成简单的图片验证码并通过html验证用户输入的验证码是否正确       最近没事研究了下验证码的的动态生成及通过cookie实现HTML页面对用户输入的验证码的校验,简要如下: 1.写 ...

  5. jsf服务器端验证用户输入

    服务器端验证用户输入数据步骤 1 html页面上插入要输入数据控件 <h:inputText size="10" value="#{commodityBean.fo ...

  6. 使用JavaScript验证用户输入的是否为正整数

    在项目开发中,需要使用JavaScript验证用户输入的是否为正整数. 方法一: var type="^[0-9]*[1-9][0-9]*$"; var r=new RegExp( ...

  7. JS高级---案例:验证用户输入的是不是中文名字

    案例:验证用户输入的是不是中文名字 [\u4e00-\u9fa5] <!DOCTYPE html> <html lang="en"> <head> ...

  8. JS高级---案例:验证用户输入的是不是邮箱

    案例:验证用户输入的是不是邮箱 <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  9. 制作登录页面,点击键盘的 Enter 键或者单击“登录”按钮,验证用户输入的邮箱和密码是否正确

    查看本章节 查看作业目录 需求说明: 制作登录页面 点击键盘的 Enter 键或者单击"登录"按钮,验证用户输入的邮箱和密码是否正确 实现思路: 准备登录的静态页面 在页面中嵌入脚 ...

随机推荐

  1. TZOJ 数据结构实验--循环队列

    描述 创建一个循环队列,队列元素个数为4.能够实现队列的初始化.入队列.出队列.求队列长度等操作. 循环队列数据类型定义如下: typedef struct{ int data[Max];    in ...

  2. Problem H: 零起点学算法87——打印所有低于平均分的分数

    #include<stdio.h> int main(){ ],b[]; while(scanf("%d",&n)!=EOF){ ; ;i<n;i++){ ...

  3. Understanding how SQL Server executes a query

    https://www.codeproject.com/Articles/630346/Understanding-how-SQL-Server-executes-a-query https://ww ...

  4. ubuntu12.04国内软件源

    手动修改方式: 163源 deb http://mirrors.163.com/ubuntu/ precise main restricted deb-src http://mirrors.163.c ...

  5. ENVI裁剪

    一.basic tools-->resize data进行规则裁剪 虽然是进行图像重采样工具,但也可以用于简单快速的裁剪 1. 选中要裁剪的图像: 对话框下面选择spatial subset(构 ...

  6. tomcat配置优化

    tomcat服务管理页面 http://192.168.1.249:8080/manager/status 找到下面的内容 "http-nio-8081"  (此处端口是根据自己实 ...

  7. Mac下php 5升级到php 7的步骤详解

    前言 在MAC OS X 10.11中php的版本是5.5的,近来一年多里,看到了很多关于php7介绍,以为php7增加了很多新特性,也删除了原来很多的老特性,所以一直以来并没想去尝试使用php7,但 ...

  8. Python学习:python网址收集

    Python学习网址收集: 语法学习:http://www.cnblogs.com/hongten/tag/python/             http://www.liaoxuefeng.com ...

  9. 【笔记】js 关于定时器的理解

    总所周知 js 里面的 setTimeout() 方法是用来设定某些功能在某段时间间隔之后执行的.但是今天看了高程对定时器的描述发现并不是这样. setTimeout(function(){ //.c ...

  10. linux ubuntu下abaqus-6.14安装破解完全指南

    本人亲测可用 目录 安装前准备 安装过程 机器配置 腾讯云服务器 ubuntu server 16.10 1.首先要在服务器上安装gui及相关依赖 sudo apt-get install ubunt ...