(翻译)Spring到Java EE的迁移

原文http://www.oracle.com/technetwork/articles/java/springtojavaee-522240.html

 

By David Heffelfinger

CTO and ardent Java EE fan David Heffelfinger demonstrates how easy it is to develop the data layer of an application using Java EE, JPA, and the NetBeans IDE instead of the Spring Framework.

Published October 2011

 

Introduction

Spring框架的追随者声称他们选择的框架要比Java EE好用的多。毫无疑问我是一个Java EE粉丝,写过好几本书来详述该门技术。然而,和大多数开发者相同,我并不总是直接选择Java,根据情况有时候会选择Spring

每次我做Spring工程时都会紧张,因为我知道一定会使用冗长的费解的XML文件来决定工程的行为。我也知道这个工程会有差不多10000项依赖并且产生出来的WAR更是巨兽。

使用Java EE时,我需要的大多数服务都由应用服务器提供好了。所以,需要的依赖项目很少。多数情况下,Java EE会提供配置(也有少量例外),也就是说我自己需要进行的配置很少,因为默认配置能满足绝大多数情况。当必须配置时,通常使用注解完成。注解让我只浏览代码就能了解工程全景而无需来来回回查看XML和源文件。

除了前面提到的好处,使用Java EE建立工程还能享受到来自高级工具NetBeans的好处。而且如果我足够幸运的话,使用GlassFish服务器开源版本或者Oracle GlassFish服务器做我的服务器,就能利用“保存时部署”特性(每次保存项目文件时都会自动部署到GlassFish服务器)。

本系列将用Java EE重写Spring提供的Pet Clinic应用。这是第一篇,我将图解如何使用牛逼的NetBeans来快速开发和用Spring版本相同功能的应用。该Java EE版本会使用JavaServer FacesJSF)作为用户接口,数据访问对象(DAO)使用EJB3.1会话bean实现,数据访问由Java Persistence APIJPA2.0提供。

本文中我们会使用已经存在的数据库来生成持久层,以开始开发我们的Java EE版本。在第二部分,我们将看到NetBeans是如何帮助我们产生EJB3.1会话bean来作为DAO的,还有JSF2.0来作为用户接口。

 这里我们假设本地工作站上安装了MySQLpetclinic数据库也已经存在。(创建也容易,运行Pet Clinic中的setupDB ANT目标就行。)

 

首先创建web工程, as shown in Figure 1.

Figure 1. Creating a New Project

指定名称和位置, as shown in Figure 2.通常,按默认的就可以。

Figure 2. Specifying a Name and Location for the New Project

现在选择框架,我们使用的是标准Java EE所以选择JavaServer Faces, as shown in Figure 3.

Figure 3. Selecting JavaServer Faces as the Framework

现在选择服务器和Java EE版本, as shown in Figure 4. 默认值就可以。

Figure 4. Selecting the Server and Java EE Version

现在点击Finish完成创建, as shown in Figure 5.

Figure 5. The Newly Created Project

接下来开始开发.

Developing the Application

 

NetBeans生成了开发我们Java EE应用所需的大部分代码,它能帮我们生成JPA实体、DAO、JSF页面、JSF托管bean。

首先需要开发我们的JPA实体。大多数JPA实现都包括了从JPA实体生成数据库表的能力;然而,反过来不可以。JPA没有提供从数据库表生成JPA实体的能力。

所以多数情况下需要手动编写JPA实体和添加注解、属性、getter、setter等等。不过使用netBeans就不用了,它可以从数据看自动生成JPA实体。选择File | New,在Persistence 目录下选择 Entity Classes from Database, as shown in Figure 6.

Figure 6. Selecting Entity Classes from Database

现在需要数据源。没有的话可以当场创建。as shown in Figure 7.

Figure 7. Creating a Data Source

只要输入 Java Naming and Directory Interface (JNDI) 名字即可, as shown in Figure 8.

Figure 8. Selecting a Database Connection

再次强调,如果没有数据库连接建立到目标数据库上,可以通过向导随时创建。创建后的第一件事就是指定JDBC驱动, as shown in Figure 9.

Figure 9. Selecting a Driver

然后要指定主机、端口、数据库、密码, as shown in Figure 10.记得点击Test Connection查看配的对不对,对的话会看见 “Connection Succeeded” .

Figure 10. Specifying Additional Details and Testing the Connection

用 MySQL的话,schema就是database. 所以Select schema 这里是灰色的, as shown in Figure 11.

Figure 11. Selecting a Schema

 

现在点击Finish就创建了数据库连接。继续点击OK直到返回New Entity Classes from Database屏幕。图12。

NB会通过数据库表名尝试猜测出实体类的名称。petclinic数据库使用了复数表名(如owners, pets, specialties),但是我们想要使用相应的单数名词(如Owner, Pet, Specialty)。哈哈,NB就有这功能:它允许修改默认的JPA实体类名称,这里双击名称即可。

现在可以随便选择为JPA实体的每个字段生成命名查询、JAXB注解和持久化单元了。多数情况下选择一三两项是好主意,我们可能用不到JAXB注解,不过选了也没事。

Figure 12. Specifying Entity Classes

点 Next, 指定mapping options, as shown in Figure 13.

 

 Association Fetch 列中,可以选择如何关联实体并加载。默认是一对一、多对一强加载、一对多、多对多懒加载。可以随便选一个,多数情况下默认的是最好的。

Figure 13. Specifying How Associated Entities Are Loaded

 

 

未完待续

猜你喜欢

转载自somefuture.iteye.com/blog/1330540
今日推荐