【JavaEE】经典JAVA EE企业应用实战-读书笔记1

今天开始阅读李刚的书《经典JAVA EE企业应用实战 基于WebLogic JBoss的JSF+EJB3+JPA整合开发》这本书,

并记录下读书笔记,以方便以后参考。


Java EE应用大致可分为如下几层:

1Domain Object(领域对象)层:此层由系列的POJO组成。

2DAOData Access Object,数据访问对象)层

3,业务逻辑层

4,控制器层

5,表现层

JBoss是一款很著名的开源的JavaEE应用服务器

 

事务控制也是Java EE应用中必须要处理的问题,他可以保证一系列数据库操作能够准确完成。事务及时保证底层数据库完整性的重要手段,也是保证应用业务逻辑成功执行的重要基础。对于一个实际企业级应用而言,既需要局部事务控制,也需要全局事务控制。

JTAJava Transaction API)则提供了事务划分的标准接口,尤其是当应用程序执行两个需要依赖于不同数据库的操作时,应用程序就需要使用JTA来将两个操作包含成一个全局事务。

事务是由一步或几步数据库操作序列组成的逻辑执行单元,这系列操作要么全部执行,要么全部放弃执行。一段程序中可能包含多个事务。

事务具备4个特性:原子性Atomicity,一致性Consistency,隔离性Isolation和持续性Durability,简称ACID特性。

原子性:事务是应用中最小执行单位,事务是应用中不可再分的最小逻辑执行体。

一致性:事务执行的结果,必须使数据库从一个一致状态变到另一个一致性状态。一致性是通过原子性来保证的。

隔离性:各个事务的执行互不干扰,任意一个事务的内部操作对其他并发的事务都是隔离的。也就是说,并发执行的事务之间不能看到对方的中间状态,并发执行的事务之间也不能互相影响。

持续性:也称为持久性,指事务一旦提交,对数据所做的任何改变都要记录到永久存储器中,通常就是保存进物理数据库。

 

Java EE应用中的事务处理一般可以分为如下两类:

局部事务,Local Transaction Processiong

分布式事务,Distributed Transaction ProcessiongDTP

对于绝大部分企业应用而言,它只需要涉及单一的数据库资源,因此只需要采用局部事务即可。局部事务通常采用单阶段提交;但是也有一些更复杂的企业级应用采用分布式事务处理。分布式事务处理的关键是必须有一种方法保证多个数据库所做的全部动作,他们也可以作为一个整体,这样才能保证党业务逻辑跨越多个数据库资源时让多个数据库的数据保持一致。

必须借助于中间件的事务管理器来进行协调,中间件的事务管理器负责通知和协调所有参与事务的相关数据库的提交或回滚,最后由各个单独的数据库将自己所做的操作进行实质提交或回滚。

从应用程序的角度来看,中间件的事务管理器消除了底层事务处理的复杂性,从而简化了分布式事务处理的编程步骤——应用程序无需理会底层多个事务资源局部事务的开始、提交或回滚操作,应用程序只要面向中间件的事务管理器编程,用全局事务管理的API来开始、提交或回滚事务即可,而底层则可能转换为多个低级别的事务命令。

当一个业务操作需要涉及多个数据库时,就可称为分布式事务处理了。为了协调多个事务资源的分布式事务处理,多个事务资源底层必须使用一种通用的事务协议,目前流行的分布式事务处理规范就是XA规范。

X/Open组织(即现在的Open Group)定义了分布式事务处理模型。X/Open DTP模型(1994)包括应用程序AP、事务管理器TM、资源管理器RM、通信资源管理器CRM,一共4个部分。一般来说,常见的事务管理器TM就是事务中间件(通常由应用服务器来实现),常见的资源管理器是数据库,常见的通信资源管理器是消息中间件。

X/Open组织为分布式事务处理指定了事务中间件与数据库之间的接口规范,这种规范就是XA规范。事务中间件用它来通知数据库事务的开始、提交或回滚等。

该组织仅仅指定了分布式事务处理的XA规范,但是具体的实现则由不同的数据库厂商自行提供。

XA规范的理论基础就是两阶段提交(2 Phase Commit2PC)协议,该协议定义了单个的事务管理器如何协调和管理一个或多个数据库的局部事务,该协议大致可分为如下5个步骤:

1,应用程序面向事务管理器编程,应用程序调用事务管理器的提交方法。

2,事务管理器通知参与全局事务的每个数据库,告诉他们准备开始提交事务——第一个阶段开始。

3,参与全局事务的各个数据库进行局部事务的预提交。

4,事务管理器收集到各个数据库预提交的结果。

5,第二阶段开始,事务管理器收集到所有参与全局事务预提交的结果之后做出相应的判断:如果所有数据库的局部事务预提交结果都可以成功,事务管理器向每个数据库都发送进行实际提交的命令;如果任意一个数据库的局部事务预提交的结果失败了,事务管理器将向每个数据库发送进行实际回滚的命令,让所有数据库退回修改之前的状态。

对于单个数据库局部事务预提交的过程,进一步解释:当某一个数据库收到预提交要求后,如果可以提交属于自己的事务分支,则将自己在该事务分支中所做的操作记录下来,并给事务中间件一个同意提交的应答,此时数据库将不能再想该事务分支中加入任何操作,但此时数据库并没有真正提交改事务,底层数据库对共享资源的操作还未释放(处于上锁状态)。如果由于某种原因数据库无法提交属于自己的事务分支,将回滚自己的所有操作,释放对共享资源上的锁,并返回给事务中间件失败的应答。

在典型的Java EE应用服务器中,全局事务管理器是必须的组件。它会负责协调和管理参与全局事务的多个数据库的局部事务处理。

在一个涉及多个数据库的分布式事务处理中,为保证全局事务的完整性,两阶段提交时必须的。但是典型的两阶段提交,对数据库来说事务从开始到结束时间相对较长,在事务处理期间数据库使用的资源将一直处于锁定状态,直到事务结束才会释放。因此,使用典型的两阶段提交相对来说会占用更多的资源,因此会带来一定的性能损失。

通过使用JTA编程,开发者可以用一种与事务管理器无关的方式处理事务,Java EE应用服务器通过Java事务服务(Java Transaction ServiceJTS)来实现事务管理器。但应用程序代码无需直接调用JTS方法,只需要面向JTA方法即可,由JTA来调用底层的JTS进行处理。

如果希望使用JTA事务,可调用javax.transaction.UserTransaction接口的begincommit、rollback等方法来控制事务。

Context ctx = new InitialContext();

DataSource oracleDs = (DataSource) ctx.lookup("oracle");

DataSource otherDs = (DataSource) ctx.lookup("other");

UserTransaction tx = (UserTransaction) ctx.lookup("javax.transaction.UserTransaction");

Connection oracleConn = oracleDs.getConnection();

Connection otherConn = otherDs.getConnection();

Statement oracleStmt = null;

Statement otherStmt = null;

tx.begin();

try {

  oracleStmt = oracleConn.createStatement();

  otherStmt = otherConn.createStatement();

  int result = oracleStmt.executeUpdate("insert into dept values(50,'研发部','广州')");

  System.out.println(result == 1 ? "插入成功" : "插入失败");

  otherStmt.executeUpdate("insert into dept values(40,'市场部','广州')");

  tx.commit();

} catch (SQLException e) {

  e.printStackTrace();

  tx.rollback();

} finally {

  oracleStmt.close();

  otherStmt.close();

  oracleConn.close();

  otherConn.close();

}

上面的代码是一个典型的 JTA 事务控制逻辑,适用于 WebLogic

jboss中如果在Resource->Datasources->XA Datasources中配置后,在server\default\deploy目录下就会生成一个xxx-ds.xml的文件。

DataSource oracleDs = (DataSource) ctx.lookup("java:/oracle");

DataSource otherDs = (DataSource) ctx.lookup("java:/other");

//适用于jboss

UserTransaction tx = (UserTransaction) ctx.lookup("UserTransaction");

事务控制是保证应用程序底层数据完整性的重要手段,但事务控制对程序性能的影响也是很大的,如果应用程序的事务属性设置不合适,应用程序的性能将会大大降低。

事务隔离指的是事务处理中如何管理事务的隔离性,所谓隔离性实际上就意味着数据库如何处理并发操作的问题,当两个或者多个操作处理同一个数据时,可能引起访问的冲突和数据库的不一致。

