使用servlet简单实现注册和登录功能小结(书城项目第二阶段)

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)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。