1. 程式人生 > 程式設計 >Servlet實現簡單的使用者登入功能例項程式碼

Servlet實現簡單的使用者登入功能例項程式碼

1、建立html介面

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
</head>
<body>
 <form action="" method="post">
  使用者名稱:<input type="text" name="username"> <br>
  密碼:<input type="password" name="password"><br>

  <input type="submit" value="登入">

 </form>
</body>
</html>

2 、建立資料庫

CREATE TABLE USER(
			id INT PRIMARY KEY AUTO_INCREMENT,username VARCHAR(32) UNIQUE NOT NULL,PASSWORD VARCHAR(32) NOT NULL
		);

3、建立使用者實體類

	public class User {
		
		 private int id;
		 private String username;
		 private String password;
  	 public int getId() {
		  return id;
		 }
		
		 public void setId(int id) {
		  this.id = id;
		 }
		
		 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;
		 }
		
		 @Override
		 public String toString() {
		  return "User{" +
		    "id=" + id +
		    ",username='" + username + '\'' +
		    ",password='" + password + '\'' +
		    '}';
		 }
		}
  

4、建立jdbc工具類

這裡使用的是c3p0 / druid 兩種資料庫連線池技術 分別需要在專案匯入相應的jar包

public class JDBCUtils {
		
		 private static DataSource ds ;
		
		 static {
		
		  try {
		   //1.載入配置檔案
		   Properties pro = new Properties();
		   //使用ClassLoader載入配置檔案,獲取位元組輸入流
		   InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
		   pro.load(is);
		
		   //2.初始化連線池物件
		   ds = DruidDataSourceFactory.createDataSource(pro);
		
		  } catch (IOException e) {
		   e.printStackTrace();
		  } catch (Exception e) {
		   e.printStackTrace();
		  }
		 }
		
		 /**
		  * 獲取連線池物件
		  */
		 public static DataSource getDataSource(){
		  return ds;
		 }
  /**
		  * 獲取連線Connection物件
		  */
		 public static Connection getConnection() throws SQLException {
		  return ds.getConnection();
		 }

 system.out.println("=============================================================")
public class JDBCButil {
	final static ComboPooledDataSource comboPooledDataSource = new ComboPooledDataSource();
	// 獲取連線方法
	// 返回一個連線物件
	public static Connection getCon() {
		// 連線使用c3p0進行獲取
		// 使用c3p0資料庫連線池獲取連線
		Connection connection = null;
		try {
			connection = comboPooledDataSource.getConnection();
		} catch (SQLException e) {
			System.err.println("獲取連線失敗");
			return null;
		}
		return connection;
	}

	// DML方法
	// 不支援事務 單條sql語句執行
	public static boolean DML(String sql,Object... o) {
		// 獲取連線
		Connection con = getCon();
		// 建立預編譯物件
		try {
			PreparedStatement ps = con.prepareStatement(sql);
			for (int i = 0; i < o.length; i++) {
				ps.setObject((i + 1),o[i]);
			}
			ps.executeUpdate();
		} catch (SQLException e) {
			System.out.println("查詢執行失敗:" + sql);
			return false;
		}
		return true;
	}

	// DML方法
	// 支援事務 多條sql語句執行
	public static boolean DML(Connection con,String sql,Object... o) {
		// 建立預編譯物件
		try {
			PreparedStatement ps = con.prepareStatement(sql);
			for (int i = 0; i < o.length; i++) {
				ps.setObject((i + 1),o[i]);
			}
			ps.executeUpdate();
		} catch (SQLException e) {
			System.out.println("查詢執行失敗:" + sql);
			return false;
		}
		return true;
	}

