详细请参考源码(Github):https://github.com/QQ3330447288/ajaxRegister

1、目录结构

2、截图

3、核心代码:

register.jsp

<script>
  var code = "";
  var nameIsOk = false;
  var codeIsOK = false;
  //检查账号是否已经存在
  function checkUserName(input) {
    //alert(input.value);
    var name = input.value;
    $.post("<%=path%>/checkUserName.action", {
      userName : name
    }, function(data) {
      //alert(data);
      if (data == 1) {
        $('#tip').html("当前账号已经存在!");
        nameIsOk = false;
      } else {
        $('#tip').html("");
        nameIsOk = true;
      }
    });
  }
  //生成随机验证码
  function createCode(sum) {
    code = "";
    for (var i = 0; i <sum; i++) {
      var num = parseInt(Math.random() * 10) % 10;
      code += num;
    }
    return code;
  }

  //发送随机验证码给短信服务商
  function sendCode(input) {
    var phone = $("#phone").val();
    var pattern = /^1[34578]\d{9}$/;
    if(phone==""||phone==null||!pattern.test(phone)){
      alert("手机号为空或格式错误!");
      return;
    }else{
      input.setAttribute("disabled", "disabled");
      var count = 60;
      var time = setInterval(function(){
      input.value=count+"s";
      count--;
      if(count<0){
        input.removeAttribute("disabled");
        clearInterval(time);
        input.value="发送";
      }
    },1000);
    //生成6位验证码
    var code = createCode(6);
    //alert(code);
    $.post("<%=path%>/sendCode.action", {
      phone : phone,
      code : code
    }, function(data) {

    });
  }
  }
  //注册功能实现
  function register() {
    var userName = $("#userName").val();
    var pwd = $("#pwd").val();
    var pwd_sure = $("#pwd_sure").val();
    var phone = $("#phone").val();
    var codeInput = $("#codeInput").val();
    var pattern = /^1[34578]\d{9}$/;
    if($.trim(userName)==""||userName==null){
      alert("用户名不能为空!");
      return;
    }else if(pwd==""||pwd==null){
      alert("密码不能为空!");
      return;
    }else if(pwd.length<6){
      alert("密码至少6位!");
      return;
    }
    else if(pwd_sure==""){
      alert("确认密码不能为空!");
      return;
    }
    else if(pwd != pwd_sure){
      alert("两次输入密码不一致!");
      return;
    }else if(phone==""||phone==null){
      alert("手机号码不能为空!");
      return;
    }
    else if(!pattern.test(phone)){
      alert("手机号格式不正确!");
      return;
    }else if(codeInput==""||codeInput==null){
      alert("验证码不能为空!");
      return;
    }
    if(code == codeInput){
      //alert("验证码输入正确!");
      codeIsOK = true;
      //alert(codeIsOK);
    }else{
      alert("验证码输入错误!");
      codeIsOK = false;
    }
    //alert(nameIsOk);
    //alert(codeIsOK);
    if(nameIsOk==true&&codeIsOK==true){
      //alert(1);
      $.post("<%=path%>/addUser.action", {
        userName:userName,
        pwd : pwd,
        phone : phone
      },function(data){
        //alert(data);
        if(data==1){
          alert("注册成功!");
          window.location.href="<%=path%>/page/home/login.jsp";
        }else{
          alert("注册失败!");
        }
      });
    }
  }
  //键盘回车提交表单
  /*
  $(document).ready(function() {
    $(document).keydown(function(event) {
      if (event.keycode == 13) {
        register();
      }
    })
  })
  */
</script>

