国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Servlet+JavaBean+JSP打造Java Web注冊與登錄功能

Servlet+JavaBean+JSP打造Java Web注冊與登錄功能

2020-05-05 14:47xing JAVA教程

比作MVC的話,控制器部分采用Servlet來實現,模型部分采用JavaBean來實現,而大部分的視圖采用Jsp頁面來實現,接下來我們就來詳細看看如何用Servlet+JavaBean+JSP打造Java Web注冊與登錄功能

采用Java Web所實現的MVC結構圖如下,其中控制器部分采用Servlet來實現,模型部分采用JavaBean來實現,而大部分的視圖采用Jsp頁面來實現。

思想基礎
JSP+JavaBean兩層結構工作原理應該是比較熟悉的,也比較好理解。
但是有一點必須要清楚就是用戶通過瀏覽器來發送網頁的請求,此請求到達服務器后在服務器端查找對應的網頁,如果是首次請求(第二次就不用解釋執行了),對于JSP來說要生成Servlet,然后通過Servlet引擎來執行 Servlet,把調用JavaBean的結果嵌入到頁面中返回給用戶的瀏覽器。
JSP+JavaBean+Servlet三層結構的實質是多了一個Controller:Servlet來分發客戶端瀏覽器的請求。如果把起控制器作用的Servlet的作用理解為對客戶端的請求進行預處理對理解Servlet將有很大的幫助。通過web.xml配置文件可以找到用戶請求和特定的 Servlet的對應關系,每個Servlet都有一個特定的Servlet對象與之對應,所以說處理用戶請求的就是一個繼承自HttpServlet的 Servlet對象。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
﹤!-- JSPC servlet mappings start --﹥
  ﹤servlet﹥
    ﹤servlet-name﹥ms1﹤/servlet-name﹥
    ﹤servlet-class﹥news.FirstAction﹤/servlet-class
  ﹤/servlet﹥
 
  ﹤servlet﹥
    ﹤servlet-name﹥ms2﹤/servlet-name﹥
    ﹤servlet-class﹥news.DetailAction﹤/servlet-class
  ﹤/servlet﹥
﹤!-- JSPC servlet mappings end --﹥
  ﹤servlet-mapping﹥
    ﹤servlet-name﹥ms1﹤/servlet-name﹥
    ﹤url-pattern﹥/newsmain﹤/url-pattern﹥
  ﹤/servlet-mapping﹥
 
  ﹤servlet-mapping﹥
    ﹤servlet-name﹥ms2﹤/servlet-name﹥
    ﹤url-pattern﹥/newsDetail﹤/url-pattern﹥
  ﹤/servlet-mapping﹥

如上面所示的摘自web.xml的一段配置servlet,第一部分主要用來配置 Servlet與具體的Servlet對象關聯,第二部分主要用來配置請求由哪個Servlet處理,Servlet名字的關聯,處理請求就與具體 Servlet處理對象關聯起來,比如說,客戶端瀏覽器發來/newsmain的請求,它由ms1 servlet進行處理,通過ms1就能找到相對應的serlet對象news.FirstAction,即 /newsmain-﹥ms1-﹥news.FirstAction,這也就是配置文件的意義所在。到現在懂得了用戶/newsmain請求會被news.FirstAction類的對象進行處理,所以說,要看懂程序就要看懂FirstAction的作用是什么就行了。比如說下面是 FirstAction的一個實現。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public final class FirstAction extends HttpServlet {
 protected void service(HttpServletRequest req, HttpServletResponse resp)
  throws ServletException, IOException {
 
 DB db = new DB();
 HttpSession session = req.getSession();
 
 try {
  session.setAttribute(Constants.NEWS_LIST_KEY, News
   .SearchNewsTitle(db));
 } catch (Exception e) {
  e.printStackTrace();
 }
 
 db.close();
 String target = "/P43_News/newsMain.jsp";
 resp.sendRedirect(target);
 }
 
}