根据JDBC规范的定义,事务的隔离设置一共分为5种级别,这5中级别的详细规定依赖于具体使用的数据库。下面是简单的介绍:

TRANSACTION_NONE:对事务和数据不进行任何隔离限制。

TRANSACTION_READ_UNCOMMITTED:这种隔离级别允许事务读取另一个事务的未提交数据。举例来说,A线程将某个账户的余额减少了1000元,即使在事务A未提交之前,当事务B试图读取该账户余额时,也将读到减少后的账户余额。在这种隔离级别下,尽管事务A没有提交,但事务B读到的总是最新的数据。但是这种隔离级别有一个很严重的问题:读取脏数据,对于前面介绍的情形,当事务B读取到未提交的账户余额之后,如果事务A又回滚了,那意味着B读的数据是不正确的。

TRANSACTION_READ_COMMITTED:这种隔离级别保证所有读到的数据都是已经提交的数据,这样可以避免第二种情况的出现,但他不允许重复读。举例来说,当事务A开始读到某条记录的余额为2000元,在事务A未提交之前,事务B把这条记录的账户余额改为1000元,并提交了事务B,当事务A再次读取时将读到1000元,这就是不可重复读。因为对于同一条数据记录,事务A读取了两次,但两次读到的结果并不相同。对于Oracle而言,TRANSACTION_READ_COMMITTED是默认的隔离级别,在应用中通常应采用这种隔离设置。

TRANSACTION_REPEATABLE_READ:这种隔离级别可以防止第二、第三种情形的出现,他是一种可重复读的事务隔离。但当其他关联表中的数据行被插入或删除时,读事务依然可能出现一种边界效应,从而造成某种程度的错觉。假设现在数据库中有两个表:表一记录当前全部学生的详细记录(假设每条记录代表一个学生);表二则记录了表一的统计信息,包括学生总人数、男生人数、女生人数等。事务A读取表一记录,并计算出学生总人数、男生人数、女生人数等统计信息,接下来事务B向表一中插入记录并修改表二的统计记录,如果此时恰好事务A去读取表二中的统计信息,并用读到的统计信息与之前通过表一计算出来的统计信息进行对比,将会发现两组统计信息并不相等(新读到的统计数据更大)。

TRANSACTION_SERIALIZABLE:这种隔离设置可以防止第二、第三、第四种情形的出现,其代表真正可串行化的事务,提供了最高级别的保护,但是这种事务方式的性能也是最低级的。

通过Connection接口定义的setTransactionIsolation()方法可以设置隔离级别,Connection接口中定义了上面的5个常量。

conn.setTransactionIsolation(Connection.TRANSACTION_REPEATABLE_READ);

