现在的位置: 首页 > 综合 > 正文

Structs1配置文件 详解+示例

2013年10月05日 ⁄ 综合 ⁄ 共 10804字 ⁄ 字号 评论关闭

 

详解:

 

<struts-config>是struts的根元素,它主要有8个子元素,DTD定义如下:    

<!ELEMENT struts-config   

(data-sources?,form-beans?,global-exceptions?,global-forwards?,action-mappings?,controller?,message-resources*,plug-in*)   

>   

以上8个元素,下面一一描述:   

1. date-sources元素   

  date-sources元素用来配置应用程序所需要的数据源。java语言提供了javax.sql.DateSource接口,所有数据源必须实现该接口。如下配置:   

<data-sources>   

  <data-source type="org.apached.commons.dbcp.BasicDataSource">   

    ………………   

  </data-source>   

</data-sources>   

在Action中访问方式如:   

javax.sql.DataSource dataSource;   

java.sql.Connection myConnection;   

try   

{   

  dataSource = getDataSource(request);   

  myConnection = dataSource.getConnection();   

}   

…………   

  如果是多数据源,可用如下配置:   

<data-sources>   

  <data-source key="a"  type="org.apached.commons.dbcp.BasicDataSource">   

    ………………   

  </data-source>   

  <data-source key="b"   type="org.apached.commons.dbcp.BasicDataSource">   

    ………………    

  </data-source>   

</data-sources>   

访问方式:dataSource = getDataSource(request,"a");   

  

 2. form-beans元素   

  该元素主要用来配置表单验证的类。它包含如下属性:   

  1. classname:一般用得少,指定和form-bean无素对应的配置类,默认为org.apache.struts.config.FormBeanConfig,如果自定义,则必须扩展FormBeanConfig类。可有可无。   

  2. name:ActionForm Bean的惟一标识。必须。   

  3. type:ActionForm的完整类名。必须。   

如下所示:   

<form-beans>   

  <form-bean    

      name="Loign"   

      type="com.ha.login">   

  </form-bean>   

</form-beans>   

  如果是动态Action FormBean,还必须配置form-bean元素的form-property子元素。它包含四个属性,上面三个,还有一个initial 元素:以字符串的形式设置表单字段的初始值,如果没有设置该属性,则是基本类型为0,如果是对象则为null。可有可无。如下所示:   

<form-beans>   

  <form-bean    

      name="Loign"   

      type="com.ha.login">   

     <form-property name="ok"  type="java.lang.String"/>   

     <form-property name="oks"  type="java.lang.String"/>   

     <form-property name="okss"  type="java.lang.Integer" initial="20"/>   

  </form-bean>   

</form-beans>   

  

 3. global-exceptions元素   

  该元素主要配置异常处理,它的exception子元素代表全局的异常配置。struts采取配置的方式来处理异常。它用来设置java异常和异常处理类org.apache.struts.action.ExceptionHandler之间的映射。它有七个属性,如下所示:   

  1. className:指定和exception元素对应的配置类,默认为:org.apache.struts.config.ExceptionConfig。可有可无。   

  2. Handler:指定异常得理类,默认为:org.apache.struts.action.ExceptionHandler。可有可无   

  3. key:指定在Resource Bundle中描述该异常的消息key   

  4. path:指定当异常发生时的转发路径。   

  5. scope:指定ActionMessages实例的存放范围,可选值包括:request和session,默认为request。可有可无。   

  6. type:指定所需处理异常类的名字,必须。   

  7. bundle:指定Resource Bundle   

如下所示:   

<global-exceptions>   

  <exception    

      key="global.error.invalidlogin"   

      path="/error.jsp"   

      scope="request"   

      type="com.hn.tree"   

  />   

