1.JavaEE的开发模式

完成一件事情或者一个功能的一种常规的“套路”。

下面我们来介绍JSP的开发模式:

1.第一代

JSP页面:HTML+数据库交互的代码+逻辑判断的代码

2.第二代

利用javaweb-08的javabean模式
JSP页面:HTML+逻辑代码
javabean:数据库交互的代码进行了DAO封装,DAO(直接新DB数据库中进行操作)
Connection conn = DBHelper.getConn();
2.1 servlet
2.2 JavaWEN经典模式:MVC架构

3.三层架构模式

简单的说就是将一个程序中的代码分了三个层,每个层做着独立的事情,但是在某种情况下,三层之间又有联系。

web显示层
职责:显示数据
jsp(html+css+js+jQuery+bootstrap+easyui等等)
负责显示内容
doXXX.jsp 处理页面—-将来学习servlet

业务逻辑层
职责:从数据访问层拿到数据后进行判断限制
serviceIUsersServerDao UsersServerImpl
bizIUsersBiz UsersBizImpl

S阶段编写业务逻辑层:不考虑任何条件
直接从数据访问层中拿到数据进行操作即可。

负责:
1.删除数据:先获取有没有,然后再进行删除
2.考虑数据库事务处理机制
事务:在一个模块中,出现多个条件时,利用事务机制来达到一个要么一起成功,要么一起失败的现象。
事务三个操作:commit提交 savepoint还原点 rollback 回滚(撤销)
银行转账问题。
刘凯丰—–>转账—–>谢凯进1000万
update tb_users set money = money-1000 where name = ‘刘凯丰’
System.out.println(10/0);//运行时异常
update tb_users set money = money+1000 where name = ‘谢凯进’;

数据访问层
职责:专门从DB数据库中拿数据。
数据库帮助类DBHelper
实体DAO:IUsersDao UsersDaoImpl

许多代码新手可能不太了解,那么下面我们举个例子:

例子:
饭馆吃饭问题
刘凯丰 顾客
服务员(负责显示餐馆中所有的菜品)—web显示层
厨师(根据小厨提供的材料进行有效的组装和加工)–业务逻辑层
小厨(切菜,洗菜,买菜,其它事情)–数据访问层

目的:数据删除、登录。

5.分层的实现

S1阶段:实体包,工具包,dao包,ui包;
S2阶段:数据访问层(DAO)、业务逻辑层(BIZ|SERVICES)、表示层(jsp)、实体包。

1. 表示层 jsp+html;

2. 业务逻辑层 biz/service;

3. 数据库访问层 dao(访问数据库、文本文件、XML文件)。

注意:Entity实体类不属于某层,三层都可以调用,主要用于封装数据。

分层实现的优势

  • 职责划分清晰

  • 无损替换

  • 复用代码

  • 降低了系统内部的依赖程度

4.三层架构:表示层、业务逻辑层、数据访问层
①表示层:位于最外层 ( 最上层 ),使用户能够直接访问,用于显示数据和接收用户输入的数据,为用户提供一种交互式操作界面。在 Web 应用程 序中,表示层一般以 JSP 文件、HTML文件为主;

②业务逻辑层:其主要功能是提供对业务逻辑处理的封装,在业务逻辑层中,通常会定义些接口,表示层通过调用业务逻辑层的接口实现各种操作, 如数据有效性的检验. 业务辑描述等相关功能,业务逻辑层经常放在 service 包或 biz 包下,btz 是英文 buslness 的缩写,意思是 ‘业务逻 辑”;

③数据访问层:该层实现对数据的保存和读取操作。数据访问,可以访问关系数椐库、文件或 XML 文档等。数据访问层通常放在 dao 包下,DAO 是英文 Data Access Object 的缩写,意思是 “数据访问对象 “;

下面是课堂案例登录实现验证:

/** * 用户管理接口实现类 ** @author Administrator * */public class UsersDaoImpl extends BaseDao implements IUsersdao {// 编写dao 写一个复制5个@Overridepublic Users usersLogin(Users users) {// 1.定义各种对象及变量Users u = null;// 实体对象String sql = "select * from tb_t281_news_users where username = ? and password = ?";ResultSet rs = this.executeQuery(sql, new Object[] { users.getUsername(), users.getPassword() });try {if (rs.next()) {u = new Users(rs.getInt("userid"), rs.getString("username"), rs.getString("password"),rs.getString("usex"), rs.getString("uaddress"), rs.getString("utelphone"), rs.getInt("urole"),rs.getString("udate"));}} catch (Exception e) {e.printStackTrace();} finally {DBHelper.myClose(conn, ps, rs);}return u;}

登录验证加载

do登录验证

接口类:

/*

*接口类

*/

public interface IusersBiz {

public Users usersLogin(Users users);

}

接口实现类:

public class UserBizImpl implements IusersBiz {
// 实例化数据访问层 (全局变量)
private IUsersdao kk = new UsersDaoImpl();

@Override
public Users usersLogin(Users users) {
// 调用登录方法
return kk.usersLogin(users);
}

}

———————————-今天的分享就到这里了,下次分享再见哦—————————————–