1. ホーム
  2. Web プログラミング
  3. AJAX関連

AJAXを使ったユーザーログイン認証の手順(正規表現を含む)

2022-01-15 14:35:25

手順を分解してみましょう。

1. HTMLコード、ページが最初に書き出される。

2. 入力されたユーザー名パスワードが正しいかどうかを確認するための正規表現、フォーカスバリデーションを失う

3.Ajaxによる非同期送信

4. サーブレット これはデータを取得し、レスポンスを比較するためのバックグラウンド処理コードで、その後、成功ページにジャンプします。

効果

構造です。

コードは以下の通りです。

<%@ 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>username:</td>
  <td><input type="text" name="name" id="username"
  onblur="verifyName()" /></td>
 </tr>
 <tr>
  <td>password:</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="Submit login verification" /></td>
 </tr>
 </table>
 </center>
 </form>
 <script type="text/javascript">
 function verifyName() {
 //username verification
 var verifyName = document.getElementById("username").value;
 var name = /^[A-Z][0-9A-Za-z_][a-zA-Z0-9_]{5,19}$/; // capital letters starting with 6-20 characters (no symbols allowed but _ is allowed)
 if (!name.test(verifyName)) {
 //$("#username").after("<span>6-20 characters at the beginning of uppercase letters (no symbols allowed but _ is allowed)</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}$/; //Upper case beginning with mixed alphabetic symbols 8-15 digits
 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("Login failed! ");
  $("#mypwd").val("");
  $("#username").focus().select();
  }
  }
 });
 });
 });
 </script>
</body>
</html>

サーブレットコードです。

package com.chaz.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http;
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>

このページの成功ページへジャンプします。:

 Login successful! 

概要

上記は、AJAX(正規表現を含む)を使ってユーザーのログインステップを確認するための小さな紹介です、私はそれがあなたの助けになることを願っています、あなたが何か質問があれば、私にメッセージをください、私はすぐにみんなに返信します。BinaryDevelopのウェブサイトをサポートしてくださっている皆様に感謝いたします。
この記事がお役に立つと思われる方は、ご自由に転載してください!ソースを明記してください!ありがとうございます。