【第十章】集成其它Web框架 之 10.3 集成Struts2.x 集成JSF ——跟我学spring3

先进行通用配置, 【第十章】集成其它Web框架 之 10.1 概述 

 

10.3  集成Struts2.x

10.3.1  概述

Struts2前身是WebWork,核心并没有改变,其实就是把WebWork改名为struts2,与Struts1一点关系没有。

 

Struts2中通过ObjectFactory接口实现创建及获取Action实例,类似于Spring的IoC容器,所以Action实例可以由ObjectFactory实现来管理,因此集成Spring的关键点就是如何创建ObjectFactory实现来从Spring容器中获取相应的Action Bean。

 

Struts2提供一个默认的ObjectFactory接口实现StrutsSpringObjectFactory,该类用于根据Struts2配置文件中相应Bean信息从Spring 容器中获取相应的Action。

 

因此Struts2.x与Spring集成需要使用StrutsSpringObjectFactory类作为中介者。

 

接下来让我们首先让我们准备Struts2x所需要的jar包

准备Struts2.x需要的jar包,到Struts官网http://struts.apache.org/下载struts-2.2.1.1版本,拷贝如下jar包到项目的lib目录下并添加到类路径:


lib\struts2-core-2.2.1.1.jar              //核心struts2包

lib\xwork-core-2.2.1.1.jar              //命令框架包,独立于Web环境,为Struts2

//提供核心功能的支持包

lib\freemarker-2.3.16.jar               //提供模板化UI标签及视图技术支持

lib\ognl-3.0.jar                       //对象图导航工具包,类似于SpEL

lib\ struts2-spring-plugin-2.2.1.1.jar      //集成Spring的插件包

lib\commons-logging-1.0.4.jar          //日志记录组件包(已有)

lib\commons-fileupload-1.2.1.jar        //用于支持文件上传的包

 

10.3.2  使用ObjectFactory集成

1、Struts2.x的Action实现:

 

java代码:
Java代码 复制代码  收藏代码
  1.        
  2. package cn.javass.spring.chapter10.struts2x.action;   
  3. import org.apache.struts2.ServletActionContext;   
  4. import com.opensymphony.xwork2.ActionSupport;   
  5. public class HelloWorldAction extends ActionSupport {   
  6.     private String message;   
  7.     @Override  
  8.     public String execute() throws Exception {   
  9.         ServletActionContext.getRequest().setAttribute("message", message);   
  10.         return "hello";   
  11.     }   
  12.     public void setMessage(String message) {//setter注入  
  13.         this.message = message;   
  14.     }   
  15. }  

 

2、JSP页面定义,使用Struts1x中定义的JSP页面“webapp/WEB-INF/jsp/hello.jsp”;

 

3、Spring一般配置文件定义(resources/chapter10/applicationContext-message.xml):

在此配置文件中定义我们使用的“message”Bean;

 

java代码:
Java代码 复制代码  收藏代码
  1. <bean id="message" class="java.lang.String">   
  2.     <constructor-arg index="0" value="Hello Spring"/>   
  3. </bean>  

 

 

4、Spring Action 配置文件定义(resources/chapter10/hello-servlet.xml):

 

java代码:
Java代码 复制代码  收藏代码
  1. <bean name="helloAction" class="cn.javass.spring.chapter10.struts2x.action.HelloWorldAction" scope="prototype">   
  2.     <property name="message" ref="message"/>   
  3. </bean>  

 

Struts2的Action在Spring中配置,而且应该是prototype,因为Struts2的Action是有状态的,定义在Spring中,那Struts如何找到该Action呢?

 

 

5、struts2配置文件定义(resources/chapter10/struts2x/struts.xml):

 

java代码:
Java代码 复制代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>   
  2. <!DOCTYPE struts PUBLIC   
  3.     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
  4.     "http://struts.apache.org/dtds/struts-2.0.dtd">   
  5. <struts>   
  6.     <constant name="struts.objectFactory" value="org.apache.struts2.spring.StrutsSpringObjectFactory"/>   
  7.     <constant name="struts.devMode" value="true"/>   
  8.     <package name="default" extends="struts-default">   
  9.         <action name="hello" class="helloAction">   
  10.             <result name="hello" >/WEB-INF/jsp/hello.jsp</result>   
  11.         </action>   
  12.     </package>   
  13. </struts>  
  • struts.objectFactory:通过在Struts配置文件中使用常量属性struts.objectFactory来定义Struts将要使用的ObjectFactory实现,此处因为需要从Spring容器中获取Action对象,因此需要使用StrutsSpringObjectFactory来集成Spring;
  • <action name="hello" class="helloAction">:StrutsSpringObjectFactory对象工厂将根据<action>标签的class属性去Spring容器中查找同名的Action Bean;即本例中将到Spring容器中查找名为helloAction的Bean。

 

