JavaEE项目的三层结构
image.png
image.png
书城项目的整个结构
image.png
学到的东西
1. 一上来就应该将项目的整个框架搭建好
2. src下各个包的功能:
1. dao实现持久层的功能 ,其中dao.impl 中的UserDaoImpl是具体的实现类,它继承了BaseDao,同时实现了接口UserDao。主要是用来和数据库进行交互
2. pojo 封装一个javabean 对象,跟数据库的表对应
3. service 业务层,有一个接口和一个实现类。主要实现各种业务:如:查询用户名是否存在,登录功能,注册功能,
4. test 测试包,主要进行测试,使用快捷键 alt+ins 生产Junit4 测试单元,在接口中使用
5. utils 工具包 和数据库连接池打交道,获取连接,放回连接池
6. web 各种servlet,用来只行web 层的业务。如:将HTML 页面中form标签的action 指向 XxxServlet 。需要在web.xml文件中配置使用的servlet。(这个包里面的 Xxxservlet 其实就是生成一个service中的XXXservice 对象,并调用他们的方法)
3. web 下主要进行前端的处理:
1. page 各种html界面
2. static : css文件,和script,以及使用的图片
3. WEB-INF :下面自己创建一个lib 包,用来存放导入的jar包
4. web.xml :配置文件
4. jdbc.properties : 为了使用Druid 写的配置文件
内容 : username=root
password=990615
url=jdbc:mysql://localhost:3306/book
driverClassName=com.mysql.jdbc.Driver
initialSize=5
maxActive=10
一些自己容易漏掉的点
1. 当servlet需要跳转到其他的界面的时候时,req.getRequestDispatcher("/pages/user/login_success.html").forward(req,resp);
* 不能忘了最后面的 .forward(req,resp);
* 其中的 “/” 会被服务器解析为 http://localhost:8080/工程路径
2. 下面两点是因为使用DButils
* 参数 new BeanHandler<T>(type) /**
*查询返回一个javabean
* @param type 返回的类型
* @param sql 执行的SQL语句
* @param args SQL语句的参数
* @param <T> 返回的类型的泛型
* @return
*/
public <T>T queryForOne(Class<T> type ,String sql ,Object ... args){
Connection conn = JdbcUtils.getConnection();
try {
return queryRunner.query(conn, sql, new BeanHandler<T>(type), args);
} catch (SQLException throwables) {
throwables.printStackTrace();
}finally {
JdbcUtils.close(conn);
}
return null;
}
* 以及下面代码中的参数 new ScalarHandler()
/**
* 查询列的单个值
* @param sql
* @param args
* @return
*/
public Object queryForSingleValue(String sql,Object ... args){
Connection conne = JdbcUtils.getConnection();
try {
return queryRunner.query(conne, sql, new ScalarHandler(), args);
} catch (SQLException throwables) {
throwables.printStackTrace();
}
return null;
}
}
3.有时候需要清除浏览器的缓存,否则还是之前的web 工程,容易误以为自己代吗没生效
一些迷惑的基础java知识点:
1. 泛型做参数,以及作为函数的返回类型 /**
*查询返回一个javabean
* @param type 返回的类型
* @param sql 执行的SQL语句
* @param args SQL语句的参数
* @param <T> 返回的类型的泛型
* @return
*/
public <T>T queryForOne(Class<T> type ,String sql ,Object ... args){
Connection conn = JdbcUtils.getConnection();
try {
return queryRunner.query(conn, sql, new BeanHandler<T>(type), args);
} catch (SQLException throwables) {
throwables.printStackTrace();
}finally {
JdbcUtils.close(conn);
}
return null;
}
或者/**
* 返回多个查询类型
* @param type 返回的对象类型
* @param sql 执行的SQL语句
* @param args
* @param <T>
* @return
*/
public <T> List<T> queryForList(Class<T> type,String sql,Object ... args){
Connection conn = JdbcUtils.getConnection();
try {
return queryRunner.query(conn,sql, new BeanListHandler<T>(type),args);
} catch (SQLException throwables) {
throwables.printStackTrace();
}finally {
JdbcUtils.close(conn);
}
return null;
}
其中的<T> List<T> queryForList(Class<T> type,String sql,Object ... args)