遇到用户注册等情况时,如果等用户输入所有信息,点击注册按钮提交后,再验证输入是否正确,体验很不好,而且很浪费用户的时间,增加注册成本,这里提供一个例子,演示了怎么使用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就行

1
2
3
4
5
6
7
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 ;

二、页面设计

三、HTML部分

view/Index/index.html

1
 
用户名:

密码:

确认密码:

邮箱:

注册

四、thinkphp自动验证

1
2
3
4
5
6
7
8
9
10
11
12
13
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

用户输入用户名后,当输入框失去焦点时会触发blur事件,可以在这时候验证用户名输入是否正确

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

参数:

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

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

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

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
$('#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);
                    }
                })
                return false;
            });

密码,重复密码,邮箱验证类似

验证邮箱的时候需要注意,如果用户输入邮箱后,立刻点击注册按钮,这时候会同时执行注册按钮的click事件,邮箱输入框的blur事件,由于邮箱验证是$.post是异步的,post还没有执行完,click事件里error['email']=1,不会执行$('#submit1').submit();所以这时候再设置一个标志error['submit'] = 0;0表示点击过注册按钮,默认为1,在邮箱blur回调函数中判断error['submit'] 是否等于0,即判断是否点击过,如果点击过,提交表单,如果没点击过,只需要验证邮箱。

用户输入邮箱后,鼠标在屏幕上其他地方点击,只执行blur,跟用户名,密码情况一样。

六、服务器处理

1
2
3
4
5
6
7
8
public function checkName() {
        $user = D ( 'user' );
        if (! $user->create ()) {
            exit ( $user->getError () );
        } else {
            echo 0;//这是回传给$.post的数据,对应上面的data
        }
    }

以上是单步验证用户名的方法,下面来看怎么把所有数据提交给服务器

七、 把所有数据提交给服务器

通过上面的html代码注意到这里用了一个form,以post方式提交表单,action指向服务器能处理的地址
点击注册按钮时,先判断所有输入是否正确,如果正确,才执行提交表单

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
31
32
33
34
35
$('#submit1').click(function() {
        if ($('#username').val() == '') {
            $('#tooltip1').attr('class', 'tooltip-info visible-inline error');
            $('#mess1').html(用户名不能为空!);
        }
        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(); // 如果用户名验证失败,屏幕会滚动到用户名的位置,让用户重新输入
            $(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 true;
        } else {           
            $('#submit1').submit();
            return true;
        }
    });

服务器端register方法接收所有数据,如果成功跳转到Home/index页面,如果失败,跳转到错误提示页面

1
2
3
4
5
6
7
8
9
10
11
12
13
14
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配置

1
2
3
4
5
6
7
8
9
10
11
<!--?php
return array(
     /* 数据库配置 */
    &#39;DB_TYPE&#39;   =--> 'mysql', // 数据库类型
    'DB_HOST'   => '127.0.0.1', // 服务器地址
    'DB_NAME'   => 'thinkphp', // 数据库名
    'DB_USER'   => 'root', // 用户名
    'DB_PWD'    => '123'// 密码
    'DB_PORT'   => '3306', // 端口
    'DB_PREFIX' => 'tp_', // 数据库表前缀
);

thinkphp 注册验证的更多相关文章

  1. thinkphp注册验证

    在model中新建一个UserModel //覆盖原本的设置 //一次性获得全部验证错误 protected $patchValidate = true; //实现表单项目验证 //通过重写父类属性_ ...

  2. thinkphp+jquery+ajax前后端交互注册验证

    thinkphp+jquery+ajax前后端交互注册验证,界面如下 register.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1. ...

  3. ThinkPHP 自动验证实例

    //array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),protected $_validate = array( ); ThinkPHP 自动验证定义的附加规则如下: r ...

  4. MVC中使用WebMail 发送注册验证信息

    在MVC中发送Email 可以使用WebMail :使用起来十分简单.如下: WebMail.SmtpServer = ConfigurationHelper.GetValue("SmtpS ...

  5. Ajax注册验证用户名是否存在 ——引自百度经验

    Ajax注册验证用户名是否存在 http://jingyan.baidu.com/article/a948d6515fdf870a2dcd2e85.html

  6. ThinkPHP 自动验证与自动填充无效可能的原因(转)

    自动验证与自动填充是在使用ThinkPHP时经常用到的功能,但偶尔会遇到自动验证与自动填充无效的情况,本文就ThinkPHP 自动验证与自动填充无效可能的原因做一些分析. create() Think ...

  7. <转>thinkphp自动验证无效的问题

    新手入门thinkphp,试用自动验证表单输入数据功能,却发现怎么都不能调用自动验证,自动验证无效,原因竟是一个小细节的疏忽,学习一定要细心啊! Action方法: IndexAction下的adds ...

  8. PHP+Ajax 异步通讯注册验证

    HTML代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  9. jQuery失去焦点的时候注册验证

    //注册验证$('form :input').blur(function () { if ($("#txtName").val() == "") { $(&qu ...

随机推荐

  1. 【CSS学习笔记】超链接标签

    有些网址后面为什么是#? 比如,href="http://www.xxx.com/index.html/#q2"标示网页index.html的q2位置处,浏览器读取这个URL后,会 ...

  2. app外包开发注意事项大全『最新』

    随着移动互联网的高速发展,很多互联网创业公司或传统向互联网转型的公司都急需发开一款app软件,多数公司会选择让外包公司来开发.问题来了,App外包市场鱼龙混杂,我们要如何在这里面选择一个靠谱的公司,这 ...

  3. putty连接远程局域网的MySql(不需要单独打开plink)

    3316 是本地端口,映射到远程内网的一台MySql主机 10.8.2.172

  4. D3.js

    html代码: <div id="id"> <p>Apple</p> <p id="aa">Pear</p ...

  5. [SQL基础教程] 5-1视图

    [SQL基础教程] 5-1视图 视图和表 从SQL角度看视图就是一张表 视图与表的差别 表保存了实际的数据,视图保存的是SELECT语句: 视图的优点 节省存储空间: 将常用的Select 语句保存成 ...

  6. js 设计模式-接口

    js模拟java接口检测函数:确保子类实现接口中的方法:(出自js设计模式) 上代码: <script type="text/javascript" > <%-- ...

  7. textfile 属性

    //设置textfile的Placeholder的颜色和字体大小 nameText.attributedPlaceholder = NSAttributedString.init(string: &q ...

  8. SQL 默认数据库被误删

    我今天也遇到了,自己解决了.这是我总结的:(不管这帖子沉到哪里了) 删除了SQL服务器默认数据库,无法连接服务器,用户[]登录失败. 1,使用管理员账户修改此用户的默认数据库.    企业管理器,展开 ...

  9. AngularJs中,如何在父元素中调用子元素为自定义Directive中定义的函数?

    最近一段时间准备使用AngularJs中的自定义Directive重构一下代码. 在这里说明一下,把自定义控件封装成Directive并不一定是要复用,而是要让代码结构更加清晰.就好像你将一个长方法拆 ...

  10. [Q]复制授权了文件但仍显示“未注册”问题(安装在非默认目录或目录包含中文)

    1. 注意要将解压后的文件复制到CAD批量打图精灵安装目录,而不要复制文件夹,复制是提示是否需要覆盖,要选择覆盖. 2. 若通过第1步操作仍然显示“未注册”,则可能是由于安装目录含有中文或者不是默认目 ...