</global-exceptions>   

  

 4. global-forwards元素   

  该元素主要用来声明全局的转发关系,它具有以下四个属性:   

  1. className:和forward元素对应的配置类,默认为:org.apache.struts.action.ActionForward。可有可无。   

  2. contextRelative:此项为true时,表时path属性以"/"开头,相对于当前上下文的URL,默认为false.可有可无。    

  3. name:转发路径的逻辑名.必填。   

  4. path:转发或重定向的URL,当contextRelative=false时,URL路径相对于当前应用(application),当为ture时,表示URL路径相对于当前上下文(context)。   

  5.  redirect:当此项为ture时,表示执行重定向操作。当此项为false时表示转向操作。默认为false。   

如下所示:   

<global-forwards>   

  <forward  name="forms1"  path="/a.do"/>   

  <forward  name="forms2"  path="/nb.jsp"/>   

<global-forwards>   

  

 5. action-mappings元素   

  描述从特定的请求路径到相应的Action类的映射。它具有以下几个属性:   

  1. attribute:设置和Action关联的ActionForm Bean在request和session范围内的key。如:Form Bean存在于request范围内,此项设为“myBenas”,则在request.getAttribute("myBenas")就可以返回该Bean的实例。   

  2. classsName:和action元素对应的配置元素,默认为:org.apache.struts.action.ActionMapping.   

  3. forward:转发的URL路径。   

  4. include:指定包含的URL路径。   

  5. input:输入表单的URL路径,当表单验证失败时,将把请求转发到该URL。   

  6. name:指定和Action关联的Action FormBean的名字,该名字必须在Form-Bean定义过。   

  7. path:指定访问Action的路径,以“/”开头,无扩展名。   

  8. parameter:指定Actgion的配置参数,在Action类的execute()方法中,可以调用ActionMapping对象的getParameter()方法来读取该配置参数。   

  9. roles:指定允许调用该Action的安全角色,多个角色之间用,隔开,在处理请求时,RequestProcessor会根据该配置项来决定用户是否有权限调用Action权限。   

  10. scope:指定ActionForm Bean的存在范围,可选取为request和session,默认为session。   

  11. type:指定Action类的完整类名。   

  12. unknown:如果此项为true,表示可以处理用户发出的所有无效的Action URL,默认为false;   

  13. validate:指定是否要调用Action FormBean的validate方法,默认值为ture.   

注:forward、include、type属性只能选中其中一项。   

如下:   

<action path="/search"   

    type="zxj.okBean"   

    name="a1"   

    scope="request"   

    validate="true"   

    input="/b.jsp">   

  <forward name="tig" path="/aa.jsp"/>   

</action>   

注:此中的forward是指局部的转发路径。global-forwards表示全局的转发路径。   

  

 6. controller元素   

  该元素用于配置ActionServlet。它具有以下属性。   

  1. bufferSize:指定上载文件的输入缓冲大小,可选,默认为4096   

  2. className:指定和controller元素对应的配置类,默认为org.apache.struts.config.ControllerConfig   

  3. conentType:字符编码,如果在Action和JSP网页中设置了,则覆盖该设置。   

  4. locale:指定是否把Locale对象保存到当前用户的session中,默认值为false.   

  5. processorClass:指定负责请求的java类完整路径。   

  6. tempDir:指定处理文件的临时工作目录,如果此项没有设置,将采用Servlet容器为web应用分配的临时工作目录。   

  7. nochache:如果为true:在响应结果中将加入特定的头参数:Pragma,Cache-Control和Expise,防止页面被保存在客户端的浏览器中,默认为false   

如下:   

<controller   

  contentType="text/html;charset="UTF-8""   

  locale="true"   

  processorClass="con.ok"/>   

  

 7. message-resources元素   

  主要配置本地化消息文本,它具有以下属性。   

  1. className:和message-resources元素对应的配置类,默认为org.apache.struts.config.MessageResourcesConfig。   

  2. factory:指定消息资源的工厂类,默认为:org.apache.struts.util.PropertyMessageResourcesFactory类   

  3. key:指定Resource Bundle存放的ServletContext对象中时采用的属性Key,默认由Globals.MESSAGES_KEY定义的字符串常量,只允许一个Resource Bundle采用默认的属性Key。   

  4. null:指定MessageSources类如何处理未知消息的key,如果为true,则返回空字符串,如果为false,则返回相关字串,默认为false   

  5. prameter:指定MessageSources的资源文件名,如果为:a.b.ApplicationResources,则实际对应的文件路径为:WEB-INF/classes/a/b/ApplicationResources.properties.   

