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

JMS的消息类型

1)StreamMessage:这种类型的消息内容由序列化的对象流组成,读取消息时必须按写对象时的顺序从流中读取对象。

2)MapMessage:这种类型的消息内容由多个key-value对组成,要求key是唯一的。

3)TextMessage:这种类型的消息内容就是普通字符串。

4)ObjectMessage:该消息内容包含序列化的对象。

5)BytesMessage:该消息的内容是原始的字节流。只有当客户端需要完全控制原始消息格式时才考虑使用这种消息类型。

6)WebLogic还在TextMessage的基础上进行了扩展,扩展出了XMLMessage类型,这种类型的消息对XML消息内容的传递和选择提供了优化。

不管是那种消息对象,都是Message接口的实例。对于一个Message对象,包括

 

JMS消息中的消息头、消息属性本质上都是一系列key-value对,用于对消息的描述,可以成为消息的元数据。

消息头和消息属性的区别在于:消息头的所有key是标准的、固定的,而且Message接口为这些标准提供了相应的settergetter方法。单JMS属性则允许开发者任意定义。

Message接口中包含了添加属性的方法:setXxxProperty(String name,xxx value)

例如,msg.setStringProperty(“ConType”,”text”);

消费者可以通过getXXXProperty()来读取这些属性值。

 

当客户需要发送两个消息时,创建一个Message对象,通过修改Message对象的内容,sender可以重用发送两条消息。

对于JMS消费者,JMS消息时只读的。

sender.setDeliveryMode(DeliveryMode.PERSISTENT);

sender.setTimeToLive(20000);

上面用于修改消息的传递模式、有效时间。

NON_PERSISTENT:指定消息是一个无需持久化保存的消息。

PERSISTENT:指定消息是一个需要持久化报错的消息。

也可以在调用send方法时设置消息的传递模式或有效时间。

send(Message message,int deliveryMode,int priority,long timeToLive)

当我们将一个消息设置为需要持久化,JMS服务器会在发送之前先保存到数据库或文件中,保存完成后才会发送,因此即使系统崩溃,消息内容也不会丢失。

JMS允许生产者手动设置JMS消息的优先级,一共支持0~9个优先级,0~4是普通的优先级,5~9是较高的优先级。如果生产者没有修改JMS的优先级,那么使用默认优先级是4

JMS允许两种方式改变优先级

1,设置消息生产者的默认优先级。

2,当调用send方法时指定该消息的优先级。

sender.setPriority(9);//设置默认的优先级

如果在send方法中指定了优先级,则对于单个消息,默认优先级设置被覆盖。

JMS会一直保持着每个消息,直到消费者送回一个确认信号为止。

对于事务性的JMS,当一个事务对收到的消息进行了适当的处理,且该事务被提交之后将会反馈一个确认消息给生产者。

对于非事务性会话而言,则可以在创建JMS会话时指定消费者使用的确认方式。

Session session=conn.createSession(false/*不是事务性会话*/,

Session.AUTO_ACKNOWLEDGE);

Session接口中定义了如下几种确认方式。

1)AUTO_ACKNOWLEDGE:自动确认方式。对于同步消费者,当消费者的receive方法调用完成且没有异常发生的,系统将会自动对收到的消息进行确认;对于异步消费者,当onMessage执行完成且没有异常发生时,将会自动对收到的消息进行确认。

2)CLIENT_ACKNOWLEDGE:客户端确认方式。要求开发者使用javax.jms.Messageacknowledge方法来进行显式确认。当然并不是要求对每个消息都进行确认;相反,只要调用了acknowledge方法,将确认当前和以前收到的任何消息。

3)DUPS_OK_ACKNOWLEDGE:延迟确认方式。并不要求JMS消费者立即确认收到的消息,因此大多数情况下比AUTO_ACKNOWLEDGE的性能更好。但从另一个方面来看,当系统崩溃或网络故障时,由于JMS消费者没有立即对消息确认,JMS生产者可以重发那些已经收到的消息。

WebLogic还提供了两种确认方式

4)NO_ACKNOWLEDGE:无需确认方式,不要求消费者对收到的消息进行确认。在这种情况下,JMS服务器把消息传递给消费者之后将不再保存这些消息。

5)MULTICAST_NO_ACKNOWLEDGE:无需确认方式,主要针对通过IP广播方式把消息传递给主题订阅者的情况。

由于消费者可能只对某一部分消息感兴趣,消费者希望JMS服务器只将感兴趣的消息传递过来,因此JMS提供了消息选择器机制。消息选择器本质属于消息过滤。

消息选择器是根据消息头或消息属性来进行过滤的,对消息体的内容不做任何考虑。JMS消费者需要提供消息过滤的表达式,表达式返回true时,该消息才会被传递给消费者。JMS消息选择器的表达式是一个SQL-92的字符串表达式,该表达式由JMS消息头、消息属性和SQL-92比较运算符、逻辑运算符组成,该表达式必须返回一个boolean值。

消费者可以指定消息选择器,可以在创建消费者时指定。

createConsumer(Destination destination,String messageSelector):第二个参数用于为该消费者指定消息选择器。

MessageConsumer receiver=session.createConsumer(dest,”JMSPriority > 5”);