通過這個實現可以看到,當服務器收到客戶端請求執行 News.SearchNewsTitle(db)的操作,然后把返回值通過session.setAttribute放到session里,然后通過 resp.sendRedirect(target)間接轉移到newsMain.jsp,這樣在newsMain.jsp里通過 session.getAttribute函數就可以得到在存儲在session里的對應值。
回過頭來就容易看出JSP+JavaBean工作原理和JSP+JavaBean+Servlet工作原理的不同了,兩層結構必須把預處理放在JSP中進行,比如說 News.SearchNewsTitle(db),三層結構先把預處理在Servlet里進行了,然后相當于把這個處理結果通過Session返回給 JSP,讓JSP更關注于界面的顯示。

登陸注冊模塊需求
1 注冊
1.1 用戶的注冊表單(用戶名,密碼,郵箱,昵稱,驗證碼)
1.2 提交注冊:要做(用戶名,密碼,郵箱,昵稱,驗證碼)的校驗。
1.2.1 用戶名,密碼,郵箱,昵稱是在客戶端瀏覽器完成的,通過JS來實現。
1.2.2 驗證碼的是要在服務器端的程序完成的。
2.如果注冊表單的校驗通過, 那么就進行業務邏輯的判斷。
2.1 如果用戶已經存在, 告訴用戶錯誤信息。
2.2 如果郵箱已經存在, 告訴用戶錯誤信息。
2.3 如果都不存在 .則進行第3步。
3. 將用戶的信息 保存到數據庫中
4. 注冊 成功, 跳轉到 登錄 頁面
5. 登陸
5.1 將用戶的登陸信息發送到后臺進行驗證
5.2 如果驗證成功,則跳轉到首頁
5.3 如果跳轉失敗,則跳轉到登陸頁面,并提示錯誤信息。

項目目錄結構
項目的源碼分成四個包文件,分別用來存取模型,視圖,控制器和工具類,具體文件如下:

Servlet+JavaBean+JSP打造Java Web注冊與登錄功能

對于視圖,我們定義三個JSP頁面,如下所示:

Servlet+JavaBean+JSP打造Java Web注冊與登錄功能

 

定義視圖
login.jsp頁面

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>登錄的表單</title>
</head>
<body>
  <font color="red">${message }</font>
  <a href="regist.jsp">注冊新賬號</a>
  <form action="${pageContext.request.contextPath }/login" method="post">
    用戶名:<input type="text" name="username"><br/>
    密碼:<input type="password" name="password"><br/>
    <input type="submit" value="登錄">
</form>
</body>
</html>

index.jsp頁面

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
    <font color="red">${message }</font>   
  <%
   if(request.getSession().getAttribute("username")==null)
   {
     response.sendRedirect("login.jsp");
   }
   else{
    %>
     <font color="red">"歡迎您:" <%=request.getSession().getAttribute("username").toString() %></font>
    <%   
   }
  %>
</body>
</html>

regist.jsp頁面

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>用戶注冊的表單</title>
<script type="text/javascript">
  function changeImage(){
 
    document.getElementById("image").src="${pageContext.request.contextPath }/checkimage?" + new Date().getTime()
 
  }
 
  function validateForm(){
 
    // 做 用戶名 , 密碼, 郵箱, 昵稱的校驗
 
    var username= document.getElementById("username").value;
    if(username==""){
 
      alert("用戶名 不能為空");
      return false;
    }
 
    var password= document.getElementById("password").value;
    if(password==""){
 
      alert("密碼 不能為空");
      return false;
    }
 
    var repassword= document.getElementById("repassword").value;
    if(password!=repassword){
 
      alert("密碼 必須 一致 ");
      return false;
    }
 
    var nickname= document.getElementById("nickname").value;
    if(nickname==""){
 
      alert("昵稱 不能為空");
      return false;
    }
 
    // ^\\s*\\w+(?:\\.{0,1}[\\w-]+)*@[a-zA-Z0-9]+(?:[-.][a-zA-Z0-9]+)*\\.[a-zA-Z]+\\s*$
    var email= document.getElementById("email").value;
    if(email.match("^\\s*\\w+(?:\\.{0,1}[\\w-]+)*@[a-zA-Z0-9]+(?:[-.][a-zA-Z0-9]+)*\\.[a-zA-Z]+\\s*$")==null){
 
      alert("郵箱地址 不正確 ");
      return false;
    }
 
 
  }