	// 查詢dql語句方法
	public static <E> ArrayList<E> DQL(String sql,Class<E> c,Object... o) {
		ArrayList<E> list = new ArrayList<>();
		try {
			// 獲取連線
			Connection con = getCon();
			// 準備預編譯物件
			PreparedStatement ps = con.prepareStatement(sql);
			// 獲取元資料 準備儲存所有列名的陣列
			ResultSetMetaData metaData = ps.getMetaData();
			// 建立指定長度用於儲存列名的陣列
			String[] names = new String[metaData.getColumnCount()];
			// 迴圈為names陣列進行賦值
			for (int i = 0; i < names.length; i++) {
				names[i] = metaData.getColumnLabel(i + 1);// 獲取指定列名
			}
			
			for (int i = 0; i < o.length; i++) {
				ps.setObject(i+1,o[i]);
			}
			// 執行sql返回結果集
			ResultSet rs = ps.executeQuery();
			while (rs.next()) {

				// 每一行資料就是一個物件
				// 使用反射建立物件
				E obj = c.newInstance();

				// 當前行所有列名 在names陣列中儲存
				// 迴圈names陣列取出當前行對應資料
				for (String colname : names) {
					Object value = rs.getObject(colname);// 獲取列名對應值
					// 將值存入相應物件
					// 使用反射獲取類中同名的屬性物件
					Field field = c.getDeclaredField(colname);
					// 私有屬性使用前必須賦權
					field.setAccessible(true);
					// 呼叫屬性物件的set方法為指定物件進行賦值
					field.set(obj,value);
				}

				// 列名迴圈結束後對應物件屬性已經全部進行賦值
				// 將物件儲存至集合中
				list.add(obj);
			}

		} catch (Exception e) {
			e.printStackTrace();
			return null;
		}
		return list;
	}
}ublic class JDBCUtils {
		
		 private static DataSource ds ;
		
		 static {
		
		  try {
		   //1.載入配置檔案
		   Properties pro = new Properties();
		   //使用ClassLoader載入配置檔案,獲取位元組輸入流
		   InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
		   pro.load(is);
		   //2.初始化連線池物件
		   ds = DruidDataSourceFactory.createDataSource(pro);
		
		  } catch (IOException e) {
		   e.printStackTrace();
		  } catch (Exception e) {
		   e.printStackTrace();
		  }
		 }
		
		 /**
		  * 獲取連線池物件
		  */
		 public static DataSource getDataSource(){
		  return ds;
		 }

5、建立提供登入方法的userdao

	public class UserDao {
		
		 //宣告JDBCTemplate物件共用
		 private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
		 /**
		  * 登入方法
		  * @param loginUser 只有使用者名稱和密碼
		  * @return user包含使用者全部資料,沒有查詢到,返回null
		  */
		 public User login(User loginUser){
		  try {
		   //1.編寫sql
		   String sql = "select * from user where username = ? and password = ?";
		   //2.呼叫query方法
		   User user = template.queryForObject(sql,new BeanPropertyRowMapper<User>(User.class),loginUser.getUsername(),loginUser.getPassword());
		       return user;
		  } catch (DataAccessException e) {
		   e.printStackTrace();
		   return null;
		  }
		 }
		}
	

6、編寫登入的servlet

@WebServlet("/loginServlet")
		public class LoginServlet extends HttpServlet {
		 @Override
		 protected void doGet(HttpServletRequest req,HttpServletResponse resp) throws ServletException,IOException {
		  //1.設定編碼
		  req.setCharacterEncoding("utf-8");
		  //2.獲取請求引數
		  String username = req.getParameter("username");
		  String password = req.getParameter("password");
		  //3.封裝user物件
		  User loginUser = new User();
		  loginUser.setUsername(username);
		  loginUser.setPassword(password);
		
		  //4.呼叫UserDao的login方法
		  UserDao dao = new UserDao();
		  User user = dao.login(loginUser);
		
		  //5.判斷user
		  if(user == null){
		   //登入失敗
		   req.getRequestDispatcher("/failServlet").forward(req,resp);
		  }else{
		   //登入成功
		   //儲存資料
		   req.setAttribute("user",user);
		   //轉發
		   req.getRequestDispatcher("/successServlet").forward(req,resp);
		  }
		
		 }
		 @Override
		 protected void doPost(HttpServletRequest req,IOException {
		  this.doGet(req,resp);
		 }
		}
		

7、 編寫FailServlet和SuccessServlet類

	public class SuccessServlet extends HttpServlet {
		 protected void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException {
		  //獲取request域中共享的user物件
		  User user = (User) request.getAttribute("user");
		
		  if(user != null){
		   //給頁面寫一句話
		
		   //設定編碼
		   response.setContentType("text/html;charset=utf-8");
		   //輸出
		   response.getWriter().write("登入成功!"+user.getUsername()+",歡迎您");
		  }
		  }		
		 @WebServlet("/failServlet")
		public class FailServlet extends HttpServlet {
		 protected void doPost(HttpServletRequest request,IOException {
		  //給頁面寫一句話
		
		  //設定編碼
		  response.setContentType("text/html;charset=utf-8");
		  //輸出
		  response.getWriter().write("登入失敗,使用者名稱或密碼錯誤");
		
		 }
		
		 protected void doGet(HttpServletRequest request,IOException {
		  this.doPost(request,response);
		 }
		}
		  
		  
		  

到此這篇關於Servlet實現簡單的使用者登入功能的文章就介紹到這了,更多相關Servlet實現使用者登入功能內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!