如:   

<message-resources null="false" parameter="defaultResource"/>   

<message-resources key="num1" null="false" parameter="test"/>   

访问为:   

<bean:message  key="zxj"/>   

<bean:message  key="zxj"  bundle="num1"/>   

其中,zxj表法,messagesource资源文件中的一个字符串。   

  

 8. plugin-in元素   

  配置Struts的插件,属性如下:   

  1. className:指定的Struts插件类,必须实现org.apache.struts.action.PlugiIn接口。如:   

<plug-in   

  className="a.b.c.">   

  <set-property property="xxx" value="/WEB-INF/aa.xml"  />   

</plug-in> 

 

 

示例:

1.web.xml

<?xml version="1.0"encoding="UTF-8"?>
<web-app version="2.4"
 xmlns="
http://java.sun.com/xml/ns/j2ee"
 xmlns:xsi="
http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="
http://java.sun.com/xml/ns/j2ee
 http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
 
  <!-- 描述性文本-->
 <display-name>Strutsweb</display-name>
 
  <!-- 1.欢迎列表,既默认主页-->
 <welcome-file-list>
   <welcome-file>index.jsp</welcome-file>
 </welcome-file-list>
 
 
  <!-- 2.Struts标签库的部署
  taglib-uri:为标签库文件指定别名,用于JSP引用,
                格式:<%@ tablib="/WEB-INF/struts-html.tld"prefix="html"%>;
  taglib-location:标签实际的保存位置;
   -->
  <jsp-config>
  <taglib>
  <taglib-uri>/WEB-INF/struts-html.tld</taglib-uri>
  <taglib-location>/WEB-INF/struts-html.tld</taglib-location>
  </taglib>
  <taglib>
  <taglib-uri>/WEB-INF/struts-bean.tld</taglib-uri>
  <taglib-location>/WEB-INF/struts-bean.tld</taglib-location>
  </taglib>
  <taglib>
  <taglib-uri>/WEB-INF/struts-logic.tld</taglib-uri>
  <taglib-location>/WEB-INF/struts-logic.tld</taglib-location>
  </taglib>
  <taglib>
  <taglib-uri>/WEB-INF/struts-nested.tld</taglib-uri>
  <taglib-location>/WEB-INF/struts-nested.tld</taglib-location>
  </taglib>
  <taglib>
  <taglib-uri>/WEB-INF/struts-tiles.tld</taglib-uri>
  <taglib-location>/WEB-INF/struts-tiles.tld</taglib-location>
 </taglib> 
 </jsp-config>
 
 
  <!-- 3.配置struts的action类
  servlet-name:该ActionServet的名称,用于其他配置的引用;
  servlet-class:该ActionServet所属的类路径;
  init-param:struts专用config初始化参数;
  load-on-startup:启动时创建Servlet实例数目;
  -->
  <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/upload</param-name>
    <param-value>/WEB-INF/upload/struts-config.xml</param-value>
   </init-param>
   <init-param>
    <param-name>config/validator</param-name>
    <param-value>/WEB-INF/validator/struts-config.xml</param-value>
   </init-param>
   
   <init-param>
     <param-name>debug</param-name>
     <param-value>2</param-value>
   </init-param>
   <init-param>
     <param-name>detail</param-name>
     <param-value>2</param-value>
   </init-param>
   <load-on-startup>2</load-on-startup>
  </servlet>
 
 
  <!-- 指定Action列请求处理的URL地址
   url-pattern:所要处理的URL格式;
  servlet-name:请求所转向的ActionServet名称;
   -->
 <servlet-mapping>
   <servlet-name>action</servlet-name>
   <url-pattern>*.do</url-pattern>
 </servlet-mapping>
 
 
  <!-- 配置错误处理
   404:路径错误;
   500:程序错误;
   -->
  <error-page>
 <error-code>500</error-code>
 <location>/common/500.jsp</location>
 </error-page>
  <error-page>
 <error-code>404</error-code>
  <location>/common/404.jsp</location>
 </error-page>
