[java] struts的web.xml和struts-config.xml详解


一、web.xml

是标准的Web档案部署描述器。下面是一个简单项目的web.xml中的配置消息。

<?xml version="1.0"?>
<web-app>
<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>
<load-on-startup>1</load-on-startup>
<servlet>
<servlet-mapping>
<servlet-name>action</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>/index.jsp</welcome-file>
</welcome-file-list>
</web-app>

声明从给Servlet赋值一个名称开始,改名称用于下面将Servlet映射到指定的应用请求。<BR> 定义了Servlet的名称和类之后,接下来定义config初始化参数。该参数告诉哪里能找到中心配置文件struts-config.xml<BR> load-on-startup标签指定的值越低,在Servlet启动时首先载入。<BR> <BR> 接下来一段知名映射关系。Servlet-name引用前面的名称,使之对应 的Action与此映射有关。<BR> url-pattern声明ServletAction将要应答的URL的模式。默认是以.do结尾<BR> welcome-file配置欢迎文件的列表。当web请求无法实现时,Servlet就用这些页面应答。

二、struts-config.xml。

以下是一份完整的struts-config.xml文件,配置元素的说明详见注释.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 1.1//EN"
"http://jakarta.apache.org/struts/dtds/struts-config.dtd">
<!-- struts-config.xml中的元素必须按照上述doc指令中的dtd文档定义顺序书写,本例即遵从了dtd定义顺序 -->
<!-- struts-config是整个xml的根元素,其他元素必须被包含其内 -->
<struts-config>
<!--
名称:data-sources 
描述:data-sources元素定义了web App所需要使用的数据源 
数量:最多一个 
子元素:data-source 
-->
<data-sources>
<!--
名称:data-source 
描述:data-source元素定义了具体的数据源 
数量:任意多个 
属性: 
@key:当需要配置多个数据源时,相当于数据源的名称,用来数据源彼此间进行区别 
@type:可以使用的数据源实现的类,一般来自如下四个库 
Poolman,开放源代码软件 
Expresso,Jcorporate 
JDBC Pool,开放源代码软件 
DBCP,Jakarta 
-- >
<data-source key="firstOne" type="org.apache.commons.dbcp.BasicDataSource">
<!--
名称:set-property 
描述:用来设定数据源的属性 
属性: 
@autoCommit:是否自动提交 可选值:true/false 
@description:数据源描述 
@driverClass:数据源使用的类 
@maxCount:最大数据源连接数 
@minCount:最小数据源连接数 
@user:数据库用户 
@password:数据库密码 
@url:数据库url 
-- >
<set-property property="autoCommit" value="true"/>
<set-property property="description" value="Hello!"/>
<set-property property="driverClass" value="com.mysql.jdbc.Driver"/>
<set-property property="maxCount" value="10"/>
<set-property property="minCount" value="2"/>
<set-property property="user" value="root"/>
<set-property property="password" value=""/>
<set-property property="url" value="jdbc:mysql://localhost:3306/helloAdmin"/>
</data-source>
</data-sources>
<!--
名称:form-beans 
描述:用来配置多个ActionForm Bean 
数量:最多一个 
子元素:form-bean 
-->
<form-beans>
<!--
名称:form-bean 
描述:用来配置ActionForm Bean 
数量:任意多个 
子元素:form-property 
属性: 
@className:指定与form-bean元素相对应的配置类,一般默认使用org.apaceh.struts.config.FormBeanConfig,如果自定义,则必须继承 FormBeanConfig 
@name:必备属性!为当前form-bean制定一个全局唯一的标识符,使得在整个Struts框架内,可以通过该标识符来引用这个ActionForm Bean。 
@type:必备属性!指明实现当前ActionForm Bean的完整类名。 
-- >
<form-bean name="Hello" type="myPack.Hello">
<!--
名称:form-property 
描述:用来设定ActionForm Bean的属性 
数量:根据实际需求而定,例如,ActionForm Bean对应的一个登陆Form中有两个文本框,name和password,ActionForm Bean中也有这两个字段,则此处编写两个form-property来设定属性 
属性: 
@className:指定与form-property相对应的配置类,默认是org.apache.struts.config.FormPropertyConfig,如果自定义,则必须继承FormPropertyConfig类 
@name:所要设定的ActionForm Bean的属性名称 
@type:所要设定的ActionForm Bean的属性值的类 
@initial:当前属性的初值 
-- >
<form-property name="name" type="java.lang.String"/>
<form-property name="number" type="java.lang.Iteger" initial="18"/>
</form-bean>
</form-beans>
<!--
名称:global-exceptions 
描述:处理异常 
数量:最多一个 
子元素:exception 
-->
<global-exceptions>
<!--
名称:exception 
描述:具体定义一个异常及其处理 
数量:任意多个 
属性: 
@className:指定对应exception的配置类,默认为org.apache.struts.config.ExceptionConfig 
@handler:指定异常处理类,默认为org.apache.struts.action.ExceptionHandler 
@key:指定在Resource Bundle种描述该异常的消息key 
@path:指定当发生异常时,进行转发的路径 
@scope:指定ActionMessage实例存放的范围,默认为request,另外一个可选值是session 
@type:必须要有!指定所需要处理异常类的名字。 
@bundle:指定资源绑定 
-- >
<exception
key= ""hello.error
path= "/error.jsp"
scope= "session"
type= "hello.HandleError"/>
</global-exceptions>
<!--
名称:global-forwards 
描述:定义全局转发 
数量:最多一个 
子元素:forward 
-->
<global-forwards>
<!--
名称:forward 
描述:定义一个具体的转发 
数量:任意多个 
属性: 
@className:指定和forward元素对应的配置类,默认为org.apache.struts.action.ActionForward 
@contextRelative:如果为true,则指明使用当前上下文,路径以“/”开头,默认为false 
@name:必须配有!指明转发路径的唯一标识符 
@path:必须配有!指明转发或者重定向的URI。必须以 "/"开头。具体配置要与contextRelative相应。(要与<action></action>中的path相同)
@redirect:为true时,执行重定向操作,否则执行请求转发。默认为false 
@这里的forward与 <action>中的forward区别在于
//struts中global-forwards是全局的,也就是所有的ACTION都可以用的FORWARD,相当于JAVA类中的
//PUBLIC访问域。而action 中的forwards只能在当前的ACTION中使用,相当于JAVA类中的PRIVATE访问域。
//另外如果我没有记错的话:局部和全局如果重名的话,先找局部,然后再找全局的 
-- >
<forward name="A" path="/hello/c.do"/>
<forward name="B" path="/hello/b.do"/>
</global-forwards>
<!--
名称:action-mappings 
描述:定义action集合 
数量:最多一个 
子元素:action 
-->
<action-mappings>
<!--
名称:action 
描述:定义了从特定的请求路径到相应的Action类的映射 
数量:任意多个 
子元素:exception,forward(二者均为局部量) 
属性: 
@attribute:制定与当前Action相关联的ActionForm Bean在request和session范围内的名称(key) 
@className:与Action元素对应的配置类。默认为org.apache.struts.action.ActionMapping 
@forward:指名转发的URL路径 
@include:指名包含的URL路径 
@input:指名包含输入表单的URL路径,表单验证失败时,请求会被转发到该URL中 
@name:指定和当前Acion关联的ActionForm Bean的名字。该名称必须在form-bean元素中定义过。 
@path:指定访问Action的路径,以 "/"开头,没有扩展名
@parameter:为当前的Action配置参数,可以在Action的execute()方法中,通过调用ActionMapping的getParameter()方法来获取参数 
@roles:指定允许调用该Aciton的安全角色。多个角色之间用逗号分割。处理请求时,RequestProcessor会根据该配置项来决定用户是否有调用该Action的权限 
@scope:指定ActionForm Bean的存在范围,可选值为request和session。默认为session 
@type:指定Action类的完整类名 
@unknown:值为true时,表示可以处理用户发出的所有无效的Action URL。默认为false 
@validate:指定是否要先调用ActionForm Bean的validate()方法。默认为true 
注意:如上属性中,forward/include/type三者相斥,即三者在同一Action配置中只能存在一个。 
-- >
<action path="/search"
type= "addressbook.actions.SearchAction"
name= "searchForm"
scope= "request"
validate= "true"
input= "/search.jsp">
<forward name="success" path="/display.jsp"/>
</action> 
</action-mappings>
<!--
名称:controller 
描述:用于配置ActionServlet 
数量:最多一个 
属性: 
@bufferSize:指定上传文件的输入缓冲的大小.默认为4096 
@className:指定当前控制器的配置类.默认为org.apache.struts.config.ControllerConfig 
@contentType:指定相应结果的内容类型和字符编码 
@locale:指定是否把Locale对象保存到当前用户的session中,默认为false 
@processorClass:指定负责处理请求的Java类的完整类名.默认org.apache.struts.action.RequestProcessor 
@tempDir:指定文件上传时的临时工作目录.如果没有设置,将才用Servlet容器为web应用分配的临时工作目录. 
@nochache:true时,在相应结果中加入特定的头参数:Pragma ,Cache-Control,Expires防止页面被存储在可数浏览器的缓存中,默认为false 
-->
<controller 
locale= "true"
processorClass= "CustomRequestProcessor">
</controller>
<!--
名称:message-resources 
描述:配置Resource Bundle. 
数量:任意多个 
属性: 
@className:指定和message-resources对应的配置类.默认为org.apache.struts.config.MessageResourcesConfig 
@factory:指定资源的工厂类,默认为org.apache.struts.util.PropertyMessageResourcesFactory 
@key: 
@null: 
@parameter: 
-->
<message-resources
null= "false"
parameter= "defaultResource"/>
<message-resources
key= "images"
null= "false"
parameter= "ImageResources"/>

<!--
名称:plug-in 
描述:用于配置Struts的插件 
数量:任意多个 
子元素:set-property 
属性: 
@className:指定Struts插件类.此类必须实现org.apache.struts.action.PlugIn接口 
-->
<plug-in
className= "org.apache.struts.validator.ValidatorPlugIn">
<!--
名称:set-property 
描述:配置插件的属性 
数量:任意多个 
属性: 
@property:插件的属性名称 
@value:该名称所配置的值 
-- >
<set-property 
property= "pathnames"
value= "/WEB-INF/validator-rules.xml,/WEB-INF/vlaidation.xml"/>
</plug-in>
</struts-config>

formbean配置段,用来指定Struts应用中所有使用的ActionForm对象。将逻辑名与别名相联系,这样直接引用ActionForm即可<BR> 接下来是全局配置段,是一种将逻辑名配置给页面位置的方法。

action-mapping配置段六个属性分别配置: path配置与action有关的路径(用于访问Struts应用)。在这里,Struts处理访问到"/search.do"的请求 type配置指定应当执行的 action类的路径 name属性对性web.xml中formbean的属性 scope和validate是关于formbean 的配置。分别配置范围和formbean是否应该有validate()方法 input指定哪个页面用于输入数据或者执行action






  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值