6、web.xml部署描述符文件定义(webapp/WEB-INF/web.xml):

 

6.1、由于Struts2只能使用通用配置,因此需要在通用配置中加入Spring Action配置文件(chapter10/struts2x/struts2x-servlet.xml):

 

java代码:
Java代码 复制代码  收藏代码
  1. <context-param>   
  2.     <param-name>contextConfigLocation</param-name>   
  3.     <param-value>   
  4.         classpath:chapter10/applicationContext-message.xml,   
  5.         classpath:chapter10/struts2x/struts2x-servlet.xml   
  6.     </param-value>   
  7. </context-param>  

       Struts2只能在通用配置中指定所有Spring配置文件,并没有如Struts1自己指定Spring配置文件的实现。

 

6.2、Strut2前端控制器定义,在web.xml中添加如下配置:

 

java代码:
Java代码 复制代码  收藏代码
  1. <!-- Struts2.x前端控制器配置开始   -->   
  2. <filter>   
  3.     <filter-name>struts2x</filter-name>   
  4.     <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>   
  5.     <init-param>   
  6.               <param-name>config</param-name>   
  7.               <param-value>   
  8.                      struts-default.xml,struts-plugin.xml,chapter10/struts2x/struts.xml   
  9.                </param-value>   
  10.        </init-param>   
  11. </filter>   
  12. <filter-mapping>   
  13.     <filter-name>struts2x</filter-name>   
  14.     <url-pattern>*.action</url-pattern>   
  15. </filter-mapping>   
  16. <!-- Struts2.x前端控制器配置结束   -->  
  • FilterDispatcher:Struts2前端控制器为FilterDispatcher,是Filter实现,不是Servlet;
  • config:通过初始化参数config指定配置文件为struts-default.xml,struts-plugin.xml,chapter10/struts2x/struts.xml;如果不知道该参数则默认加载struts-default.xml,struts-plugin.xml,struts.xml(位于webapp/WEB-INF/classes下);显示指定时需要将struts-default.xml,struts-plugin.xml也添加上。
  • *.action:将拦截以“.action”结尾的HTTP请求;
  • struts2x:FilterDispatcher前端控制器的名字为struts2x,因此相应的Spring配置文件名为struts2x-servlet.xml。

 

7、执行测试,在Web浏览器中输入http://localhost:8080/hello.action可以看到“Hello Spring”信息说明Struts2集成成功。

 

 

 

集成Strut2也是非常简单,在此我们总结一下吧:

  • 配置文件位置:

         Struts配置文件默认加载“struts-default.xml,struts-plugin.xml, struts.xml”,其中struts-default.xml和struts-plugin.xml是Struts自带的,而struts.xml是我们指定的,默认位于webapp/WEB-INF/classes下;

         如果需要将配置文件放到其他位置,需要在web.xml的<filter>标签下,使用初始化参数config指定,如“struts-default.xml,struts-plugin.xml,chapter10/struts2x/struts.xml”,其中“struts-default.xml和struts-plugin.xml”是不可省略的,默认相对路径是类路径。

  • 集成关键ObjectFactory:在Struts配置文件或属性文件中使用如下配置知道使用StrutsSpringObjectFactory来获取Action实例:

 在struts.xml中指定:

 

java代码:
Java代码 复制代码  收藏代码
  1. <constant name="struts.objectFactory" value="org.apache.struts2.spring.StrutsSpringObjectFactory"/>  

 

或在struts.properties文件(webapp/WEB-INF/classes/)中:

 

java代码:
Java代码 复制代码  收藏代码
  1. struts.objectFactory=org.apache.struts2.spring.StrutsSpringObjectFactory  

 

  • 集成关键Action定义:

                StrutsSpringObjectFactory将根据Struts2配置文件中的<action class=””>标签的classes属性名字去到Spring配置文件中查找同名的Bean定义,这也是集成的关键。

 【第十章】集成其它Web框架 之 10.3 集成Struts2.x 集成JSF ——跟我学spring3_第1张图片

  • Spring配置文件中Action定义:由于Struts2的Action是有状态的,因此应该将Bean定义为prototype。

 

如图10-5,Sturt2与Spring集成的关键就是StrutsSpringObjectFactory,注意图只是说明Struts与Spring如何通过中介者StrutsSpringObjectFactory来实现集成,不能代表实际的类交互。

 【第十章】集成其它Web框架 之 10.3 集成Struts2.x 集成JSF ——跟我学spring3_第2张图片

图10-5 Strut2与Spring集成

 

 

原创内容,转载请注明出处【http://sishuok.com/forum/blogPost/list/0/2512.html

