欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaWeb實現(xiàn)用戶登錄與注冊功能

 更新時間:2021年08月23日 17:27:37   作者:奈何橋下的一道光線√  
這篇文章主要為大家詳細介紹了JavaWeb實現(xiàn)用戶登錄與注冊功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了JavaWeb實現(xiàn)用戶登錄與注冊的具體代碼,供大家參考,具體內(nèi)容如下

所用知識

客戶端:HTML CSS JS (JQuery)

服務(wù)器:JAVA基礎(chǔ)  JSP   Servlet  JDBC  Tomcat

數(shù)據(jù)庫:MySQL

用到的Jar包 druid數(shù)據(jù)庫連接池  dbutils JDBC數(shù)據(jù)庫操作工具  MySQL jar包

實現(xiàn)效果基本為注冊用戶,注冊成功將數(shù)據(jù)寫入數(shù)據(jù)庫,登錄過程查看數(shù)據(jù)庫中是的用戶名,密碼是否匹配,匹配跳轉(zhuǎn)到登錄成功頁面,失敗返回登錄頁面。

思路:

1、先寫前端登錄注冊界面,把前端的基本外觀框架完成

2、數(shù)據(jù)庫創(chuàng)建用戶信息表,儲存注冊用戶的信息

3、服務(wù)器部分采用JavaEE三層架構(gòu)

(1)、表現(xiàn)層:通俗講就是展現(xiàn)給用戶的界面,即用戶在使用一個系統(tǒng)的時候他的所見所得。
(2)、業(yè)務(wù)邏輯層:針對具體問題的操作,也可以說是對數(shù)據(jù)層的操作,對數(shù)據(jù)業(yè)務(wù)邏輯處理。
(3)、數(shù)據(jù)訪問層:該層所做事務(wù)直接操作數(shù)據(jù)庫,針對數(shù)據(jù)的增添、刪除、修改、查找等。

一、客戶端部分

文件存儲形式

實現(xiàn)代碼:

index.jsp主頁

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>首頁</title>
 <base href="http://localhost:8080/book_war_exploded/">
<link type="text/css" rel="stylesheet" href="static/css/style.css" >
</head>
<body>
 <div id="header">
   <img class="logo_img" alt="" src="static/img/logo.gif" >
   <div>
    <a href="pages/user/login.jsp" >登錄</a> |
    <a href="pages/user/regist.jsp" >注冊</a> &nbsp;&nbsp;
   </div>
 </div>
 <div id="bottom">
  <span>
   hunustNiu
  </span>
 </div>
</body>
</html>

login.jsp登錄界面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>登錄頁面</title>
 <base href="http://localhost:8080/book_war_exploded/">
<link type="text/css" rel="stylesheet" href="${pageContext.request.contextPath}/static/css/style.css" >
</head>
<body>
  <div id="login_header">
   <img class="logo_img" alt="" src="static/img/logo.gif" >
  </div>
  
   <div class="login_banner">
   
    <div id="l_content">
     <span class="login_word">歡迎登錄</span>
    </div>
    
    <div id="content">
     <div class="login_form">
      <div class="login_box">
       <div class="tit">
        <h1>會員</h1>
        <a href="pages/user/regist.jsp" >立即注冊</a>
       </div>
       <div class="msg_cont">
        <b></b>
        <span class="errorMsg">請輸入用戶名和密碼</span>
       </div>
       <div class="form">
        <form action="${pageContext.request.contextPath}/loginServletl" method="post">
         <label>用戶名稱:</label>
         <input class="itxt" type="text" placeholder="請輸入用戶名" autocomplete="off" tabindex="1" name="username" />
         <br />
         <br />
         <label>用戶密碼:</label>
         <input class="itxt" type="password" placeholder="請輸入密碼" autocomplete="off" tabindex="1" name="password" />
         <br />
         <br />
         <input type="submit" value="登錄" id="sub_btn" />
        </form>
       </div>
       
      </div>
     </div>
    </div>
   </div>
  <div id="bottom">
   <span>
    hunustNiu
   </span>
  </div>
</body>
</html>