</script>
</head>
<body>
  <h3>用戶注冊的表</h3>
  <font color="red">${message }</font>
 
  <form action="${pageContext.request.contextPath }/regist" onsubmit="return validateForm();" method="post">
    <table border="1">
      <tr>
        <td>用戶名</td>
        <td>
          <input type="text" name="username" id="username1" v>
        </td>
      </tr>
      <tr>
        <td>密碼</td>
        <td>
          <input type="password" name="password" id="password">
        </td>
      </tr>
      <tr>
        <td>請確認密碼</td>
        <td>
          <input type="password" name="repassword" id="repassword">
        </td>
      </tr>
      <tr>
        <td>昵稱</td>
        <td>
          <input type="text" name="nickname" id="nickname">
        </td>
      </tr>
      <tr>
        <td>郵箱</td>
        <td>
          <input type="text" name="email" id="email">
        </td>
      </tr>
      <tr>
        <td>驗證碼</td>
        <td>
          <input type="text" name="checkcode">
          <img src="${pageContext.request.contextPath }/checkimage"
          style="cursor: pointer;" id="image" onclick="changeImage();">
        </td>
      </tr>
      <tr>
        <td></td>
        <td>
          <input type="submit" value="注冊">
        </td>
      </tr>
    </table>
  </form>
</body>
</html>

定義模型
User模型:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
package com.vs2022.model;
 
public class User {
 
  private String username;
  private String password;
  private String nickname;
  private String email;
 
  // alt+shft+ s // 彈出 覆蓋 方法的 對話框 。
  public String getUsername() {
    return username;
  }
  public void setUsername(String username) {
    this.username = username;
  }
  public String getPassword() {
    return password;
  }
  public void setPassword(String password) {
    this.password = password;
  }
  public String getNickname() {
    return nickname;
  }
  public void setNickname(String nickname) {
    this.nickname = nickname;
  }
  public String getEmail() {
    return email;
  }
  public void setEmail(String email) {
    this.email = email;
  }
 
}

UserOperation模型

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package com.vs2022.model;
 
import com.vs2022.utils.DBUtil;
 
public class UserOperation {
 
  public final static int USERNAMEEXIST=1;
  public final static int EMAILEXIST=2;
  public final static int SUCCESS=3;
  public final static int FAIL=4;
 
  public int regist(User user){
 
 
    DBUtil db = new DBUtil();
 
    if(db.serchUserName(user.getUsername())){
      // 說明 用戶名 已經存在了
      return USERNAMEEXIST;
    }
 
    if(db.serchEmail(user.getEmail())){
      // 說明郵箱已經存在
      return EMAILEXIST;
    }
 
 
    // 如果 走到 這里, 則說明 ,郵箱 用戶名都不存咋, 那么 就讓其注冊 . 添加 到數據庫中
    db.updateUser(user);
 
    return SUCCESS;
  }
 
  public int login(User user) {
 
    DBUtil db = new DBUtil();
 
    if(db.loginSuccess(user.getUsername(), user.getPassword())){
      // 說明 找到 了用戶 名 和密碼 都正確的
      return SUCCESS;
    }
 
    return FAIL;
  }
 
}

CheckCode模型

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package com.vs2022.model;
 
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Hashtable;
 
import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
 
 
public class CheckCode {
 
private String getRandomString() {
  int ranNum = (int) (Math.random() * 9000) + 1000;
  return ranNum + "";
}
 
public void getCode(int width, int height, HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException{
  // 在內存中創建圖象
  BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
  Graphics g=image.getGraphics();   //創建Graphics對象,其作用相當于畫筆
  g.setColor(Color.getColor("F8F8F8"));
  g.fillRect(0, 0, width, height);  //繪制背景
  Font mfont=new Font("楷體",Font.BOLD,16); //定義字體樣式
  g.setFont(mfont);          //設置字體
  g.setColor(Color.RED);
  //生成隨機數
  String rans=getRandomString();
  //將隨機數寫入會話
  HttpSession session = request.getSession();
  session.setAttribute("check", rans);
  //將隨機數寫入圖片
  g.drawString(rans, 5, 20);
  // 圖象生效
  g.dispose();
  //輸出圖像
  ImageIO.write(image, "JPEG", response.getOutputStream());
 
}
}

定義控制器
LoginServlet類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
package com.vs2022.controller;
 
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;
 
import com.vs2022.model.User;
import com.vs2022.model.UserOperation;
 
 
public class LoginServlet extends HttpServlet {
 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
 
