AJAX简单的用户注册

今天张老师讲了简单使用ajax的用户注册校验,要实现一下的一些功能:要有用户名是否为空的校验。有确认密码与密码的匹配校验。
package com.ajax.action;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;

public class RegUserUIAction extends Action {

 public ActionForward execute(ActionMapping mapping, ActionForm form,
   HttpServletRequest request, HttpServletResponse response) {
  // TODO Auto-generated method stub
  String userName = request.getParameter("username");
  if(userName != null){
  String msg = "恭喜您,用户未被注册!";
  if("hhl".equals(userName)){
   msg = "很遗憾,用户名 已被注册";
  }
  request.setAttribute("msg", msg);
  }
  return mapping.findForward("logon");
 }
}

<%@ page language="java" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html:html lang="true">
  <head>

   
    <title>logon.jsp</title>
   <script type="text/javascript">
 function verifyUserName(userName)
 {
  var url = '<html:rewrite action="/RegUserUI"/>' + '?username=' + userName;
  window.location.href = url;
 }
 </script>

  </head>
 
  <body>
 
    <form method="post"> 
     用户名:<input type="text" id="username" name="username" value="${param.username }"/><a href="javascript:verifyUserName(document.getElementByIdx('username').value);void(0)">校验是否重名</a><br>
     <div>${msg}</div>
     密码 : <input type="password" name="password"><br>
     确认密码:<input type="password" name="password" /><br>
     <input type="submit" name="password" value="注册" />
    </form>
  </body>
</html:html>

struts-config.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.2//EN" "http://struts.apache.org/dtds/struts-config_1_2.dtd">

<struts-config>
  <data-sources />
  <form-beans />
  <global-exceptions />
  <global-forwards />
  <action-mappings >
    <action
      path="/RegUserUI"
      type="com.ajax.action.RegUserUIAction"
      validate="false">
      <forward name="logon" path="/WEB-INF/jsp/logon.jsp" />
    </action>

  </action-mappings>

  <message-resources parameter="com.ajax.ApplicationResources" />
</struts-config>
上面的一段是javascript的校验,并没有用到AJAX,内容还算是比较简单的!

 


下面这段用到了AJAX,张老师是用的prototype框架,现在比如像sina的邮箱网页就是用的这个框架的!
<%@ page language="java" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html:html lang="true">
  <head>
 <title>logon.jsp</title>
    <script type="text/javascript" src="${pageCotext.request.contextPath}/js/prototype.js"></script>
   <script type="text/javascript">
 function verifyUserName2(userName)
 {
  new Ajax.Updater('result',
  '<html:rewrite action="/RegUserUI"/>',
  { 
   parameters: { username: $('username').value }
   });
  
  
  
 
 }
注:上面的function是在prototype文档里面查的。直接copy过来修改下的。在ajax.update的里面的。通过跟着张老师的学习
渐渐的开始有了查找文档的习惯。
 function verifyUserName(userName)
 {
  var url = '<html:rewrite action="/RegUserUI"/>' + '?username=' + userName;
  //window.location.href = url;
  var xhr = createXHR();
  xhr.onreadystatechange = function(){
     //alert(xhr.responseText);
     //alert(xhr.readyState);
     if(xhr.readyState == 4 && xhr.status == 200)
     {
      document.getElementByIdx("result").innerHTML = xhr.responseText;
     }
    };
  xhr.open('GET',url,true);
  xhr.send();
 }
这下面的一段function是判断是否支持浏览器版本的!
 function createXHR(){
  var xmlhttp = null;
  if(window.XMLHttpRequest){
   this.xmlhttp = new XMLHttpRequest();
   if(window.overrideMineType){
    xmlhttp.overrideMimeType("text/xml");
   }
  }else if(window.ActiveXObject){
   var microsoft = ["MSXML2.XMLHTTP.6.0","MSXML2.XMLHTTP.5.0",
   "MSXML2.XMLHTTP.4.0","MSXML2.XMLHTTP.3.0",
   "MSXML2.XMLHTTP","Microsoft.XMLHTTP"];
    for(var i=0; i<microsoft.length; i++){
     try{
      xmlhttp = new ActiveXObject(microsoft[i]);
      break;
     }catch(e){
     }
    }
  }else{
   alert("Can't Create XMLHttpRequest Object");
  }
  return xmlhttp;
 }
 </script>
</head>
 
  <body>
 
    <form method="post"> 
     用户名:<input type="text" id="username" οnblur="verifyUserName2(this.value)" name="username" value="${param.username }"/><a href="javascript:verifyUserName(document.getElementByIdx('username').value);void(0)">校验是否重名</a><br>
     <div id="result">${msg}</div>
     密码 : <input type="password" name="password"><br>
     确认密码:<input type="password" name="password" /><br>
     <input type="submit" name="password" value="注册" />
    </form>
  </body>
</html:html>

 


package com.ajax.action;

import java.io.IOException;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;

public class RegUserUIAction extends Action {

 public ActionForward execute(ActionMapping mapping, ActionForm form,
   HttpServletRequest request, HttpServletResponse response) {
  // TODO Auto-generated method stub
  String userName = request.getParameter("username");
  if(userName != null){
  String msg = "恭喜您,用户未被注册!";
  if("hhl".equals(userName)){
   msg = "很遗憾,用户名 已被注册";
  }
  //request.setAttribute("msg", msg);
  response.setContentType("text/plain;charset=UTF-8");
  try {
   response.getWriter().print(msg);
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  return null;
  }
  return mapping.findForward("logon");
 }
}
使用AJXA和js最后得到的是一样的结果的!当然现在主流的ajax框架还有jquery。只要会了一种,其他的都可以触类旁通的!

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用AJAX实现用户注册可以提高效率,并且不需要刷新整个页面。一般情况下,需要定义四个参数来完成AJAX请求,它们分别是URL(要提交的servlet位置)、data(要发送的数据,可以是JSON格式)、callback(回调函数,要执行的内容)和type(返回值的类型,如XML、JSON、Text或HTML等)。 具体的实现步骤如下: 1. 新建一个JSP页面,并在页面头部引入必要的JavaScript和jQuery库文件。 2. 在表单中添加输入框,例如用户名输入框,设置其id和name属性。 3. 添加一个用于显示提示信息的span标签,设置其id。 4. 在表单的提交按钮上绑定点击事件,触发AJAX请求。 5. 在AJAX请求的回调函数中,根据返回的结果,在提示信息的span标签中显示相应的信息[3]。 通过这样的方式,当用户输入用户名并移开输入框时,AJAX会自动发送请求到后台,检查用户名是否已经存在,并在局部页面上反馈结果。这样不仅提高了效率,还能提供实时的用户反馈。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [AJAX原理及实现用户注册](https://blog.csdn.net/weixin_44784673/article/details/100849679)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [Ajax实现用户注册模块](https://download.csdn.net/download/kingson_wu/5538861)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值