regist.jsp 注冊頁面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8">
  <title>注冊頁面</title>
  <base href="http://localhost:8080/book_war_exploded/">
  <link type="text/css" rel="stylesheet" href="static/css/style.css" rel="external nofollow" rel="external nofollow" >
  <script type="text/javascript" src="static/jquery-1.7.2.js"></script>
  <script type="text/javascript">
   // 頁面加載完成之后
   $(function (){
    $("#sub_btn").click(function (){
     //判斷用戶名稱是否合法
     //獲取用戶昵稱
     var username=$("#username").val();
     //獲取用戶昵稱匹配的正則表達式
     var zzusername=/^\w{5,12}$/;
                    //如果不符合正則
     if(!zzusername.test(username)){
                     $("span.errorMsg").text("用戶名不合法");
                     return false;
     }
 
     //判斷用戶密碼是否合法
     //獲取用戶密碼
     var password=$("#password").val();
     //獲取用戶密碼匹配的正則表達式
     var zzpassword=/^[a-z0-9_-]{6,18}$/;
     //如果不符合正則
     if(!zzusername.test(username)){
      $("span.errorMsg").text("用戶密碼不合法");
      return false;
     }
 
     //確認密碼
     var repwd=$("#repwd").val();
     if(repwd!==password){
      $("span.errorMsg").text("兩次密碼不一致");
      return false;;
     }
 
     //電子郵件
     var email=$("#email").val();
     var zzemail=/[1-9]\d{7,10}@qq\.com/;
     if(!zzemail.test(email)){
      $("span.errorMsg").text("郵箱格式不符");
      return false;
     }
     //驗證碼
     //去掉驗證碼前后空格
     var code=$("#code").val();
     code=$.trim(code);
     if(code!=="6n6np"){
      $("span.errorMsg").text("驗證碼錯誤");
      return false;
     }
    });
   })
 
  </script>
 <style type="text/css">
  .login_form{
   height:420px;
   margin-top: 25px;
  }
 
 </style>
 </head>
 <body>
  <div id="login_header">
   <img class="logo_img" alt="" src="static/img/logo.gif" >
  </div>
 
   <div class="login_banner">
 
    <div id="l_content">
     <span class="login_word">歡迎注冊</span>
    </div>
 
    <div id="content">
     <div class="login_form">
      <div class="login_box">
       <div class="tit">
        <h1>注冊</h1>
        <span class="errorMsg"></span>
       </div>
       <div class="form">
        <form action="${pageContext.request.contextPath}/registServlet" method="post">
         <label>用戶名稱:</label>
         <input class="itxt" type="text" placeholder="請輸入用戶名"
             autocomplete="off" tabindex="1" name="username" id="username" />
         <br />
         <br />
         <label>用戶密碼:</label>
         <input class="itxt" type="password" placeholder="請輸入密碼"
             autocomplete="off" tabindex="1" name="password" id="password" />
         <br />
         <br />
         <label>確認密碼:</label>
         <input class="itxt" type="password" placeholder="確認密碼"
             autocomplete="off" tabindex="1" name="repwd" id="repwd" />
         <br />
         <br />
         <label>電子郵件:</label>
         <input class="itxt" type="text" placeholder="請輸入郵箱地址"
             autocomplete="off" tabindex="1" name="email" id="email" />
         <br />
         <br />
         <label>驗證碼:</label>
         <input class="itxt" type="text" style="width: 150px;" id="code" name="code"/>
         <img alt="" src="static/img/code.bmp" style="float: right; margin-right: 40px">
         <br />
         <br />
         <input type="submit" value="注冊" id="sub_btn" />
        </form>
       </div>
 
      </div>
     </div>
    </div>
   </div>
  <div id="bottom">
   <span>
    hunustNiu
   </span>
  </div>
 </body>
</html>

login_succe.jsp 和regist_success.jsp功能目前只是返回首頁和退出登錄

 <div id="header">
    <img class="logo_img" alt="" src="static/img/logo.gif" >
    <div>
     <a href="index.jsp" >注銷</a>&nbsp;&nbsp;
     <a href="index.jsp" >返回</a>
    </div>
  </div>
  <div id="main">
   <h1>歡迎回來 <a href="index.jsp">轉(zhuǎn)到主頁</a></h1>
</div>

二、數(shù)據(jù)庫部分

文件存儲形式

 

實現(xiàn)代碼:

CREATE DATABASE users
CREATE TABLE users(
   id INT PRIMARY KEY AUTO_INCREMENT,
   username VARCHAR(25) UNIQUE,
   PASSWORD VARCHAR(25),
   email VARCHAR(30) UNIQUE
)
 
SELECT *FROM `users`
INSERT INTO `users`(`username`,`password`,`email`) VALUES('niu123','niu123','190177@qq.com')/*初始測試數(shù)據(jù)*/

三、服務(wù)器部分

點擊查看:文章鏈接

問題總結(jié)

1、客戶端部分遇到的bug首先就是在注冊,登錄,主頁之間進行頁面跳轉(zhuǎn)的過程中由于沒有加入<base>標簽總是在一個網(wǎng)頁可以顯示跳到另一個頁面就會產(chǎn)生404錯誤,通過將所有頁面<base>標簽固定為<base href="http://localhost:8080/book_war_exploded/">統(tǒng)一跳轉(zhuǎn)的基準以解決。

2、利用JQuery在注冊頁面判斷注冊結(jié)果是否符合注冊的格式要求,采用正則表達式進行判斷。

3、數(shù)據(jù)庫中的郵箱信息,在注冊過程中不能重復(fù)。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot靜態(tài)資源與首頁配置實現(xiàn)原理深入分析

    SpringBoot靜態(tài)資源與首頁配置實現(xiàn)原理深入分析

    最近在做SpringBoot項目的時候遇到了“白頁”問題,通過查資料對SpringBoot訪問靜態(tài)資源做了總結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習吧
    2022-10-10
  • SpringMVC?@RequestMapping注解屬性詳細介紹

    SpringMVC?@RequestMapping注解屬性詳細介紹

    通過@RequestMapping注解可以定義不同的處理器映射規(guī)則,下面這篇文章主要給大家介紹了關(guān)于SpringMVC中@RequestMapping注解用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Java如何使用Jetty實現(xiàn)嵌入式的Servlet容器

    Java如何使用Jetty實現(xiàn)嵌入式的Servlet容器

    這篇文章主要介紹了Java使用Jetty實現(xiàn)嵌入式的Servlet容器,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,下面我們來一起了解一下吧
    2019-06-06
  • 解決mybatis plus 駝峰式命名規(guī)則問題

    解決mybatis plus 駝峰式命名規(guī)則問題

    這篇文章主要介紹了解決mybatis plus 駝峰式命名規(guī)則,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2020-09-09
  • Java虛擬機內(nèi)存區(qū)域劃分詳解

    Java虛擬機內(nèi)存區(qū)域劃分詳解

    這篇文章主要介紹了Java虛擬機內(nèi)存區(qū)域劃分,本文邏輯清晰,可以幫助我們更好的掌握虛擬機,對我們學(xué)習java來說是一種幫助,需要的朋友可以參考下
    2021-04-04
  • Java FileWriter輸出換行操作

    Java FileWriter輸出換行操作

    這篇文章主要介紹了Java FileWriter輸出換行操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • zookeeper實戰(zhàn)之實現(xiàn)分布式鎖的方法

    zookeeper實戰(zhàn)之實現(xiàn)分布式鎖的方法

    Zookeeper實現(xiàn)分布式鎖比Redis簡單,Zookeeper有一個特性,多個線程在Zookeeper里創(chuàng)建同一個節(jié)點時,只有一個線程執(zhí)行成功,Zookeeper主要是利用臨時有序節(jié)點這一特性實現(xiàn)分布式鎖,感興趣的朋友跟隨小編一起學(xué)習吧
    2022-11-11
  • SpringBoot?整合Security權(quán)限控制的初步配置

    SpringBoot?整合Security權(quán)限控制的初步配置

    這篇文章主要為大家介紹了SpringBoot?整合Security權(quán)限控制的初步配置實例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 淺談一下JVM垃圾回收算法

    淺談一下JVM垃圾回收算法

    這篇文章主要介紹了一下JVM垃圾回收算法,Java有著自己一套的內(nèi)存管理機制,不需要開發(fā)者去手動釋放內(nèi)存,開發(fā)者只需要寫好代碼即可,運行過程中產(chǎn)生的垃圾都由JVM回收,需要的朋友可以參考下
    2023-04-04
  • Java WeakHashMap案例詳解

    Java WeakHashMap案例詳解

    這篇文章主要介紹了Java WeakHashMap案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08

最新評論