`

flex j2ee整合

    博客分类:
  • flex
阅读更多

本文摘自http://www.ibm.com/developerworks/cn/java/j-lo-jeeflex/#listing1

 

Flex 集成到 Java EE 应用程序的最佳实践

传统的 Java EE 应用程序通常使用某种 MVC 框架(例如,Struts)作为前端用户界面,随着 Flex 的兴起,基于 RIA 的客户端能够给用户带来更酷的界面,更短的响应时间,以及更接近于桌面应用程序的体验。本文将讲述如何将 Flex 集成至一个现有的 Java EE 应用程序中,以及如何应用最佳实践高效率地并行开发 Java EE Flex

开发环境

本文的开发环境为 Windows 7 UltimateEclipse 3.4Flex Builder 3(从 参考资源 获得下载链接)。Java EE 服务器使用 Resin 3.2,当然,您也可以使用 Tomcat 等其他 Java EE 服务器。

 



现有的 Java EE 应用

假定我们已经拥有了一个管理雇员信息的 Java EE 应用,名为 EmployeeMgmt-Server,结构如 1 所示:


1. Java EE 工程结构

这是一个典型的 Java EE 应用,使用了流行的 Spring 框架。为了简化数据库操作,我们使用了内存数据库 HSQLDB。对这个简单的应用,省略了 DAO,直接在 Façade 中通过 Spring JdbcTemplate 操作数据库。最后,EmployeeMgmt 应用通过 Servlet JSP 页面为用户提供前端界面:


2. EmployeeMgmt Web 界面

该界面为传统的 HTML 页面,用户每次点击某个链接都需要刷新页面。由于 Employee Management 系统更接近于传统的桌面应用程序,因此,用 Flex 重新编写界面会带来更好的用户体验。

 

 

集成 BlazeDS

如何将 Flex 集成至该 Java EE 应用呢?现在,我们希望用 Flex 替换掉原有的 Servlet JSP 页面,就需要让 Flex Java EE 后端通信。Flex 支持多种远程调用方式,包括 HTTPWeb Services AMF。不过,针对 Java EE 开发的服务器端应用,可以通过集成 BlazeDS,充分利用 AMF 协议并能轻易与 Flex 前端交换数据,这种方式是 Java EE 应用程序集成 Flex 的首选。

BlazeDS Adobe LifeCycle Data Services 的开源版本,遵循 LGPL v3 授权,可以免费使用。BlazeDS Flex 提供了基于 AMF 二进制协议的远程调用支持,其作用相当于 Java RMI。有了 BlazeDS,通过简单的配置,一个 Java 接口就可以作为服务暴露给 Flex,供其远程调用。

尽管现有的 EmployeeMgmt 应用程序已经有了 Façade 接口,但这个接口是暴露给 Servlet 使用的,最好能再为 Flex 定义另一个接口 FlexService,并隐藏 Java 语言的特定对象(如 清单 1 所示):


清单 1. FlexService interface

              

public interface FlexService {

    Employee createEmployee(String name, String title, boolean gender, Date birth);

    void deleteEmployee(String id);

    Employee[] queryByName(String name);

    Employee[] queryAll();

}

 

 

现在,Java EE 后端与 Flex 前端的接口已经定义好了,要完成 Java EE 后端的接口实现类非常容易,利用 Spring 强大的依赖注入功能,可以通过几行简单的代码完成:


清单 2. FlexServiceImpl class

              

public class FlexServiceImpl implements FlexService {

    private static final Employee[] EMPTY_EMPLOYEE_ARRAY = new Employee[0];

    private Facade facade;

 

    public void setFacade(Facade facade) {

        this.facade = facade;

    }

 

    public Employee createEmployee(String name, String title, boolean gender,

        Date birth) {

        return facade.createEmployee(name, title, gender, birth);

    }

 

    public void deleteEmployee(String id) {

        facade.deleteEmployee(id);

    }

 

    public Employee[] queryAll() {

        return facade.queryAll().toArray(EMPTY_EMPLOYEE_ARRAY);

    }

 

    public Employee[] queryByName(String name) {

        return facade.queryByName(name).toArray(EMPTY_EMPLOYEE_ARRAY);

    }

}

 

 

然后,我们将 BlazeDS 所需的 jar 包放至 /WEB-INF/lib/BlazeDS 需要如下的 jar


清单 3. BlazeDS 依赖的 Jar

              

backport-util-concurrent.jar

commons-httpclient.jar

commons-logging.jar

flex-messaging-common.jar

flex-messaging-core.jar

flex-messaging-proxy.jar

flex-messaging-remoting.jar

 

 

web.xml 中添加 HttpFlexSession Servlet 映射。HttpFlexSession BlazeDS 提供的一个 Listener,负责监听 Flex 远程调用请求,并进行一些初始化设置:


清单 4. 定义 Flex Listener

              

<listener>

    <listener-class>flex.messaging.HttpFlexSession</listener-class>

</listener>

 

 

MessageBrokerServlet 是真正处理 Flex 远程调用请求的 Servlet,我们需要将其映射到指定的 URL


清单 5. 定义 Flex servlet

              

<servlet>

    <servlet-name>messageBroker</servlet-name>

    <servlet-class>flex.messaging.MessageBrokerServlet</servlet-class>

    <init-param>

        <param-name>services.configuration.file</param-name>

        <param-value>/WEB-INF/flex/services-config.xml</param-value>

    </init-param>

    <load-on-startup>0</load-on-startup>

</servlet>

 

<servlet-mapping>

    <servlet-name>messageBroker</servlet-name>

    <url-pattern>/messagebroker/*</url-pattern>

</servlet-mapping>

 

 

BlazeDS 所需的所有配置文件均放在 /WEB-INF/flex/ 目录下。BlazeDS 将读取 services-config.xml 配置文件,该配置文件又引用了 remoting-config.xmlproxy-config.xml messaging-config.xml 3 个配置文件,所以,一共需要 4 个配置文件。

由于 BlazeDS 需要将 Java 接口 FlexService 暴露给 Flex 前端,因此,我们在配置文件 remoting-config.xml 中将 FlexService 接口声明为一个服务:


清单 6. 定义 flexService 服务

              

<destination id="flexService">

    <properties>

        <source>org.expressme.employee.mgmt.flex.FlexServiceImpl</source>

        <scope>application</scope>

    </properties>

</destination>

 

 

服务名称通过 destination id 属性指定,Flex 前端通过该服务名称来进行远程调用。scope 指定为 application,表示该对象是一个全局对象。

然而,按照默认的声明,BlazeDS 会去实例化 FlexService 对象。对于一个 Java EE 应用来说,通常这些服务对象都是被容器管理的(例如,Spring 容器或 EJB 容器),更合适的方法是查找该服务对象而非直接实例化。因此,需要告诉 BlazeDS 通过 Factory 来查找指定的 FlexService 对象,修改配置如下:


清单 7. 通过 factory 定义 flexService

              

<destination id="flexService">

    <properties>

        <factory>flexFactory</factory>

        <source>flexService</source>

        <scope>application</scope>

    </properties>

</destination>

 

 

现在,Flex 如何才能通过 BlazeDS 调用 FlexService 接口呢?由于 FlexService 对象已经被 Spring 管理,因此,我们需要编写一个 FlexFactory 告诉 BlazeDS 如何找到 Spring 管理的 FlexService 的实例。flexFactory services-config.xml 中指定:


清单 8. 定义 flexFactory

              

<factories>

    <factory id="flexFactory" class="org.expressme.employee.mgmt.flex.FlexFactoryImpl"/>

</factories>

 

 

FlexFactoryImpl 实现了 FlexFactory 接口,该接口完成两件事情:

1         创建 FactoryInstance 对象;

2         通过 FactoryInstance 对象查找我们需要的 FlexService

因此,需要一个 FactoryInstance 的实现类,我们编写一个 SpringFactoryInstance,以便从 Spring 的容器中查找 FlexService


清单 9. SpringFactoryInstance class

              

class SpringFactoryInstance extends FactoryInstance {

    private Log log = LogFactory.getLog(getClass());

 

    SpringFactoryInstance(FlexFactory factory, String id, ConfigMap properties) {

        super(factory, id, properties);

    }

 

    public Object lookup() {

        ApplicationContext appContext = WebApplicationContextUtils.

                getRequiredWebApplicationContext(

                    FlexContext.getServletConfig().getServletContext()

        );

        String beanName = getSource();

        try {

            log.info("Lookup bean from Spring ApplicationContext: " + beanName);

            return appContext.getBean(beanName);

        }

        catch (NoSuchBeanDefinitionException nex) {

            ...

        }

        catch (BeansException bex) {

            ...

        }

        catch (Exception ex) {

            ...

        }

    }

}

 

 

FlexFactoryImpl 负责实例化 SpringFactoryInstance 并通过 SpringFactoryInstance lookup() 方法查找 FlexService 接口对象:


清单 10. FlexFactoryImpl class

              

public class FlexFactoryImpl implements FlexFactory {

    private Log log = LogFactory.getLog(getClass());

 

    public FactoryInstance createFactoryInstance(String id, ConfigMap properties) {

        log.info("Create FactoryInstance.");

        SpringFactoryInstance instance = new SpringFactoryInstance(this, id, properties);

        instance.setSource(properties.getPropertyAsString(SOURCE, instance.getId()));

        return instance;

    }

 

    public Object lookup(FactoryInstance instanceInfo) {

        log.info("Lookup service object.");

        return instanceInfo.lookup();

    }

 

    public void initialize(String id, ConfigMap configMap) {

    }

}

 

 

以下是 BlazeDS 查找 FlexService 接口的过程:

1.     BlazeDS 将首先创建 FlexFactory 的实例—— FlexFactoryImpl

2.     当接收到

Flex

分享到:
评论

相关推荐

    flex J2ee整合环境搭建

    在构建Java EE(J2EE)与Flex集成的开发环境时,MyEclipse是一个非常实用的工具。本篇文章将详细讲解如何配置MyEclipse以实现Flex与Java EE的协同开发,提升开发效率。 首先,我们需要准备以下软件: 1. Eclipse ...

    flex和j2ee整合

    flex和j2ee整合 Flex 学习入门

    Flex与j2ee的整合

    通过以上步骤,我们能够完成一个基本的Flex与J2EE整合的增删改查应用。这种结合方式不仅提供了丰富的用户体验,也充分利用了J2EE平台的后端能力,为开发复杂的业务系统提供了可能。在实际项目中,可以根据具体需求...

    Flex和j2ee整合.rar

    标题中的“Flex和j2ee整合.rar”指的是将Adobe Flex技术与Java EE(通常简称为J2EE)平台集成的过程。Flex是一种用于构建富互联网应用程序(RIA)的开放源码框架,它允许开发者创建交互性强、用户体验良好的Web应用...

    flex和j2ee整合.doc

    本文主要介绍的是如何将Flex与J2EE平台进行整合,以实现富互联网应用程序(RIA)的开发。Flex是一种用于构建交互式用户界面的客户端技术,而J2EE是Java企业级应用的开发框架。通过BlazeDS这个中间件,可以使得Flex与...

    flex和j2ee整合,包含项目操作的步骤图片

    Flex 和 J2EE 整合是将 Adobe Flex 前端技术与 Java 服务器端平台(J2EE)结合,实现富互联网应用(RIA)的一种方法。以下是对整合过程的详细解释: 1. **下载 Flex 配置文件及 JAR 包**: 在开始配置前,需要访问...

    基于Flex与J2EE的整合应用

    【基于Flex与J2EE的整合应用】 在传统的Web开发中,表示层的限制往往导致用户体验受限。然而,Rich Internet Application (RIA) 技术,尤其是Adobe Flex,为Web应用的表示层带来了革命性的变化。Flex以其强大的面向...

    FlexModule_j2ee Flex 与JSP 整合用的.jar 文件

    FlexModule_j2ee 是一个专为整合Flex与JSP应用设计的组件库,它提供了一个.jar文件,使得在Java服务器端(JSP)与客户端的Adobe Flex之间建立交互变得更加便捷。Flex是一种强大的富互联网应用程序(RIA)开发技术,...

    flex整合j2ee-在eclipse wtp环境下使用blazeds

    在Flex4+BlazeDS整合J2EE实例中,提供的两个文档"Flex4+BlazeDS整合J2EE实例(非插件).doc"和"Flex4+BlazeDS整合J2EE实例(插件)"应该分别涵盖了不使用Eclipse插件和使用插件(如FlexBuilder)进行整合的步骤和示例。...

    Flex+Blazeds与J2ee整合

    ### Flex+Blazeds与J2ee整合 #### 背景介绍 随着技术的发展,企业级应用开发中,前端与后端之间的交互变得尤为重要。Adobe Flex作为一种强大的RIA(Rich Internet Applications)技术,允许开发者创建丰富的用户...

    J2ee整合flex3项目

    **J2EE整合Flex3项目详解** 在现代企业级应用开发中,J2EE(Java 2 Platform, Enterprise Edition)和Adobe Flex是两种常见的技术,分别用于后端服务和前端用户体验的构建。J2EE提供了丰富的服务器端功能,如数据库...

    Flex整合J2EE开发小记+源码下载

    3. **AMF(Action Message Format)**:在Flex和J2EE整合中,AMF作为数据传输协议,能高效地在客户端和服务器之间传递数据,降低了网络通信的开销。 4. ** BlazeDS或LCDS**:BlazeDS是Adobe提供的开源服务器端技术...

    整合flex与j2ee

    标题“整合flex与j2ee”揭示了一个关键的技术主题,即如何将Adobe Flex前端开发框架与Java Enterprise Edition(J2EE)后端平台相结合,以构建富互联网应用程序(RIA)。Flex是一款强大的工具,用于创建交互式的、...

    flex3整合j2ee开发配置

    《Flex3整合J2EE开发配置详解》 在IT行业中,Flex3与J2EE的整合是构建富互联网应用程序(RIA)的一种常见方法,它能够实现动态、交互式的前端界面与强大后端服务的无缝连接。本文将详细介绍如何在Eclipse环境中配置...

    flex j2ee工程_2

    文件大于20M了,所以分了两个传的。 BlazeDs(flex)+hibernate+spring WEB项目的实例工程。 是我整理的一个例子。 关于BlazeDs(flex)+hibernate+spring的整合。

    FlexModule_j2ee.zip

    5. **部署配置**:可能包含Web应用的部署描述符(如web.xml),定义了Servlet和过滤器,以及Flex与JSP的整合设置。 6. **资源文件**:项目可能包含样式表(CSS)、图片和其他静态资源,这些资源会被JSP和Flex共同...

Global site tag (gtag.js) - Google Analytics