    // 完成 登錄的 邏輯
    String username = request.getParameter("username");
    String password = request.getParameter("password");
 
    User user = new User();
 
    user.setUsername(username);
    user.setPassword(password);
 
    // 調用 業務功能 javabean 類 去實現 登錄的 具體 業務邏輯
    UserOperation us = new UserOperation();
 
    // 返回值 ?
    int i = us.login(user);
 
    if(i==4){
 
      // 說明 登錄失敗 ,用戶名 或 密碼錯誤
      request.setAttribute("message", "用戶名或密碼錯誤");
      request.getRequestDispatcher("login.jsp").forward(request, response);
 
    }else{
 
      // 登錄 成功 , 跳轉到網站的 首頁, 用 重定向
 
      // 將username 存入到 session 域中
      request.getSession().setAttribute("username", username);
      response.sendRedirect("index.jsp");
      //request.getRequestDispatcher("index.jsp").forward(request, response);
 
 
    }
 
  }
 
  public void doPost(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
 
    doGet(request, response);
  }
 
}

RegistServlet類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package com.vs2022.controller;
 
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import com.sun.org.apache.commons.beanutils.BeanUtils;
 
import com.vs2022.model.User;
import com.vs2022.model.UserOperation;
 
 
public class RegistServlet extends HttpServlet {
 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
 
    // 解決 post 方式 的亂碼
    request.setCharacterEncoding("UTF-8");
 
    // 完成驗證碼的校驗
    String checkcode = request.getParameter("checkcode");
    String check_code_session = (String) request.getSession().getAttribute("check");
    if(checkcode==null||!checkcode.equals(check_code_session)){
 
      // 說明 驗證碼 輸入 不正確
      request.setAttribute("message", "驗證碼輸入不正確");
      request.getRequestDispatcher("regist.jsp").forward(request, response);
      return;
    }
 
    // 如果 走到 了 這里, 則說明 所有的 校驗 都通過 ,就 要 調用 涉及 到 處理 業務邏輯 了
 
    User user = new User();
    // beanUtils 完成 數據的 封裝 到 java bean 對象 中 ,apache 基金會的 一個 開源的jar的 實現。
    try {
      // 前提 : javabean的 字段名 必須 要 與 表單中提交 過來 的 值 的 key 一致, 否則 不能 完成 封裝 .
      BeanUtils.populate(user, request.getParameterMap());
    } catch (Exception e) {
      e.printStackTrace();
      throw new RuntimeException("對不起, 封裝數據失敗 ");
    }
 
    // 所以 又 會 設計 一個 新的 java bean 類來 實現 業務邏輯
    UserOperation us = new UserOperation();
    try {
      int feedBack = us.regist(user);
 
      if(feedBack==UserOperation.EMAILEXIST){
 
        // 說明 郵箱 已經存在
        request.setAttribute("message", "郵箱已經存在 ");
        request.getRequestDispatcher("regist.jsp").forward(request, response);
 
 
 
      }else if(feedBack==UserOperation.USERNAMEEXIST){
 
        // 說明 用戶名已經存在
        request.setAttribute("message", "用戶名 已經存在 ");
        request.getRequestDispatcher("regist.jsp").forward(request, response);
 
 
      }else{
        // 說明 注冊 成功 , 跳轉到 登錄 頁面 . 要用 重定向
        response.sendRedirect("login.jsp" );
 
      }
 
 
    } catch (Exception e) {
      e.printStackTrace();
      throw new RuntimeException("添加 失敗 ");
    }
  }
 
  public void doPost(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
 
    doGet(request, response);
  }
 
}

CheckImageServlet類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
package com.vs2022.controller;
 
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import com.vs2022.model.CheckCode;
 
public class CheckImageServlet extends HttpServlet {
 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
 
    //禁用緩存,每次訪問此頁面,都重新生成
    response.setHeader("Pragma","No-cache");
    response.setHeader("Cache-Control","no-cache");
    response.setDateHeader("Expires", 0);
    response.setContentType("image/jpeg");
    int width=40;
    int height=30;
    //生成驗證碼的匿名對象,并生成驗證碼
    new CheckCode().getCode(width,height,request,response);
  }
 
 
  public void doPost(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
 
    doGet(request, response);
  }
 
}