MessageConsumer receiver=session.createConsumer(dest,”ConType = ‘TXT’”);

 

一般JMS消息目的是在应用服务器配置管理的,消息目的被绑定到JNDI命名,即使服务器重启这些JMS消息目的也会一直存在,也可以允许客户端使用临时创建的消息目的,爱客户端退出后删除。

TemporaryQueue createTemporaryQueue():创建一个临时的消息队列

TemporaryTopic createTemporaryTopic():创建一个临时的消息主题

TemporaryQueueQueue的子类,完全可作为普通Queue使用,增加了一个delete方法,用于删除自身释放资源。TemporaryTopic则是Topic的子类,增加了一个delete方法。

关于JMS的临时目的,有3点说明:

1)客户端不应该视图在临时目的的基础上创建可靠的消息订阅

2)每个临时目的只能依附于单个的JMS连接,且只能以该JMS连接来创建临时目的的JMS消费者。

3)因为临时目的会随着服务器的重启而自动消失,因此不要希望临时目的会持久化地保存消息。任何发送到临时目的的持久化消息都会被JMS服务器自动转换为NON_PRESISTENT传递模式。

 

class MessageSender{

  TemporaryQueue tempDestionation=session.createTemporaryQueue();

  Sysytem.out.println(tempDestionation);

  msg.setJMSRelpyTo(tempDestionation);

  sender.send(msg);

  Thread.sleep(5000);

  QueueBrowser browser=session.createBrowser((javax.jms.Queue)tempDestination);

  //获取消息队列中的所有消息

  Enumeration em=browser.getEnumeration();

  while(em.hasMoreElements()){

    TextMessage acMsg=(TextMessage)em.nextElement();

    if(acMsg.getText().equals(HAS_RECEIVED)){

      System.out.println(“对方已经收到消息”);

      break

    }

  }

  //临时目的调用delete方法删除自己。

tempDestination.delete();

}

class Receiver{

MessageConsumer receiver=session.createConsumer(dest);

TextMessage msg=(TextMessage)receiver.receive();

System.out.println(msg.getText());

Destination replyTo=msg.getJMSReplyTo();

MessageProducer sender=session.createProducer(replyTo);

TextMessage replyMsg=session.createTextMessage();

replyMsg.setText(HAD_RECEIVED);

sender.send(replyMsg);

}


 JMS还提供一个QueueBrowser接口,用于浏览指定消息队列中的所有消息。

Session提供了两个方法来创建队列浏览器

createBrowser(Queue queue):根据指定的队列来创建消息浏览器

createBrowser(Queue queue,String messageSelector):第二个参数指定消息选择器。

QueueBrowser browser=session.createBrowser((javax.jms.Queue)dest);

  Enumeration em=browser.getEnumeration();

  while(em.hasMoreElements()){

    TextMessage msg=(TextMessage)em.nextElement();

    System.out.println(msg.getText());

  }

JMS并未提供API来浏览主题中的消息,这是因为发布到主题的消息在他们到达主题之后就会立即消失,虽然可靠的消息会保留,但是JMS未提供API

 

虽然JMS的消息确认机制提供了一定程度的可靠性,但是对于强健的企业仍然需要为JMS增加事务控制。

目前提供了两种事务控制方式

1,使用事务性的Session

2,在JTA全局事务中使用JMS

 

使用事务性Session

createSession(boolean transacted,int acknowledgeMode):第一个参数用于指定是否是事务性Session。如果第一个参数为true时,第二个参数的值将会被忽略。

一旦获取了事务性的Session之后,可以通过session提供的commitrollback方法来显示的提交或回滚事务。

对于生产者,使用事务性Session时,所发送的消息先会被缓存,在事务提交之前消费者不会接收到任何未提交的消息。提交后事务后,之前所有发送的消息才会被整体性地传递到消费者,如果回滚,JMS服务器将直接丢弃所有缓存的消息。

对于消费者,使用事务性Session时,可以让程序来控制消息的确认方式,正如使用CLIENT_ACKNOWLEDGE确认方式一样。消费者提交事务才会向生产者确认之前收到的消息。如果事务回滚,JMS服务器会将所有消息退还给相应的消息队列和消息主题。

在单个JMS会话期间,如果需要使用事务性的操作,则应该使用事务性会话,但是其他资源如数据库、EJB操作等则不会参与事务性会话的事务。如果需要参与,则应该考虑使用JTA事务。

class MessageSender{

  UserTransaction tx=(UserTransaction)ctx.lookup(“javax.transaction.UserTranscation”);

  tx.begin();

  ......

  tx.commit();

}

 

为了让JMS客户端可以接收到JMS服务器上的异常信息,JMS提供了一种异常监听机制,JMS的异常监听器需要实现javax.jms.ExceptionListener接口。

onException(JMSException exception):当JMS服务器上出现异常时,JMS服务器上异常监听器的该方法将会被触发。

调用sned方法引发的异常不会触发上面的方法。

ConnectionFactory connFactory=(ConnectionFactory)ctx.lookup(“...”);

  Connection conn=connFactory.createConnection();

  conn.setExceptionListener(new ExceptionListener{

    public void onException(javax.jms.JMSException ex){

      ...

    }

  }

);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值