程序结构目录
login.jsp
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>登录界面</title>
</head>
<body>
<form action="LoginServlet" method="post">
账号<input type="text" name="username"/><br>
密码<input type="password" name="password"/><br>
<input type="submit" value="登录"><br>
</form>
</body>
</html>
MVC结构
Dao属于Model层,编写登录用户User的实体类,JavaBean
User.java
package Dao;
public class User {
private String username;
private String password;
public User() {
}
public User(String username, String password) {
this.username = username;
this.password = password;
}
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;
}
}
DBUtil(数据库工具类)
这里对数据库的连接操作进行了封装,写了一个getConnection方法,返回一个Connection。
package Dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DBUtil {
public Connection getConnection(){
Connection conn=null;
try{//加载MySql的驱动类
Class.forName("com.mysql.cj.jdbc.Driver") ;
}catch(ClassNotFoundException e){
System.out.println("找不到驱动程序类 ,加载驱动失败!");
e.printStackTrace() ;
}
//2.获取链接
String url = "jdbc:mysql://localhost:3306/student" ;
String username = "root" ;
String password = "1367885677" ;
try{
conn = DriverManager.getConnection(url , username , password ) ;
System.out.println("数据库连接成功");
}catch(SQLException se){
System.out.println("数据库连接失败!");
se.printStackTrace() ;
}
return conn;
}
}
编写LoginDao.java,其中有login方法,有错误,最后没关闭连接。
package Dao;
import java.sql.*;
public class LoginDao {
public Boolean login(User user) throws SQLException {//登录
//1.连接数据库
DBUtil db=new DBUtil();
Connection connection= db.getConnection();
//2.编写sql,设置value
String sql="select * from user1 where username=? and password=?";
PreparedStatement pstmt = connection.prepareStatement(sql);
pstmt.setString(1,user.getUsername());
pstmt.setString(2, user.getPassword());
//3.执行sql
ResultSet rs = pstmt.executeQuery();
//4.判断
if(rs.next()){
return true;
}else {
return false;
}
//关闭
}
}
重点理解设置占位符?的参数的getxxx()的使用
LoginServlet.java (这里是Controller)
其中从前端接受参数后,再将其封装到了user中,将user传给login()。
package servlet;
import Dao.LoginDao;
import Dao.User;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;
import java.sql.SQLException;
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
String username = request.getParameter("username");
String password = request.getParameter("password");
User user=new User();
user.setUsername(username);
user.setPassword(password);
//调用登录功能
LoginDao loginDao = new LoginDao();
try {
Boolean result = loginDao.login(user);
if(result=true){
response.getWriter().print("login success");
}else {
response.getWriter().print("login fail");
}
} catch (SQLException e) {
e.printStackTrace();
}
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doGet(request, response);
}
}