使用AJAX(包含正则表达式)验证用户登录的步骤

 更新时间:2019年10月25日 14:08:47   作者:ChenChaim  
这篇文章主要介绍了使用AJAX(包含正则表达式)验证用户登录的步骤,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

我们来分一下步骤吧:

1.HTML代码,页面先写出来;

2.正则表达式验证输入的用户名密码是否正确,失去焦点验证

3.Ajax异步提交

4.servlet这是后台处理代码获取数据并对比响应,然后跳转成功页面

效果图:

结构:

代码如下:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<script type="text/javascript" src="JS/jQuery.js"></script>
<style type="text/css">
table {
 width: 360px;
 height: 45px: 
 text-align: center;
 margin-top: 120px;
 border-collapse: collapse;
}

input {
 width: 280px;
 height: 30px;
}
</style>
</head>
<body>
 <form action="#" method="post">
 <center>
 <table align="center" border="1">
 <tr>
  <td>用户名:</td>
  <td><input type="text" name="name" id="username"
  onblur="verifyName()" /></td>
 </tr>
 <tr>
  <td>密码:</td>
  <td><input type="text" name="pwd" id="mypwd"
  onblur="verifyPwd()" /></td>
 </tr>
 <tr>
  <td colspan="3" align="center" height="36px"><input
  type="button" style="width: 8rem;height:27px" value="提交登录验证" /></td>
 </tr>
 </table>
 </center>
 </form>
 <script type="text/javascript">
 function verifyName() {
 //用户名校验
 var verifyName = document.getElementById("username").value;
 var name = /^[A-Z][0-9A-Za-z_][a-zA-Z0-9_]{5,19}$/; // 大写字母开头 6-20位字符(不允许有符号但是允许有_)
 if (!name.test(verifyName)) {
 //$("#username").after("<span>大写字母开头6-20位字符(不允许有符号但是允许有_)</span>");
 $("#username").css("border-color", "red");
 return false;
 } else {
 return true;
 }
 }
 function verifyPwd() {
 //密码
 var verifyPwd = document.getElementById("mypwd").value;
 var pwd = /^[A-Z][A-Za-z0-9]\w{7,14}.{1,20}$/; //大写开头 数字字母符号混合 8-15位
 if (!pwd.test(verifyPwd)) {
 $("#username").css("border-color", "red");
 return false;
 } else {
 return true;
 }
 }
 
 $(function() {
 $(":button").on("click", function() {
 $.ajax({
  type : "post",
  url : "AJAXServlet",
  data : {
  name : $("#username").val(),
  pwd : $("#mypwd").val()
  },
  dataType : "text",
  success : function(data) {
  if (data == "ok") {
  window.location.href = "show.jsp";
  } else {
  alert("登录失败!");
  $("#mypwd").val("");
  $("#username").focus().select();
  }
  }
 });
 });
 });
 </script>
</body>
</html>

servlet代码:

package com.chaz.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class AJAXServlet extends HttpServlet {
 public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
 doPost(request, response);
 }
 public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
 response.setContentType("text/html;charset=utf-8");
 request.setCharacterEncoding("utf-8");
 PrintWriter out = response.getWriter();
 
 String name = "ZhangSan";
 String pwd = "Zhang123456";
 
 String ajaxName = request.getParameter("name");
 String ajaxPwd = request.getParameter("pwd");
 System.out.println(ajaxName+":"+ajaxPwd);
 if(name.equals(ajaxName)&&pwd.equals(ajaxPwd)){
 out.print("ok");
 }else{
 out.print("Error");
 }
 out.flush();
 out.close();
 }
}

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0"
 xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
 <servlet>
 <description>This is the description of my J2EE component</description>
 <display-name>This is the display name of my J2EE component</display-name>
 <servlet-name>AJAXServlet</servlet-name>
 <servlet-class>com.chaz.servlet.AJAXServlet</servlet-class>
 </servlet>

 <servlet-mapping>
 <servlet-name>AJAXServlet</servlet-name>
 <url-pattern>/AJAXServlet</url-pattern>
 </servlet-mapping>

</web-app>

跳转成功页面就这个😄:

<body> 登录成功!</body>

总结

以上所述是小编给大家介绍的使用AJAX(包含正则表达式)验证用户登录的步骤,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

相关文章

  • 深入浅析AjaxFileUpload实现单个文件的 Ajax 文件上传库

    深入浅析AjaxFileUpload实现单个文件的 Ajax 文件上传库

    jQuery.AjaxFileUpload.js是一款jQuery插件,用于通过ajax上传文件。本文给大家介绍AjaxFileUpload实现单个文件的 Ajax 文件上传库,对此感兴趣的朋友一起学习吧
    2016-04-04
  • AJax与Jsonp跨域访问问题小结

    AJax与Jsonp跨域访问问题小结

    本文给大家汇总介绍了JavaScript的AJax,JQuery的AJax以及利用jsonp实现跨域访问的问题,非常的细致全面,有需要的小伙伴可以参考下。
    2015-12-12
  • js跨域调用WebService的简单实例

    js跨域调用WebService的简单实例

    下面小编就为大家带来一篇js跨域调用WebService的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • ajax post下载flask文件流以及中文文件名问题

    ajax post下载flask文件流以及中文文件名问题

    这篇文章主要介绍了ajax post下载flask文件流以及中文文件名问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • 利用XMLHTTP实现的二级连动Select

    利用XMLHTTP实现的二级连动Select

    利用XMLHTTP实现的二级连动Select...
    2006-09-09
  • Jquery中ajax提交表单几种方法(get、post两种方法)

    Jquery中ajax提交表单几种方法(get、post两种方法)

    ajax技术带给我们的是良好的用户体验,同时,使用jquery可以简化开发,提高工作效率,接下来,脚本之家小编给大家分享Jquery中ajax提交表单几种方法,需要的朋友可以参考下
    2015-09-09
  • jquery中的ajax异步上传

    jquery中的ajax异步上传

    本篇文章给大家介绍jquery中的ajax异步上传,在此需要引入ajaxfileupload.js这个js文件。接下来,有需要的朋友跟着小编一起学习吧
    2015-09-09
  • AJAX 支持搜索引擎问题分析

    AJAX 支持搜索引擎问题分析

    AJAX是利用浏览器的两个内置对象实现了,异步传输,说白了,页面不刷新对后台请求功能,现在市面上有很多AJAX框架,我就不一一列举了。
    2009-02-02
  • jquery ajax实现文件上传功能实例代码

    jquery ajax实现文件上传功能实例代码

    这篇文章主要介绍了jquery ajax实现文件拖拽上传功能的实例代码,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-04-04
  • 简单谈谈AJAX核心对象

    简单谈谈AJAX核心对象

    核心对象是XMLHttpRequest,它可以提供不重新加载页面的情况下更新网页,在页面加载后在客户端向服务器请求数据,在页面加载后在服务器端接受数据,在后台向客户端发送数据。
    2015-11-11

最新评论