CheckUserAction.java:

  public class CheckUserAction extends ActionSupport {
  /**
  * 查看是否已经存在
  * @throws IOException
  */
  public void checkUserName() throws IOException {
    // ServletActionContext类来自strut2-core-2.1.6.jar
    // 获取request对象
    HttpServletRequest request = ServletActionContext.getRequest();
    String userName = request.getParameter("userName");
    // System.out.println(userName);
    // 获取response对象
    HttpServletResponse response = ServletActionContext.getResponse();
    // 设置response返回数据内容的编码
    response.setContentType("text/html,charset=utf-8");
    PrintWriter out = response.getWriter();
    // out.print(111);
    if (isExists(userName)) {
      out.print("1");
    } else {
      out.print("0");
    }
    out.flush();
    out.close();
  }

  public Boolean isExists(String userName) {
    String sql = "SELECT *FROM user WHERE username=?";
    BaseDao baseDao = new BaseDao();
    List<Object> param = new ArrayList<Object>();
    param.add(userName);
    try {
      List<User> list = baseDao.getModelsWidthSqlAndParam(sql, param, new User());
      if (list.size() > 0) {
        return true;
      } else {
        return false;
      }
    } catch (Exception e) {
      e.printStackTrace();
    }  
    return false;
  }
}

SendCodeAction.java:

  public class SendCodeAction extends ActionSupport {
    public void sendCode() {
      HttpServletRequest request = ServletActionContext.getRequest();
      String code = request.getParameter("code");
      String phone = request.getParameter("phone");
      // System.out.println(code);
      // System.out.println(phone);
      SDKDemo.sendCodeWithTel(phone, code);
    }
  }

 

AddUserAction.java:

  public class AddUserAction extends ActionSupport {
    public void addUser() throws IOException {
      HttpServletRequest request = ServletActionContext.getRequest();
      String userName = request.getParameter("userName");
      String pwd = Md5.md5(request.getParameter("pwd"), "Thanlon");
      // System.out.println(pwd);
      String phone = Md5.md5(request.getParameter("phone"), "Thanlon");
      HttpServletResponse response = ServletActionContext.getResponse();
      response.setContentType("text/html;charset=utf-8");
      PrintWriter out = response.getWriter();
      // System.out.println(userName+phone+pwd);
      if (iSaddUser(userName, pwd, phone)) {
        out.print(1);
      } else {
        out.print(0);
      }
      out.flush();
      out.close();
    }

    private Boolean iSaddUser(String userName, String pwd, String phone) {
      String sql = "INSERT user(username,pwd,phone) VALUES(?,?,?)";
      List<Object> parames = new ArrayList<Object>();
      parames.add(userName);
      parames.add(pwd);
      parames.add(phone);
      BaseDao dao = new BaseDao();
      try {
        int count = dao.executeUpdate(sql, parames);
        return count > 0;
      } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
      return false;
    }
  }

文章难免会有纰漏之处,还望热心业内人士能给出修改的意见或者建议。
版权声明:本文为博主原创,转载请注明出处。

Ajax+Struts2用户注册功能实现的更多相关文章

  1. Ajax+Struts2实现验证码验证功能

    ---------------------------------------------------------------------------------------------------- ...

  2. JQuery+Ajax+Struts2+Hibernate 实现完整的登录注册

    写在最前: 下午有招聘会,不想去,总觉得没有准备好,而且都是一些不对口的公司,可是又静不下心来,就来写个博客. 最近在仿造一个书城的网站:http://www.yousuu.com ,UI直接拿来用, ...

  3. JavaWeb_(Hibernate框架)使用Hibernate开发用户注册功能

    使用Hibernate开发用户注册功能: 用户在register.jsp表单成功后,页面跳转到login.html,数据库中会存放用户注册的信息 <%@ page language=" ...

  4. JavaWeb_(Hibernate框架)使用c3p0与Dbutils开发用户注册功能

    使用c3p0与Dbutils开发用户注册功能: 用户在register.jsp表单成功后,页面跳转到login.html,数据库中会存放用户注册的信息 <%@ page language=&qu ...

  5. Django项目: 3.用户注册功能

    本章内容的补充知识点 导入库的良好顺序: 1.系统库 2.django库 3.自己定义的库(第三方库) redis缓存数据库的数据调用速度快,但是不利于长时间保存. mysql用于长时间存储,但是调用 ...

  6. Web---创建Servlet的3种方式、简单的用户注册功能

    说明: 创建Servlet的方式,在上篇博客中,已经用了方式1(实现Servlet接口),接下来本节讲的是另外2种方式. 上篇博客地址:http://blog.csdn.net/qq_26525215 ...

  7. ajax实现下载功能

    ajax实现下载功能 适用场景:由于点击按钮下载excel响应时间过长,此时间段加入加载样式(灰色层.加载动画): 浏览器弹出下载框后,上面的加载样式去掉.  方     法 :使用jquery.fi ...

  8. ajax 实现修改功能

    这段时间在做项目,发现自己忘得好快呀,幸亏有博客园帮我记着呢,整理博客园简直不要太重要了哦  因为做的是一个内部管理系统,只用了一个主页面,所有的都不允许整个网页刷新,所以我们只能用ajax 来做,当 ...

  9. 利用 FormData 对象和 Spring MVC 配合可以实现Ajax文件上载功能

    Ajax文件上载 利用 FormData 对象和 Spring MVC 配合可以实现Ajax文件上载功能: 步骤 导入组件并准备静态脚本 <dependency> <groupId& ...

