ajax实例2

login.jsp

<html>
  <head>
    <base href="<%=basePath%>">
   
    <title>My JSP 'login.jsp' starting page</title>
   
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <!--
 <link rel="stylesheet" type="text/css" href="styles.css">
 -->
 <script type="text/javascript">
 function createXMLHttpRequest(){
   if(window.XMLHttpRequest){//如果这个对象存在,说明是mozilla浏览器
    //基于mozilla的方式来创建对象
    XMLHttpReq = new XMLHttpRequest();
   }else{
    //IE浏览器
    if(window.ActiveXObject){
     try{
      XMLHttpReq = new ActiveXObject("Msxml2.XMLHTTP");
     }catch(e){
      try{
       XMLHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
      }catch(e){}
     }
    }//if
   }//else
  }//method
  
  //处理响应的回调函数
  function handleResponse(){
   //判断对象状态
   if(XMLHttpReq.readyState == 4){
    //信息已经成功返回了,下一步要处理信息。
    if(XMLHttpReq.status == 200){
     //说明返回的内容正确了,成功了。下一步就是ajax层判断处理返回结果
     //alert(200);
     var res = XMLHttpReq.responseText;//以XML格式获得响应
     document.getElementById("id1").innerHTML = res;
    }
   }
  }
  //处理响应的回调函数
  function handleResponse1(){
   //判断对象状态
   if(XMLHttpReq.readyState == 4){
    //信息已经成功返回了,下一步要处理信息。
    if(XMLHttpReq.status == 200){
     //说明返回的内容正确了,成功了。下一步就是ajax层判断处理返回结果
     //alert(200);
     var res = XMLHttpReq.responseText;//以XML格式获得响应
     document.getElementById("id2").innerHTML = res;
    }
   }
  }
  //处理响应的回调函数
  function handleResponse2(){
   //判断对象状态
   if(XMLHttpReq.readyState == 4){
    //信息已经成功返回了,下一步要处理信息。
    if(XMLHttpReq.status == 200){
     //说明返回的内容正确了,成功了。下一步就是ajax层判断处理返回结果
     //alert(200);
     var res = XMLHttpReq.responseText;//以XML格式获得响应
     document.getElementById("id3").innerHTML = res;
    }
   }
  }
  //发送请求函数
  function sendRequest(url){
   createXMLHttpRequest();
   
   XMLHttpReq.open("GET", url, true);//open方法没连服务器,只定义了连接条件
   //写一个函数主动地,不停地到服务器上拿结果
   XMLHttpReq.onreadystatechange = handleResponse;//当服务器状态发生改变时,用一个回调函数来主动的拿结果
   //真正的发送请求。
   XMLHttpReq.send(null);
   
  }
  function sendRequest1(url){
   createXMLHttpRequest();
   
   XMLHttpReq.open("GET", url, true);//open方法没连服务器,只定义了连接条件
   //写一个函数主动地,不停地到服务器上拿结果
   XMLHttpReq.onreadystatechange = handleResponse1;//当服务器状态发生改变时,用一个回调函数来主动的拿结果
   //真正的发送请求。
   XMLHttpReq.send(null);
   
  }
  function sendRequest2(url){
   createXMLHttpRequest();
   
   XMLHttpReq.open("GET", url, true);//open方法没连服务器,只定义了连接条件
   //写一个函数主动地,不停地到服务器上拿结果
   XMLHttpReq.onreadystatechange = handleResponse2;//当服务器状态发生改变时,用一个回调函数来主动的拿结果
   //真正的发送请求。
   XMLHttpReq.send(null);
   
  }
  
  function checkUname(){
   //取得要输入的值
   var uname = document.getElementById("uname").value;
   //把用户名当成请求的一部分发送出去。
   //alert(name);
   sendRequest("checkUnameServlet?uname="+uname);
  }
  function checkPwd(){
   //取得要输入的值
   var pwd = document.getElementById("pwd").value;
   //把密码当成请求的一部分发送出去。
   //alert(name);
   sendRequest1("checkPwdServlet?pwd="+pwd);
  }
  function checkEmail(){
   //取得要输入的值
   var email = document.getElementById("email").value;
   //把邮编当成请求的一部分发送出去。
   //alert(name);
   sendRequest2("checkEmailServlet?email="+email);
  }
 </script>
  </head>
 
  <body>
  <table>
    <tr><td>用户名:</td><td><input type="text" id="uname" onblur="checkUname()"></td><td><div id="id1"></div></td></tr>
   <tr><td>密&nbsp;&nbsp;码:</td><td><input type="text" id="pwd" onblur="checkPwd()"/></td><td><div id="id2"></div></td></tr>
    <tr><td>email:</td><td><input type="text" id="email" onblur="checkEmail()"></td><td><div id="id3"></div></td></tr>
    </table>
  </body>
