在struts1.1中使用应用模块(Application Modules) 
 Struts 1.1的一个新特性是应用模块的概念。应用模块允许将单个Struts应用划分成几个模块,每个模块有自己的Struts配置文件, JSP页面,Action等等。这个新特性是为了解决大中型的开发队伍抱怨最多的一个问题,即为了更好的支持并行开发允许多个配置 文件而不是单个配置文件。 
 在用struts进行大型项目开发中,使用这种新特性将是非常好的选择。 
 下面我以一个非常简单的例子来展示这一功能。 
 通常在单模块进行开发时,文件的最一般的目录结构如下: test/ ..../web-inf/ .........../classes .........../lib .........../*.tld .........../struts-config.xml ........... /web.xml ........... /validator-rules.xml ........... /validation.xml ........... ... ..../js ..../css            ..../main1.jsp (本例使用的一个简单的jsp页面) ..../*.jsp ... ..        如果我们增加一个单独的模块如:test1,则文件的最一般的目录结构如下: test/ ..../test1   **** ........./main11.jsp (本例使用的一个简单的jsp页面) ........./*.jsp  **** ..../web-inf/ .........../classes .........../lib .........../*.tld .........../struts-config.xml ........... /struts-test1-config.xml ***** ........... /web.xml ........... /validator-rules.xml ........... /validation.xml ........... ... .../js ... /css            .../main1.jsp (本例使用的一个简单的jsp页面) .../*.jsp ... ..      [旁边带有“****”的为新增的一些文件或目录]    以下为变更的几个xml配置文件:  1.struts-config.xml          在原来的action-mapping 增加switchAction 如:           ....           ....   <action-mappings> 
    <!-- Edit user registration --> 
    <action    path="/login"               type="com.ifreeway.rms.v12.action.LoginAction"                        scope="request">      <forward name="error"              path="/main1.jsp"/>    </action>    <action    path="/login1"               type="com.ifreeway.rms.v12.action.LoginAction1"                        scope="request">      <forward name="error"              path="/main1.jsp"/>    </action>     <action   path="/switchdo"   type="org.apache.struts.actions.SwitchAction"/> ****  </action-mappings>      ....  ....       [旁边带有“****”的为新特性中增加的配置]  2.struts-test1-config.xml            添加输入这个模块的actionmapping  如下:      ....      ....    <action-mappings> 
    <!-- Edit user registration --> 
    <action    path="/login3"               type="com.ifreeway.rms.v12.action.LoginAction2"                        scope="request">      <forward name="error"              path="/main11.jsp"/>    </action>     </action-mappings>  ....  ....  3.web.xml  ....  ....  <servlet>    <servlet-name>action</servlet-name>    <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>    <init-param>      <param-name>config</param-name>      <param-value>/WEB-INF/struts-config.xml</param-value>    </init-param>    <init-param>      <param-name>config/test1</param-name> *****      <param-value>/WEB-INF/struts-test1-config.xml</param-value> *****    </init-param>        <init-param>      <param-name>debug</param-name>      <param-value>3</param-value>    </init-param>    <init-param>      <param-name>detail</param-name>      <param-value>3</param-value>    </init-param>    <load-on-startup>2</load-on-startup>  </servlet>    ....  .... [旁边带有“****”的为新特性中增加的配置] 
 大家可以看到在struts-test1-config.xml中增加了下面代码: <action   path="/switchdo"   type="org.apache.struts.actions.SwitchAction"/> 因为在struts1.1中模块之间的导航要使用到org.apache.struts.actions.SwitchAction,如果你查看struts1.1的源代码可以发现 org.apache.struts.actions.SwitchAction需要两个参数:prefix 和 page 下面对这个参数逐一说明: 这两个参数均要以“/”开头 prefix 简单一点就是新增模块的名字,本例为:test1 page  就是在新的strutsconfig配置文件中要使用的actionmapping的名字 就本例为:login3.do 
 注意:如果是要使用却省模块的调用的话 prefix=空字符串 
 好了下面给出模块间转换的方法 
 启动Tomcat http://localhost:8080/test/switchdo.do?prefix=/test1&page=/login3.do 则调用struts-test1-config.xml下的/login3.do http://localhost:8080/test/switchdo.do?prefix=&page=/login1.do 则调用struts-config.xml下的/login1.do http://localhost:8080/test/switchdo.do?prefix=&page=/login.do 则调用struts-config.xml下的/login.do 
 总的来说模块之间的转换要用到org.apache.struts.actions.SwitchAction,而它需要传递两个参数(一般出错的地方极有可能出在参数 的错误上,请注意了) 
 [注:在struts1.1正式版中已经支持多了配置文件 2003-07-21]
 这篇贴子最初是发贴在cjw(http://www.chinajavaworld.net)的struts专区
 Jplateau   2003-05-05  
 
  |