10.4  集成JSF

10.4.1  概述

       JSF(JavaServer Faces)框架是Java EE标准之一,是一个基于组件及事件驱动的Web框架,JSF只是一个标准(规范),目前有很多厂家实现,如Oracle的默认标准实现Mojarra、Apache的MyFaces、Jboss的RichFaces 等。

 

       本示例将使用Oracle标准实现Mojarra,请到官网http://javaserverfaces.java.net/下载最新的JSF实现。

 

       JSF目前有JSF1.1、JSF1.2、JSF2版本实现。

 

       Spring集成JSF有三种种方式:

  • 最简单集成:使用FacesContextUtils工具类的getWebApplicationContext方法,类似于Struts1x中的最简单实现;
  • VariableResolver实现:Spring提供javax.faces.el.VariableResolver的两种实现DelegatingVariableResolver和SpringBeanVariableResolver,此方式适用于JSF1.1、JSF1.2及JSF2,但在JSF1.2和JSF2中不推荐使用该方式,而是使用第三种集成方式;
  • ELResolver实现:Spring提供javax.el.ELResolver (Unified EL)实现SpringBeanFacesELResolver用于集成JSF1.2和JSF2。

 

接下来让我们首先让我们准备JSF所需要的jar包:

首先准备JSF所依赖的包:

commons-digester.jar                  //必须,已有

commons-collections.jar                //必须,已有

commons-beanutils.jar                 //必须,已有

jsp-api.jar                                   //必须,已有

servlet-api.jar                              //必须,已有                          

jstl.jar                                        //可选

standard.jar                                //可选

 

准备JSF包,到http://javaserverfaces.java.net/下载相应版本的Mojarra实现,如下载JSF1.2实现mojarra-1.2_15-b01-FCS-binary.zip,拷贝如下jar包到类路径:

lib\jsf-api.jar                           //JSF规范接口包

lib\jsf-impl.jar                          //JSF规范实现包

 

 

 

10.4.2  最简单集成

类似于Struts1x中的最简单集成,Spring集成JSF也提供类似的工具类FacesContextUtils,使用如下方式获取WebApplicationContext:

 

java代码:
Java代码 复制代码  收藏代码
  1. WebApplicationContext ctx = FacesContextUtils.getWebApplicationContext(FacesContext.getCurrentInstance());   
  2.    

       当然我们不推荐这种方式,而是推荐使用接下来介绍的另外两种方式。

 

10.4.2  使用VariableResolver实现集成

Spring提供javax.faces.el.VariableResolver的两种实现DelegatingVariableResolver和SpringBeanVariableResolver,其都是Spring与JSF集成的中介者,此方式适用于JSF1.1、JSF1.2及JSF2:

  • DelegatingVariableResolver:首先委托给JSF默认VariableResolver实现去查找JSF管理Bean,如果找不到再委托给Spring容器去查找Spring管理Bean;
  • SpringBeanVariableResolver:其与DelegatingVariableResolver查找正好相反,首先委托给Spring容器去查找Spring管理Bean,如果找不到再委托给JSF默认VariableResolver实现去查找JSF管理Bean。

 

接下来看一下如何在JSF中集成Spring吧(本示例使用JSF1.2,其他版本的直接替换jar包即可):

 

1、JSF管理Bean(Managed Bean)实现:

 

java代码:
Java代码 复制代码  收藏代码
  1. package cn.javass.spring.chapter10.jsf;   
  2. public class HelloBean {   
  3.     private String message;   
  4.     public void setMessage(String message) {   
  5.         this.message = message;   
  6.     }   
  7.     public String getMessage() {   
  8.         return message;   
  9.     }   
  10. }   
  11.    

 

2、JSF配置文件定义(resources/chapter10/jsf/faces-config.xml):

 

java代码:
Java代码 复制代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>   
  2. <faces-config version="1.2" xmlns="http://java.sun.com/xml/ns/javaee"  
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4. xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-facesconfig_1_2.xsd">   
  5.     
  6.     <application>   
  7.         <variable-resolver>   
  8.             org.springframework.web.jsf.DelegatingVariableResolver   
  9.         </variable-resolver>   
  10.     </application>   
  11.       
  12.     <managed-bean>   
  13.         <managed-bean-name>helloBean</managed-bean-name>   
  14.         <managed-bean-class>   
  15.             cn.javass.spring.chapter10.jsf.HelloBean   
  16.         </managed-bean-class>   
  17.         <managed-bean-scope>request</managed-bean-scope>   
  18.         <managed-property>   
  19.             <property-name>message</property-name>   
  20.             <value>#{message}</value>   
  21.         </managed-property>   
  22.     </managed-bean>         
  23. </faces-config>  
  • 与Spring集成:通过<variable-resolver>标签来指定集成Spring的中介者DelegatingVariableResolver;
  • 注入Spring管理Bean:通过<managed-property>标签的<value>#{message}</value>注入Spring管理Bean“message”。

 