由于事务隔离级别需要底层数据库的支持,但并不是每个数据库都支持所有的隔离级别,不同数据库也可能采用不同的锁定算法,因此设定时还需要查阅数据库的相关资料。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
中文名: 经典Java EE企业应用实战--基于WebLogic/JBoss的JSF+EJB 3+JPA整合开发 原名: 经典Java EE企业应用实战--基于WebLogic/JBoss的JSF+EJB 3+JPA整合开发 作者: 李刚 资源格式: PDF 版本: 第一版 出版社: 电子工业出版社书号: 9787121115349发行时间: 2010年8日 地区: 大陆 语言: 简体中文 简介: 内容简介:   本书是《轻量级java ee企业应用实战》的姊妹篇,《轻量级java ee企业应用实战》主要介绍以spring+hibernate为基础的java ee应用;本书则主要介绍以ejb 3+jpa为基础的java ee应用。ejb 3、jpa规范都属于sun公司所制订的java ee规范,因此把基于ejb 3+jpa的应用称为经典java ee架构,目前这种架构在java开发领域也有极大的市场占有率。   本书介绍了java ee规范的三大主要规范jsf、ejb 3和jpa,其中jsf是sun公司提供的jsf ri;ejb 3部分则包含session bean、message driven bean的详细介绍。所使用的应用服务器是jboss 5.1和weblogic 11g,详细介绍了这两种应用服务器的安装和使用,以及如何在两大主流服务器上安装、部署java ee应用。   本书内容主要包括三部分,第一部分介绍java ee开发的基础知识,以及如何搭建开发环境,包括安装jboss、weblogic应用服务器,以及如何使用svn、netbeans等。第二部分详细讲解了jsf ri、jta、jndi、rmi、jms、javamail、ejb 3的session bean、message driven bean、jpa、jax-ws 2、jaas等java ee知识,这部分知识以jsf+ejb 3+jpa整合开发为重点,通过使用netbeans ide工具上手,带领读者逐步深入jsf+ejb 3+jpa整合开发。这部分内容是笔者讲授“疯狂java实训”的培训讲义,也是本书的重点部分。第三部分提供了一个jsf+ejb 3+ jpa整合开发项目:电子拍卖系统。这个项目包括5个实体,这5个实体之间具有复杂的关联关系,而且业务逻辑也相对复杂,希望让读者理论联系实际,真正将jsf+ejb 3+jpa整合真正运用到实际开发中。该案例采用目前最流行、最规范的java ee架构,整个应用分为jpa实体层、eao层、业务逻辑层、mvc层和视图层,各层之间分层清晰,层与层之间以松耦合的方法组织在一起。该案例既提供了ide无关的、基于ant管理的项目源码,也提供了基于netbeans ide的项目源码,最大限度地满足读者的需求。 作者简介: 李刚,从事10年的Java EE应用开发。曾任LITEON公司的J2EE技术主管,负责该公司的企业信息平台的架构设计。曾任广州电信、广东龙泉科技等公司的技术培训导师。2007年3月26日的《电脑报》专访人物。现任新东方广州中心软件教学总监,并曾任广东技术师范学院计算机科学系的兼职副教授。   培训的学生已在华为、立信、普信、网易、电信盈科、中企动力等公司就职。   国内知名的高端IT技术作家,已出版《Spring 2.0宝典》、《基于J2EE的Ajax宝典》、《轻量级J2EE企业应用实战》、《Struts 2权威指南》、《Ruby On Rails敏捷开发最佳实践》等著作。 目录: 第0章 学习Java的正确方法 1 0.1 我适合不适合编程 2 0.2 走出象牙塔 4 0.3 学习Java,应该如此疯狂 7 第1章 经典Java EE应用和开发环境 9 1.1 经典Java EE应用概述 10 1.1.1 Java EE 6相关规范 10 1.1.2 经典Java EE应用的分层模型 11 1.1.3 经典Java EE应用的组件 13 1.1.4 经典Java EE应用架构的优势 13 1.1.5 常用的企业服务器 14 1.2 经典Java EE应用相关技术 14 1.2.1 JSP、Servlet和JavaBean及 替代技术 14 1.2.2 JSF及替代技术 15 1.2.3 EJB组件技术简介 15 1.3 JBoss的下载和安装 15 1.3.1 下载和安装JBoss服务器 16 1.3.2 配置JBoss的服务端口 18 1.3.3 进入控制台 19 1.3.4 部署Web应用 22 1.4 WebLogic的下载和安装 24 1.4.1 WebLogic的下载和安装 24 1.4.2 WebLogic的基本配置 25 1.4.3 修改WebLogic的服务端口 29 1.4.4 部署Web应用 30 1.5 NetBeans的安装和使用 32 1.5.1 NetBeans的下载和安装 32 1.5.2 使用NetBeans开发Java EE应用 33 1.5.3 打开NetBeans项目 36 1.5.4 导入Eclipse项目 37 1.6 使用SVN进行协作开发 38 1.6.1 下载和安装SVN服务器 39 1.6.2 配置SVN资源库 39 1.6.3 下载和安装SVN客户端 41 1.6.4 发布项目到服务器 41 1.6.5 从服务器下载项目 42 1.6.6 提交(Commit)修改 42 1.6.7 同步(Update)本地文件 43 1.6.8 添加文件和目录 44 1.6.9 删除文件和目录 45 1.6.10 查看文件或目录的版本变革 45 1.6.11 从以前版本重新开始 46 1.6.12 创建分支 46 1.6.13 沿着分支开发 46 1.6.14 合并分支 47 1.6.15 使用NetBeans作为SVN客户端 48 1.7 本章小结 50 第2章 JSF的基本用法 51 2.1 MVC和JSF 52 2.1.1 MVC和常见MVC框架 52 2.1.2 JSF的优势 56 2.2 下载和安装JSF 57 2.3 JSF使用入门 60 2.3.1 从输入页面开始 60 2.3.2 开发托管Bean 61 2.3.3 定义导航规则 63 2.4 解读JSF配置 65 2.4.1 配置核心控制器(FacesServlet) 65 2.4.2 JSF配置文件结构 68 2.5 托管Bean和表达式语言 69 2.5.1 托管Bean的属性和表达式语言 69 2.5.2 托管Bean的方法 78 2.5.3 托管Bean的分类 80 2.5.4 初始化托管Bean的属性 85 2.5.5 通过FacesContext访问应用环境 89 2.6 导航模型 91 2.6.1 静态导航 93 2.6.2 动态导航 93 2.7 使用UI标签创建视图页面 94 2.7.1 UI标签概述 94 2.7.2 UI标签的通用属性 97 2.7.3 表单相关标签 98 2.7.4 其他标签 103 2.8 JSF的运行流程和生命周期 109 2.8.1 恢复视图阶段 110 2.8.2 应用请求值阶段 110 2.8.3 处理输入校验阶段 111 2.8.4 更新模型的值阶段 111 2.8.5 调用应用阶段 111 2.8.6 生成响应阶段 111 2.9 利用JSF的消息 112 2.10 本章小结 116 第3章 深入使用JSF 117 3.1 JSF事件机制 118 3.1.1 Java事件模型概述 118 3.1.2 Java事件模型示例 119 3.1.3 JSF事件模型 120 3.1.4 Action事件 122 3.1.5 值改变事件 125 3.1.6 生命周期事件 128 3.1.7 将监听器绑定到Bean属性 130 3.2 JSF的国际化支持 132 3.2.1 加载国际化资源文件 132 3.2.2 使用国际化消息 134 3.2.3 动态数据国际化 137 3.2.4 让用户选择语言 142 3.3 使用转换器完成类型转换 143 3.3.1 转换器概述、用途 144 3.3.2 JSF内建转换器 144 3.3.3 使用转换器 145 3.3.4 转换失败后的错误消息 149 3.4 自定义转换器 154 3.4.1 实现转换器类 154 3.4.2 注册转换器 156 3.4.3 使用自定义转换器 159 3.4.4 绑定到Bean属性的转换器 159 3.5 使用验证器进行输入校验 161 3.5.1 输入校验概述 161 3.5.2 JSF内置校验器 162 3.5.3 校验失败后的错误消息 163 3.5.4 必填校验器 165 3.6 自定义校验器 166 3.6.1 开发自定义校验器 166 3.6.2 注册校验器 167 3.6.3 使用自定义校验器 168 3.6.4 为自定义校验器开发专用标签 169 3.6.5 使用托管Bean的方法执行校验 173 3.6.6 绑定到Bean属性的校验器 175 3.7 本章小结 177 第4章 利用JDBC和JTA访问 数据库和管理全局事务 178 4.1 JDBC和容器管理的数据源 179 4.1.1 JDBC概述 179 4.1.2 使用JDBC执行数据库访问 180 4.1.3 使用WebLogic服务器管理的 数据源 182 4.1.4 使用JBoss服务器管理的数据源 187 4.2 事务和JTA 191 4.2.1 事务的基本概念 191 4.2.2 分布式事务处理、XA规范和 2PC协议 192 4.2.3 使用JTA全局事务保证多 数据库的一致性 193 4.3 事务隔离、传播属性的设置 198 4.3.1 并发访问和隔离 198 4.3.2 事务属性 199 4.4 EJB的事务管理 201 4.4.1 容器管理事务(CMT) 201 4.4.2 Bean管理事务(BMT) 201 4.5 事务超时设置 201 4.6 本章小结 203 第5章 JNDI和远程方法调用 204 5.1 JNDI的概念 205 5.1.1 命名服务 205 5.1.2 目录服务 206 5.1.3 JNDI的优点 206 5.2 JNDI编程入门 207 5.2.1 文件系统的命名服务 207 5.2.2 JNDI编程 208 5.3 服务器提供的JNDI支持 212 5.3.1 WebLogic的JNDI支持 212 5.3.2 JBoss的JNDI支持 215 5.4 RMI概述 216 5.4.1 RMI的相关概念 216 5.4.2 RMI的作用和意义 217 5.5 RMI编程 217 5.5.1 开发RMI服务器 217 5.5.2 开发RMI客户端 220 5.5.3 RMI的基本原理 220 5.6 同时作为客户端和服务器的 RMI程序 222 5.6.1 开发客户端程序 222 5.6.2 开发服务器端程序 223 5.7 本章小结 225 第6章 利用JMS实现企业消息处理 226 6.1 面向消息的架构和JMS概述 227 6.1.1 面向消息的应用架构 227 6.1.2 JMS的基础知识和优势 228 6.1.3 JMS的两个重要版本 229 6.2 PTP类型的JMS 230 6.2.1 配置PTP的JMS服务器 231 6.2.2 PTP消息的发送 241 6.2.3 PTP消息的同步接收 244 6.2.4 PTP消息的异步接收 246 6.3 Pub-Sub类型的JMS 248 6.3.1 配置Pub-Sub模型的JMS 服务器 248 6.3.2 消息的生产、消费 250 6.3.3 可靠的JMS订阅 251 6.4 JMS消息 253 6.4.1 JMS消息类型 253 6.4.2 JMS消息头和消息属性 253 6.4.3 重用消息对象 254 6.4.4 JMS传递方式和有效时间 255 6.4.5 设置消息的优先级 256 6.4.6 消息的确认方式 256 6.4.7 消息选择器 257 6.4.8 消息的临时目的261 6.5 使用队列浏览器查看全部消息 264 6.6 JMS和事务 265 6.6.1 使用事务性Session 265 6.6.2 利用JTA全局事务 267 6.7 JMS服务器的异常监听 268 6.8 JMS集群 269 6.9 本章小结 270 第7章 利用JavaMail实现E-mail 271 7.1 E-mail简介 272 7.1.1 SMTP协议简介 272 7.1.2 POP3协议简介 272 7.1.3 IMAP4协议简介 273 7.1.4 E-mail的用途 273 7.2 JavaMail介绍 274 7.2.1 JavaMail下载和安装 274 7.2.2 JavaMail的常用API 275 7.2.3 使用JavaMail发送邮件 277 7.2.4 使用JavaMail接收邮件 281 7.3 应用服务器的JavaMail支持 287 7.3.1 在WebLogic中配置JavaMail 288 7.3.2 通过WebLogic的邮件支持来 发送邮件 290 7.3.3 在JBoss中配置JavaMail 292 7.4 本章小结 294 第8章 会话EJB 295 8.1 EJB概述 296 8.1.1 EJB的概念和意义 296 8.1.2 EJB的发展历史 298 8.1.3 EJB的优势和使用场景 299 8.2 EJB的分类 301 8.2.1 Session Bean的概念和作用 302 8.2.2 Message Driven Bean的概念和 作用 303 8.2.3 实体和JPA 303 8.3 开发无状态的Session Bean 304 8.3.1 开发远程调用的无状态 Session Bean 304 8.3.2 开发本地调用的无状态 Session Bean 311 8.4 发布Session Bean 314 8.4.1 打包EJB-JAR 315 8.4.2 Annotation与部署描述文件 315 8.5 开发有状态的Session Bean 318 8.6 Session Bean的生命周期 321 8.6.1 无状态Session Bean的生命周期 321 8.6.2 有状态Session Bean的生命周期 322 8.6.3 定制Session Bean的生命 周期行为 323 8.7 在Session Bean中使用事务 327 8.7.1 容器管理事务 327 8.7.2 Bean管理事务 330 8.8 拦截器 332 8.9 依赖注入 335 8.9.1 EJB注入 336 8.9.2 资源注入 339 8.10 配置EJB引用 340 8.11 使用计时器进行任务调度 342 8.12 本章小结 345 第9章 消息驱动EJB 346 9.1 JMS和EJB 347 9.1.1 为什么使用MDB 347 9.1.2 使用MDB的设计原则 348 9.2 使用消息驱动Bean 349 9.2.1 使用@MessageDriven和@ActivationConfigProperty 350 9.2.2 实现MessageListener 352 9.2.3 MDB的生命周期 353 9.2.4 MDB中的依赖注入 356 9.2.5 事务管理和异常处理 359 9.3 使用NetBeans开发EJB 359 9.3.1 使用NetBeans开发Session Bean 359 9.3.2 使用NetBeans开发MDB 362 9.4 本章小结 363 第10章 Java持久化API(JPA) 364 10.1 实体简介 365 10.1.1 对象/关系数据库映射(ORM) 365 10.1.2 JPA的映射规则 367 10.1.3 JPA规范简介 368 10.2 实体入门 368 10.2.1 开发实体 369 10.2.2 在Java SE环境下使用 Hibernate JPA实现 370 10.2.3 在Java SE环境下使用 TopLink JPA实现 374 10.2.4 在Java SE环境下使用 EntityManager 377 10.2.5 使用orm.xml管理O/R映射 379 10.3 理解实体 382 10.3.1 持久化上下文和持久化单元 382 10.3.2 实体类的要求 382 10.3.3 实体的状态 383 10.3.4 管理实体的方法 384 10.4 实体的基本映射387 10.4.1 映射实体类的属性 387 10.4.2 将实体映射到多个表 394 10.4.3 映射复合类型的属性 396 10.4.4 映射实体类的主键 398 10.5 关联关系映射 402 10.5.1 单向N-1关联 403 10.5.2 单向1-1关联 406 10.5.3 单向1-N关联 409 10.5.4 单向N-N关联 411 10.5.5 双向1-1关联 414 10.5.6 双向1-N关联 417 10.5.7 双向N-N关联 420 10.5.8 使用Map集合记录关联实体 423 10.5.9 对关联实体进行排序 424 10.6 继承关系映射 426 10.6.1 整个类层次对应一张表的 映射策略 427 10.6.2 连接子类的映射策略 430 10.6.3 每个具体类对应一张表的 映射策略 434 10.7 使用抽象实体和非实体父类 436 10.7.1 抽象实体 436 10.7.2 非实体父类 438 10.7.3 重定义子类实体的外键列 440 10.8 实体的生命周期和监听器 444 10.8.1 实体的生命周期与回调事件 444 10.8.2 使用专门的监听器实现回调 448 10.8.3 为全部实体配置默认监听器 450 10.8.4 排除监听器 452 10.9 本章小结 455 第11章 JPA的查询支持 456 11.1 查询API 457 11.1.1 面向对象的JPQL 457 11.1.2 查询API简介 457 11.2 执行查询 459 11.2.1 使用Query创建查询 459 11.2.2 设置查询参数 459 11.2.3 取得查询结果 460 11.3 JPQL语法 461 11.3.1 使用from子句 462 11.3.2 使用select子句 463 11.3.3 查询部分属性 463 11.3.4 查询中使用构造器 464 11.3.5 使用distinct排除相同的记录 465 11.3.6 where子句和条件表达式 466 11.3.7 使用JPQL函数 466 11.3.8 多态查询 467 11.3.9 关联和连接 469 11.3.10 使用order by进行结果排序 473 11.3.11 JPQL查询的聚集函数 473 11.3.12 使用group by进行分组 474 11.3.13 结果集分页 475 11.3.14 使用子查询 475 11.3.15 命名查询 476 11.4 批量更新和批量删除 478 11.4.1 批量更新 479 11.4.2 批量删除 480 11.5 原生SQL查询 481 11.5.1 使用原生SQL查询 481 11.5.2 结果集映射和实体查询 482 11.5.3 使用命名的原生SQL查询 486 11.5.4 调用存储过程 488 11.6 本章小结 490 第12章 Web层和EJB的整合 491 12.1 Java EE应用的架构 492 12.1.1 SSH架构的复习和应用架构的 思考 492 12.1.2 MVC层和业务层整合 494 12.1.3 DAO模式和EAO模式 495 12.1.4 使用Session Facade模式 499 12.2 从Web层访问Session Bean 500 12.2.1 使用依赖注入访问无状态 Session Bean 501 12.2.2 通过EJB引用访问有状态 Session Bean 507 12.2.3 在工具类中调用Session Bean 509 12.3 在Web层使用JPA 511 12.3.1 使用容器管理的EntityManager 512 12.3.2 在容器内使用应用程序管理的 EntityManager 516 12.3.3 通过ThreadLocal在容器外使用 安全的EntityManager 518 12.4 基于JBoss的JSF+EJB 3+JPA 整合 522 12.4.1 开发JPA实体 522 12.4.2 开发EAO对象 524 12.4.3 开发业务逻辑组件 526 12.4.4 定义JSF的托管Bean来 处理请求 527 12.5 基于WebLogic的Struts 2+ EJB 3+JPA整合 531 12.5.1 开发实体并配置持久化单元 531 12.5.2 开发EAO组件和业务逻辑组件 532 12.5.3 配置EJB引用 532 12.5.4 定义Action来处理用户请求 532 12.6 本章小结 536 第13章 EJB和Web Service 537 13.1 Web Service概述 538 13.1.1 Web Service概述 538 13.1.2 Web Service平台概述 539 13.1.3 Web Service的广泛应用 542 13.2 JAX-WS:Java EE 5 Web Service平台 543 13.2.1 Java EE的Web Service支持 543 13.2.2 为什么选择EJB开发 Web Service 544 13.3 使用JAX-WS 2.0开发 Web Service 545 13.3.1 使用@WebService 545 13.3.2 使用@WebMethod 551 13.3.3 使用@SOAPBinding指定 Web Service风格 553 13.3.4 使用@WebParam 555 13.3.5 使用@WebResult 556 13.3.6 使用@OneWay 558 13.4 客户端调用Web Service 558 13.5 本章小结 559 第14章 利用JAAS开发安全的应用 560 14.1 JAAS概述 561 14.1.1 Java EE应用的安全概述 561 14.1.2 安全域、用户、组和角色概念 561 14.1.3 JAAS的基本流程 563 14.2 管理服务器的用户和组 565 14.2.1 管理WebLogic服务器上的 用户和组 565 14.2.2 管理JBoss服务器上的用户和 角色 573 14.2.3 使用RDBMS管理Jboss 服务器上的用户和角色 574 14.3 开发安全的Web应用 576 14.3.1 声明安全性 576 14.3.2 映射安全角色 579 14.3.3 基于JBoss服务器的表单登录 580 14.3.4 基于WebLogic服务器的安全 角色映射 583 14.3.5 基于WebLogic服务器的 表单登录 583 14.3.6 Web应用中编程式安全 584 14.4 开发安全的Java EE应用 585 14.4.1 为EJB声明安全性 585 14.4.2 应用客户端访问被保护的方法 587 14.4.3 使用Web组件调用EJB被 保护的方法 588 14.4.4 EJB中编程式安全 592 14.5 使用SSL建立安全连接 592 14.5.1 SSL基础知识 593 14.5.2 安装和配置SSL支持 593 14.5.3 在配置描述符中指定安全连接 595 14.6 本章小结 597 第15章 电子拍卖系统 598 15.1 系统功能简介和架构设计 599 15.1.1 系统功能简介 599 15.1.2 系统架构设计 599 15.2 持久层设计 600 15.2.1 系统实体 601 15.2.2 系统E-R图和数据表 601 15.2.3 实现JPA 实体 603 15.2.4 管理持久化单元 612 15.3 实现系统EAO层 614 15.3.1 实现EAO基类 615 15.3.2 实现系统EAO组件 618 15.4 实现业务逻辑层 622 15.4.1 定义业务逻辑组件接口 622 15.4.2 依赖注入EAO组件 624 15.4.3 业务逻辑组件中的异常处理 625 15.4.4 处理用户竞价 627 15.4.5 判断拍卖物品状态 631 15.4.6 事务管理 633 15.5 实现系统Web层 633 15.5.1 安装JSF 633 15.5.2 处理用户登录 634 15.5.3 图形验证码 639 15.5.4 登录控制 642 15.5.5 添加物品 643 15.5.6 处理用户竞价 650 15.6 使用SiteMesh页面装饰 656 15.6.1 在Web应用中安装SiteMesh 656 15.6.2 定义页面装饰 657 15.7 本章小结 659

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值