定義工具類
DBUtil類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
package com.vs2022.utils;
 
import java.sql.*;
import com.vs2022.model.User;
 
public class DBUtil {
 
  boolean bInited = false;
 
  // 加載驅動
  public void initJDBC() throws ClassNotFoundException {
    // 加載MYSQL JDBC驅動程序
    Class.forName("com.mysql.jdbc.Driver");
    bInited = true;
    System.out.println("Success loading Mysql Driver!");
 
  }
 
  public Connection getConnection() throws ClassNotFoundException,
      SQLException {
    if (!bInited) {
      initJDBC();
    }
    // 連接URL為 jdbc:mysql//服務器地址/數據庫名
    // 后面的2個參數分別是登陸用戶名和密碼
    Connection conn = DriverManager.getConnection(
        "jdbc:mysql://localhost:3306/數據庫", "用戶名", "密碼");
    return conn;
  }
 
  public boolean loginSuccess(String userName, String password) {
    boolean returnValue = false;
    String sql = "SELECT * FROM user where username=? and password=?";
    Connection conn = null;
    PreparedStatement ps=null;
    int i=0;
 
    try {
      conn = getConnection();
      ps=conn.prepareStatement(sql);
      ps.setString(1, userName);
      ps.setString(2, password);
      ResultSet rs=ps.executeQuery();
      if(rs.next()){
        returnValue=true;
      }
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    return returnValue;
  }
 
  public boolean updateUser(User user) {
    boolean flag=false;
    int i=0;
    Connection conn=null;
    PreparedStatement ps=null
    String sql= "insert into user (username,password,nickname,email) values(?,?,?,?)";
    try {
      conn = getConnection();
      ps=conn.prepareStatement(sql);
      ps.setString(1, user.getUsername()); //對占位符設置值,占位符順序從1開始,第一個參數是占位符的位置,第二個參數是占位符的值。
      ps.setString(2, user.getPassword());
      ps.setString(3, user.getNickname());
      ps.setString(4, user.getEmail());
      i=ps.executeUpdate();
      if(i>0){
        flag=true;
      }
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    }catch (SQLException e) {
      e.printStackTrace();
    }
    return flag;
  }
 
  public boolean serchUserName(String userName){
    boolean returnValue = false;
    String sql = "SELECT * FROM user where username=?";
    Connection conn = null;
    PreparedStatement ps=null;
    try {
      conn = getConnection();
      ps=conn.prepareStatement(sql);
      ps.setString(1, userName);
      ResultSet rs=ps.executeQuery();
      if(rs.next()){
        returnValue=true;
      }
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    return returnValue;
  }
 
  public boolean serchEmail(String email){
    boolean returnValue = false;
    String sql = "SELECT * FROM user where email=?";
    Connection conn = null;
    PreparedStatement ps=null;
    int i=0;
    try {
      conn = getConnection();
      ps=conn.prepareStatement(sql);
      ps.setString(1, email);
      ResultSet rs=ps.executeQuery();
      if(rs.next()){
        returnValue=true;
      }
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    return returnValue;
  }
}

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美电影在线观看 | 999精品视频一区二区三区 | 成人影视免费 | 玖玖玖视频 | 精品福利一区二区三区 | 日韩精品www| 国产精品一区二区不卡 | 一区二区电影 | 午夜天堂精品久久久久 | 999久久久 | 亚洲精品网址 | 人人干人人爱 | 久久国产区| 欧美视频一二三区 | 亚洲欧美一区二区视频 | 国产h片在线观看 | 国产伦精品一区二区三区四区视频 | 99国产精品久久久久久久久久 | 狠狠操综合网 | 国产精品入口久久 | 中文字幕在线观看一区二区三区 | 国产精品免费视频一区 | 日韩在线 | 亚洲第一黄色网 | 日韩精品一区二 | 色综合色综合网色综合 | 精品自拍视频 | 日韩成人影院 | 福利精品视频 | 一本一道久久久a久久久精品91 | 欧美日韩在线一区二区三区 | 亚洲午夜免费视频 | 国产精品久久久久久久久软件 | 国内毛片 | 美国理论 | 国产婷婷精品 | 精品一二三区在线观看 | 成人精品一区二区 | 插插射啊爱视频日a级 | xxxx网| 欧美日韩国产一区二区三区不卡 |