用户登录案例需求:
- 编写login.html登录页面
username & password 两个输入框 - 使用Druid数据库连接池技术,操作mysql,day14数据库中user表
- 使用JdbcTemplate技术封装JDBC
- 登录成功跳转到SuccessServlet展示:登录成功!用户名,欢迎您
- 登录失败跳转到FailServlet展示:登录失败,用户名或密码错误
. 分析
- 开发步骤:
1.创建项目,导入html页面,配置文件,jar包
新建一个模块,tomcat配置看之前的博客,虚拟目录为"/"
创建好后在web文件夹下建WEB-INF(Directory)里面再建lib(Directory)放jar包,记得add as library:
这里记得是创建WEB-INF和lib(它们的名字不能改变,否则tomcat识别不了)
还要把druid.properties直接放到src下,下面建包就行。
2.创建数据库环境
CREATE DATABASE day14;
USE day14;
CREATE TABLE USER(
id INT PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(32) UNIQUE NOT NULL,
password VARCHAR(32) NOT NULL
);
3.创建包cn.itcast.domain,创建类User
4.创建包cn.itcast.util,编写工具类JDBCUtils
5.创建包cn.itcast.dao,创建类UserDao,提供login方法
6.编写cn.itcast.web.servlet.LoginServlet类
7.编写FailServlet和SuccessServlet类
8.login.html中form表单的action路径的写法
在LoginServlet一开始我们是这样获取网页请求的参数,并把它存到实体类中:
// //2.获取请求参数
// //这里getParameter都是根据html的name值的
// String username = request.getParameter("username");
// String password = request.getParameter("password");
// //3.封装user对象
// User loginUser = new User();
// loginUser.setUsername(username);
// loginUser.setPassword(password);
如果你请求的有很多个参数,那么你要set和get就很麻烦,所以我们使用
BeanUtils
来解决这个问题:
Map<String, String[]> map = request.getParameterMap();
//3.封装user对象
User loginUser = new User();
//3.2使用BeanUtils封装
try {
BeanUtils.populate(loginUser,map);
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
BeanUtils.populate(loginUser,map)会把你的实体类跟你的请求参数map做个映射,非常方便。
BeanUtils的方法:
- setProperty()
- getProperty()
- populate(Object obj , Map map):将map集合的键值对信息,封装到对应的JavaBean对象中
总结:
总的项目结构:
- html和servlet的资源路径得写一致(前提你的虚拟目录为/,如果假设你的虚拟目录为bbb,那么你的login.html应该写为:/bbb/loginServlet,而LoginServlet还是写@WebServlet("/loginServlet"),不懂可以看看我之前的博客)
这里没有M层而已
最后附上代码:https://github.com/QLBF11/Java_small_important/tree/master/Login_smallProj