现在的位置: 首页 > 综合 > 正文

Ajax js 使用Ajax检测用户名是否存在

2013年01月31日 ⁄ 综合 ⁄ 共 4120字 ⁄ 字号 评论关闭

jsp页面:

Js代码
  1. <script type="text/javascript" language="javascript">   
  2.         var xmlHttp = false;   
  3.         try {   
  4.             xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");   
  5.         } catch (e) {   
  6.             try {   
  7.                 xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");   
  8.             } catch (e2) {   
  9.                 xmlHttp = false;   
  10.             }   
  11.         }   
  12.         if (!xmlHttp && typeof XMLHttpRequest != 'undefined') {   
  13.             xmlHttp = new XMLHttpRequest();   
  14.         }   
  15.            
  16.         //检测用户名是否存在   
  17.         function callServerCheckUname() {   
  18.             //通过GET方法请求,将请求封装在URL中
      
  19.             var uname = document.getElementById("u_name").value;   
  20.             xmlHttp.open("POST"'CheckUname?u_name='+uname);   
  21.             //设置服务器响应的处理方法   
  22.             xmlHttp.onreadystatechange = updatePageCheckUname;   
  23.             // 发送请求   
  24.             xmlHttp.send(null);   
  25.         }   
  26.         function updatePageCheckUname() {   
  27.             if (xmlHttp.readyState == 4) {   
  28.                 var response = xmlHttp.responseText;   
  29.                 if(response >= 1){   
  30.                     alert("用户名已存在!");   
  31.                 }else{   
  32.                     alert("可注册!");   
  33.                 }   
  34.             }   
  35.         }   
  36.         </script>  

web.xml配置文件:

Xml代码
  1. <servlet>  
  2.     <servlet-name>CheckUname</servlet-name>  
  3.     <servlet-class>servlet.AjaxCheckUname</servlet-class>  
  4.   </servlet>  
  5. <servlet-mapping>  
  6.     <servlet-name>CheckUname</servlet-name>  
  7.     <url-pattern>/CheckUname</url-pattern>  
  8.   </servlet-mapping>  

servlet页面:

Java代码
  1. public void doPost(HttpServletRequest request, HttpServletResponse response)   
  2.             throws ServletException, IOException {   
  3.         response.setContentType("text/html;charset=GB2312");   
  4.         PrintWriter out = response.getWriter();   
  5.         try {   
  6.             String uname = request.getParameter("u_name");   
  7.             RegistDAOImpl regDao = new RegistDAOImpl();   
  8.             out.print(regDao.checkUname(uname)) ;   
  9.         } catch (Exception e) {   
  10.         }   
  11.         out.flush();   
  12.         out.close();   
  13.     }  

DAO实现类:

Java代码
  1. public int checkUname(String uname){   
  2.         Connection conn = null;   
  3.         PreparedStatement pstm = null;   
  4.         ResultSet rs = null;   
  5.         int success = 0;   
  6.         String sql = "select u_name from u_info where u_name='"+uname+"' or u_mobtel='"+uname+"' or u_email='"+uname+"'";
      
  7.         try {   
  8.             conn = getConnection();   
  9.             pstm = conn.prepareStatement(sql);   
  10.             rs = pstm.executeQuery(sql);   
  11.             if(rs.next()){   
  12.                 success = 1;   
  13.             }   
  14.             return success;   
  15.         } catch (Exception e) {   
  16.             e.printStackTrace();   
  17.         } finally {   
  18.             try {   
  19.                 conn.close();   
  20.             } catch (Exception e) {   
  21.                 e.printStackTrace();   
  22.             }   
  23.         }   
  24.         return success;   
  25.     }  

抱歉!评论已关闭.