步骤
1.创建项目,导入需要的jar包,和配置文件
2.创建相关数据库
CREATE DATABASE Users;
CREATE TABLE users(
id INT PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(20) UNIQUE NOT NULL,
PASSWORD VARCHAR(20) NOT NULL
);
SHOW TABLES;
3.创建user实体类
用于封装数据
//用户的实体类
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 passward) {
this.password = passward;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", passward='" + password + '\'' +
'}';
}
}
4.创建jdbcutil工具类
创建前需要配置properties文件
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost/Users
username=root
password=wstujunjie2
initialSize=5
maxActive=10
maxWait=3000
public class JDBCUtils {
private static DataSource ds;
static {
try {
//加载配置文件
Properties pro = new Properties();
//使用classloader加载配置文件
InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
pro.load(is);
//初始化连接池对象
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();
}
}
5.完善dao类,并用类检测是否可用
public class UserDao {
/**
* 登录方法
*
*
*/
//声明JDBCTemplate对象共用
private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
public User login(User loginUser){
try {
//编写sql
String sql = "select * from users where username = ? and password = ?";
User user = template.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class), loginUser.getUsername(), loginUser.getPassword());
return user;
} catch (DataAccessException e) {
return null;
}
}
}
6.创建html登录界面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="demo1" METHOD="post">
<input type="text" name="usename" placeholder="用户名">
<input type="text" name="password" placeholder="密码">
<input type="submit" value="注册">
</form>
</body>
</html>
7.创建servlet类判断
@WebServlet("/loginservlet")
public class LoginServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//设置编码
req.setCharacterEncoding("utf-8");
//获取请求参数
String username = req.getParameter("username");
String password = req.getParameter("password");
//封装
User user = new User();
user.setUsername(username);
user.setPassword(password);
//调用dao
UserDao dao = new UserDao();
User loginuser = dao.login(user);
if (loginuser==null){
req.getRequestDispatcher("/failservlet").forward(req,resp);
}else {
req.setAttribute("user",user);
req.getRequestDispatcher("/succedservlet").forward(req,resp);
}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doGet(req,resp);
}
}