4、JSP页面定义(webapp/hello-jsf.jsp):

 

java代码:
Java代码 复制代码  收藏代码
  1.        
  2. <%@ page language="java" pageEncoding="UTF-8" contentType="text/html; charset=UTF-8"%>   
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">   
  4. <%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %>   
  5. <%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %>   
  6. <f:view>   
  7. <html>   
  8. <head>   
  9.     <title>Hello World</title>   
  10. </head>   
  11. <body>   
  12.     <h:outputText value="#{helloBean.message}"/>   
  13. </body>   
  14. </html>   
  15. </f:view>  

 

 

5、JSF前端控制器定义,在web.xml中添加如下配置:

 

指定JSF配置文件位置,通过javax.faces.CONFIG_FILES上下文初始化参数指定JSF配置文件位置,多个可用“,”分割,如果不指定该参数则默认加载的配置文件为“/WEB-INF/ faces-config.xml”:

 

java代码:
Java代码 复制代码  收藏代码
  1. <!-- JSF配置文件开始 -->   
  2. <context-param>   
  3.     <param-name>javax.faces.CONFIG_FILES</param-name>   
  4.     <param-value>   
  5.         /WEB-INF/classes/chapter10/jsf/faces-config-jsf1x.xml   
  6.     </param-value>   
  7. </context-param>   
  8. <!-- JSF配置文件结束 -->  

 

前端控制器定义:使用FacesServlet作为JSF的前端控制器,其拦截以“.jsf”结尾的HTTP请求:

 

 

java代码:
Java代码 复制代码  收藏代码
  1. <!-- jsf前端控制器配置开始   -->   
  2. <servlet>   
  3.     <servlet-name>jsf</servlet-name>   
  4.     <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>   
  5. </servlet>   
  6. <servlet-mapping>   
  7.     <servlet-name>jsf</servlet-name>   
  8.     <url-pattern>*.jsf</url-pattern>   
  9. </servlet-mapping>   
  10. <!-- jsf前端控制器配置结束   -->  

 

7、执行测试,在Web浏览器中输入http://localhost:8080/hello-jsf.jsp可以看到“Hello Spring”信息说明JSF集成成功。

 

自此,JSF集成Spring已经成功,在此可以把DelegatingVariableResolver替换为SpringBeanVariableResolver,其只有在查找相应依赖时顺序是正好相反的,其他完全一样。

如果您的项目使用JSF1.2或JSF2,推荐使用SpringBeanFacesELResolver,因为其实标准的Unified EL实现,而且VariableResolver接口已经被注释为@Deprecated,表示可能在以后的版本中去掉该接口。

 

10.4.2         使用ELResolver实现集成

JSF1.2之前,JSP和JSF各个使用自己的一套表达式语言(EL Language),即如JSF使用VariableResolver实现来解析JSF EL表达式,而从JSF1.2和JSP2.1开始使用Unified EL,从而统一了表达式语言。

 

因此集成JSF1.2+可以通过实现Unified EL来完成集成,即Spring提供ELResolver接口实现SpringBeanFacesELResolver用于集成使用。

类似于VariableResolver实现,通过SpringBeanFacesELResolver集成首先将从Spring容器中查找相应的Spring管理Bean,如果没找到再通过默认的JSF ELResolver实现查找JSF管理Bean。

 

接下来看一下示例一下吧:

 

1、 添加Unified EL所需要的jar包:

el-api.jar                                       //Unified EL规范接口包

 

由于在Jetty中已经包含了该api,因此该步骤可选。

 

 

2、 修改JSF配置文件(resources/chapter10/jsf/faces-config.xml):

 

将如下配置

 

java代码:
Java代码 复制代码  收藏代码
  1. <variable-resolver>   
  2.     org.springframework.web.jsf.DelegatingVariableResolver   
  3. </variable-resolver>  

 

修改为:

 

java代码:
Java代码 复制代码  收藏代码
  1. <el-resolver>   
  2. org.springframework.web.jsf.el.SpringBeanFacesELResolver   
  3. </el-resolver>  

 

 

3、执行测试,在Web浏览器中输入http://localhost:8080/hello-jsf.jsp可以看到“Hello Spring”信息说明JSF集成成功。

 

自此JSF与Spring集成就算结束了,是不是也很简单。

 

 

原创内容,转载请注明出处【http://sishuok.com/forum/blogPost/list/0/2513.html

你可能感兴趣的:(【第十章】集成其它Web框架 之 10.3 集成Struts2.x 集成JSF ——跟我学spring3)