</html>

checkUnameServlet.java

public class checkUnameServlet extends HttpServlet {

 
 public void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  
  List<String> list = new ArrayList<String>();
  list.add("z3");list.add("l4");list.add("w5");list.add("z6");
  list.add("ls");list.add("dk");list.add("gmf");list.add("cge");
  
  String str = request.getParameter("uname");
  response.setContentType("text/xml;charset=UTF-8");
  response.setHeader("Cache-Control", "no-cache");
  PrintWriter out = response.getWriter();
  if(str.length()>0){
   if(list.contains(str)){
    out.println("<font color='red'>该用户名已经存在,请重新输入</font>");
   }else{
    out.println("该用户名可用!");
   }
  }else{
   out.println("<font color='red'>用户名不能为空!</font>");
  }
  out.close();
 }

 

 checkPwdServlet.java


 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {

  doGet(request,response);
 }

}

public class checkPwdServlet extends HttpServlet {

 public void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {

  String str = request.getParameter("pwd");
  
  response.setContentType("text/xml;charset=UTF-8");
  response.setHeader("Cache-Control", "no-cache");
  PrintWriter out = response.getWriter();
  if(str.length()>=3&&str.length()<=6){
   out.println("密码合法!");
  }else{
   out.println("<font color='red'>密码长度不合法必须为3-6位字母数字组合");
  }
  out.close();
 }

 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {

  doGet(request,response);
 }

}

checkEmailServlet.java

public class checkEmailServlet extends HttpServlet {

 public void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {

  response.setContentType("text/xml;charset=UTF-8");
  response.setHeader("Cache-Control", "no-cache");
  String str= request.getParameter("email");
  
  PrintWriter out = response.getWriter();
  if(str.indexOf("@")!=-1){
   out.println("该邮箱名合法!");
  }else{
   out.println("<font color='red'>该邮箱名不合法,缺少@符号</font>");
  }
  out.close();
 }

 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {

  doGet(request,response);
 }

}

 

内容概要:本文深入探讨了Kotlin语言在函数式编程和跨平台开发方面的特性和优势,结合详细的代码案例,展示了Kotlin的核心技巧和应用场景。文章首先介绍了高阶函数和Lambda表达式的使用,解释了它们如何简化集合操作和回调函数处理。接着,详细讲解了Kotlin Multiplatform(KMP)的实现方式,包括共享模块的创建和平台特定模块的配置,展示了如何通过共享业务逻辑代码提高开发效率。最后,文章总结了Kotlin在Android开发、跨平台移动开发、后端开发和Web开发中的应用场景,并展望了其未来发展趋势,指出Kotlin将继续在函数式编程和跨平台开发领域不断完善和发展。; 适合人群:对函数式编程和跨平台开发感兴趣的开发者,尤其是有一定编程基础的Kotlin初学者和中级开发者。; 使用场景及目标:①理解Kotlin中高阶函数和Lambda表达式的使用方法及其在实际开发中的应用场景;②掌握Kotlin Multiplatform的实现方式,能够在多个平台上共享业务逻辑代码,提高开发效率;③了解Kotlin在不同开发领域的应用场景,为选择合适的技术栈提供参考。; 其他说明:本文不仅提供了理论知识,还结合了大量代码案例,帮助读者更好地理解和实践Kotlin的函数式编程特性和跨平台开发能力。建议读者在学习过程中动手实践代码案例,以加深理解和掌握。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值