struts1.2配置详细

struts配置文件

web.xml是web应用的发布描述文件。。。
struts-config.xml是struts应用专有的配置文件,可以根据需要给这个配置文件起其它的文件名。

 

一、web配置文件web.xml
<servlet>元素必须出现在<servlet-mapping>元素前面,<servlet-mapping>元素必须出现在<taglib>元素的前面。

 

<init-param>
 <param-name>config</param-name>
 <param-value>/WEB-INF/struts-config.xml</param-value>
</init-param>
<init-param>元素用来声明servlet初始化参数,config参数是配置struts的ActionServlet专有的,用来设置struts配置文件的相对路径。

 

<welcome-file-list>。。。不能直接把struts的Action作为欢迎文件,以下是在欢迎文件中调用struts action。
<global-forwards>
 <forward name="welcome" path="HelloWorld.do"/>
</global-forwards>

 

<body>
<logic:forward name="welcome"/>
</body>

 

<welcome-file-list>
<welcome-file>welcome.jsp</welcome-file>
</welcome-file-list>

 

配置错误处理
<error-page>
<error-code>404</error-code>
<location>/common/404.jsp</location>
</error-page>
<error-page>
<error-code>505</error-code>
<location>/common/505.jsp</location>
</error-page>


配置异常处理
<error-page>
<exception-type>javax.servle.ServletException</exception-type>
<location>/common/system_error.jsp</location>
</error-page>

 

配置标签库
<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/mytaglib.tld</taglib-uri>
<taglib-location>WEB-INF/mytaglib.tld</taglib-location>
</taglib>
web版本在2.4版本中允许不在web.xml中配置taglib描述文件而直接在页面上引用。


二、struts配置文件struts-config.xml

<struts-config>元素:这是Struts配置文件的根元素,和它对应的配置类org.apache.struts.config.ModuleConfig类,<struts-config>元素有8个子元素。他们的DTD定义是data-sources?form-bean? global-exception?global-forwards?action-mapping?controller?message-resources*plug-in*

 

<data-sources>元素:配置应用数据源,一般没用。。。

 

<form-beans>元素:用来配置多个ActionForm,包含一个或者N个<form-bean>子元素。name指定该ActionForm的唯一标识符,这个属性是必须的以后作为引用使用;type指定ActionForm类的完整类名,这个属性也是必须的。
该元素主要用来配置表单验证的类。它包含如下属性:
  1. className:一般用得少,指定和form-bean元素对应的配置类,默认为org.apache.struts.config.FormBeanConfig,如果自定义,则必须扩展FormBeanConfig类,可有可无。
  2. name:ActionForm Bean的惟一标识。必须。
  3. type:ActionForm的完整类名。必须。
如下所示:

  1. <form-beans>
  2.   <form-bean 
  3.       name="Loign"
  4.       type="com.ha.login">
  5.   </form-bean>
  6. </form-beans>

若配置动态ActionForm Bean,还必须配置form-bean元素的form-property子元素。

 

<global-exceptions>元素:用来配置异常处理,一般没用。。。

 

<global-forwards>元素:用来声明全局的转发关系。元素可以有一个或者N个<forward>元素组成,用于把一个逻辑名映射到特定的URL,通过这种方法Action类或者JSP页面无需指定URL,只要指定逻辑名称就可以实现请求转发或者重定向。
该元素主要用来声明全局的转发关系,它具有以下四个属性:
  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。
如下所示:

  1. <global-forwards>
  2.   <forward  name="forms1″  path="/a.do"/>
  3.   <forward  name="forms2″  path="/nb.jsp"/>
  4. <global-forwards>

<action-mapping>元素:包含一个或者N个<action>元素,描述了从特定的请求路径到响应的Action的映射。
上述从特定的请求路径到相应的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属性只能选中其中一项。

  1. <action path="/search"
  2.     type="zxj.okBean"
  3.     name="a1"
  4.     scope="request"
  5.     validate="true"
  6.     input="/b.jsp">
  7.   <forward name="tig" path="/aa.jsp"/>
  8. </action>

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

 

<controller>元素:用于配置ActionServlet.buffreSize指定上载文件的输入缓冲大小,一般

不用。。。

 

<message-resources>元素:用来配置Resource Bundle。
    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。
如下:

  1. <message-resources null="false" parameter="defaultResource"/>
  2. <message-resources key="num1" null="false" parameter="test"/>

访问为:

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

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

 

<plug-in>元素:用于配置Struts插件,配置多应用模块,一般不用。。。

 

原文链接:http://blog.csdn.net/badboy_blue/archive/2008/10/28/3164866.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值