随机推荐

  1. Ext 修改内容之后 不做任何动作 再次修改时的数据是原来第一次修改前的数据

    转自  http://blog.csdn.net/jaune161/article/details/18220257 在项目开发中遇到这样一个问题,点击Grid中的一条记录并修改,修改完后保存并且刷新 ...

  2. ZBX_NOTSUPPORTED: Cannot obtain filesystem information: [13] Permission denied

    zabbix有默认两条自动发现规则,其中一条是自动发现已挂载文件系统,但笔者的三个挂载文件系统中两个监控成功了,一个失败 agentd端挂载情况: 仔细研究sdb1的挂载点,发现它是挂载在xiami用 ...

  3. Tomcat不加项目名称访问设置

    一.Tomcat不加项目名称访问设置 一.方法一:修改配置文件server.xml 1.修改配置文件server.xml <Host appBase="webapps" au ...

  4. Java 基础 IO流

    一,前言 在前面的学习过程中,我们一直都是在操作文件或者文件夹,并没有给文件中写任何数据.现在我们就要开始给文件中写数据,或者读取文件中的数据. 二,字节流 2.1 字节输出流 OutputStrea ...

  5. zabbix-agent 在SElinux Enforcing 状态的文件权限问题及解决办法

    因为某种原因必须要开启SElinux,用yum装了一个zabbix-agent 替换了一下配置文件结果悲剧了 # systemctl restart zabbix-agent ● zabbix-age ...

  6. IP-v4&IP-v6

    IPv6与IPv4区别: 1:IPv6的地址空间更大.IPv4中规定IP地址长度为32,即有2^32-1个地址: 而IPv6中IP地址的长度为128,即有2^128-1个地址. 2.IPv6的路由表更 ...

  7. axios的基本概念及安装配置方法

    ajax:异步请求,是一种无需再重新加载整个网页的情况下,能够更新部分网页的技术 axios:用于浏览器和node.js的基于promise的HTTP客户端 1.从浏览器制作XMLHttpReques ...

  8. 从AST编译解析谈到写babel插件

    之前一直在掘金上看到一些关于面试写babel插件的文章,最近也在学,以下就是学习后的总结. 关键词:AST编译解析, babel AST编译解析 AST[维基百科]:在计算机科学中,抽象语法树(Abs ...

  9. sitecore开发入门之Sitecore字典结构最佳实践

    使用Sitecore时,一个重要的主题是如何为您的网站处理不同的语言和区域.Sitecore对此的回答是使用字典项,它基本上只代表键/值定义.但是,这个字典项可以设置为具有不同的语言版本,这几乎允许您 ...

  10. [openjudge-动态规划]滑雪

    题目描述 描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.Michael想知道载一个区 ...