</web-app>

 

 

 

 

2.struts-coinfig.xml

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE struts-config PUBLIC
         "-//Apache Software Foundation//DTD Struts Configuration1.2//EN"
         "
http://jakarta.apache.org/struts/dtds/struts-config_1_2.dtd">
 
<struts-config>

 <!-- 配置数据源
  Key:数据源名称,如果在应用程序中只有一个的DataSource则可省略Key的值。
  DriverClass:JDBC驱动类(必须的)
  url:所用的JDBC的URL(必须的)
  MaxCount:同时打开的最大连结数,缺省值为2(可选的)
  MinCount:同时打开的最小连结数,缺省值为1(可选的)
  User:连结到数据库的用户名(必须的)
  Password:连结到数据库的密码(必须的)
  Description:关于DataSource的描述信息(可选的)
  ReadOnly:如果设为true,则表示该连结是只读的,缺省为false。(可选的)
  LoginTimeout:创建连结的最大允许时间,以秒为单位。(可选的)
  AutoCommit:如果为true,则每次execute之后会强制回滚。缺省为true。(可选的)
 -->
 <data-sources>
  <data-sourcekey="dataSource"
   type="org.apache.commons.dbcp.BasicDataSource">
   <set-propertyproperty="driverClass"
    value="org.gjt.mm.mysql.Driver"/>
   <set-propertyproperty="url"
    value="jdbc:mysql://localhost/wileyusers"/>
   <set-propertyproperty="maxCount" value="10" />
   <set-propertyproperty="minCount" value="1" />
   <set-propertyproperty="user" value="sa" />
   <set-propertyproperty="password" value="yourpassword" />
  </data-source>
 </data-sources>

 <!-- ActionForm配置-->
 <form-beans>
       <form-bean name="LoginForm"type="mail.login.LoginForm"></form-bean>
   </form-beans>
   
   
   <!-- 全局转发配置
     首先在<action-mappings>元素中找对应的<forward>,若找不到,则到全局转发配置中找。
    name及path属性之外,还有一个redirect属性,如果redirect设为true的时候,则用
    HttpServletResponse.sendRedirect()方法,否则用RequestDispatcher.forward()方法,缺省为false。
    -->
   <global-forwards>
    <forward name="success"path="/welcome.jsp" />
    <forward name="failure"path="/index.jsp" />
   </global-forwards>

   <!-- Action配置
    Path:在浏览器的URL中输入的字符(必须的)
    Type:连结到本映射的Action的全称(可选的)
    Name:与本操作关联的ActionBean在<form-bean/>中定义name名(可选的)
    Scope:指定ActionFormBean的作用域(session和request),缺省为session。(可选的)
    Input:当Bean发生t误时返回的控制。(可选的)
    ClassName:指定一个调用这个Action类的ActionMapping类的全名。缺省用
    org.apache.struts.action.ActionMapping,(可选的)
    Forward:指定处理相应请求所对应的JSP页面。(可选的)
    Include:如果没有forward的时候,它起forward的作用。(可选的)
    Validate:若为true,则会调用ActionForm的validate()方法,否则不调用,缺省为true。(可选的)
   -->
   <action-mappings>
       <action path="/login"
               type="mail.login.LoginAction"
               name="LoginForm"
               scope="request">
               <forward name="success"path="/index.jsp"></forward>
               <forward name="error"path="/userError.jsp?i=1"></forward>
       </action>
   </action-mappings>
   
   <!-- 资源文件配置 -->
   <message-resourcesparameter="wiley.ApplicationResources"/>
</struts-config>

抱歉!评论已关闭.