Servlet實現(xiàn)簡單的用戶登錄功能實例代碼
更新時間:2020年12月04日 11:59:02 作者:少女總裁、
這篇文章主要給大家介紹了關于利用Servlet實現(xiàn)簡單的用戶登錄功能的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
1、創(chuàng)建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 、創(chuàng)建數(shù)據(jù)庫
CREATE TABLE USER( id INT PRIMARY KEY AUTO_INCREMENT, username VARCHAR(32) UNIQUE NOT NULL, PASSWORD VARCHAR(32) NOT NULL );
3、創(chuàng)建用戶實體類
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、創(chuàng)建jdbc工具類
這里使用的是c3p0 / druid 兩種數(shù)據(jù)庫連接池技術 分別需要在項目導入相應的jar包
public class JDBCUtils {
private static DataSource ds ;
static {
try {
//1.加載配置文件
Properties pro = new Properties();
//使用ClassLoader加載配置文件,獲取字節(jié)輸入流
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數(shù)據(jù)庫連接池獲取連接
Connection connection = null;
try {
connection = comboPooledDataSource.getConnection();
} catch (SQLException e) {
System.err.println("獲取連接失敗");
return null;
}
return connection;
}
// DML方法
// 不支持事務 單條sql語句執(zhí)行
public static boolean DML(String sql, Object... o) {
// 獲取連接
Connection con = getCon();
// 創(chuàng)建預編譯對象
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("查詢執(zhí)行失敗:" + sql);
return false;
}
return true;
}
// DML方法
// 支持事務 多條sql語句執(zhí)行
public static boolean DML(Connection con, String sql, Object... o) {
// 創(chuàng)建預編譯對象
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("查詢執(zhí)行失敗:" + 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);
// 獲取元數(shù)據(jù) 準備存儲所有列名的數(shù)組
ResultSetMetaData metaData = ps.getMetaData();
// 創(chuàng)建指定長度用于存儲列名的數(shù)組
String[] names = new String[metaData.getColumnCount()];
// 循環(huán)為names數(shù)組進行賦值
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]);
}
// 執(zhí)行sql返回結果集
ResultSet rs = ps.executeQuery();
while (rs.next()) {
// 每一行數(shù)據(jù)就是一個對象
// 使用反射創(chuàng)建對象
E obj = c.newInstance();
// 當前行所有列名 在names數(shù)組中存儲
// 循環(huán)names數(shù)組取出當前行對應數(shù)據(jù)
for (String colname : names) {
Object value = rs.getObject(colname);// 獲取列名對應值
// 將值存入相應對象
// 使用反射獲取類中同名的屬性對象
Field field = c.getDeclaredField(colname);
// 私有屬性使用前必須賦權
field.setAccessible(true);
// 調用屬性對象的set方法為指定對象進行賦值
field.set(obj, value);
}
// 列名循環(huán)結束后對應對象屬性已經(jīng)全部進行賦值
// 將對象存儲至集合中
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加載配置文件,獲取字節(jié)輸入流
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、創(chuàng)建提供登錄方法的userdao
public class UserDao {
//聲明JDBCTemplate對象共用
private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
/**
* 登錄方法
* @param loginUser 只有用戶名和密碼
* @return user包含用戶全部數(shù)據(jù),沒有查詢到,返回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.獲取請求參數(shù)
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{
//登錄成功
//存儲數(shù)據(jù)
req.setAttribute("user",user);
//轉發(fā)
req.getRequestDispatcher("/successServlet").forward(req,resp);
}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, 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, HttpServletResponse response) throws ServletException, IOException {
//給頁面寫一句話
//設置編碼
response.setContentType("text/html;charset=utf-8");
//輸出
response.getWriter().write("登錄失敗,用戶名或密碼錯誤");
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request,response);
}
}
到此這篇關于Servlet實現(xiàn)簡單的用戶登錄功能的文章就介紹到這了,更多相關Servlet實現(xiàn)用戶登錄功能內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringBoot使用Kaptcha實現(xiàn)驗證碼的生成與驗證功能
這篇文章主要介紹了SpringBoot使用Kaptcha實現(xiàn)驗證碼的生成與驗證功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03

