struts.xml配置文件详解



struts.xml配置文件详解.

<?xml version=”1.0″ encoding=”UTF-8″ ?>
<!DOCTYPE struts PUBLIC
    “-//Apache Software Foundation//DTD Struts Configuration 2.0//EN”
    “http://struts.apache.org/dtds/struts-2.0.dtd“>

<struts>
 <!– 表示现在处于开发模式,更改即可用 –>
    <constant name=”struts.devMode” value=”true” />
    <constant name=”struts.i18n.encoding” value=”GBK” /> <!– internationalization –>
    
    <package name=”admin” extends=”struts-default” namespace=”/admin”>
        <action name=”loginAction”>
            <result name=”success”>/Admin_main.jsp</result>
            <result name=”input”>/Failure.jsp</result>
        </action>
    </package> 
</struts>

namespace决定了action的访问路径,默认为””,可以接收所有路径的action
Namespace可以写为/,或者/xxx,或者/xxx/yyy,对应的action访问路径为/index.action,/xxx/index.action,或者/xxx/yyy/index.action.
Namespace最好也用模块来进行命名。
package元素:Struts2当中的包和Java中的包类似,将action、result、result类型、拦截器和拦截器栈组织为一个逻辑单元,从而简化了维护工作,提高了重用性。包名一般比命名空间少一个/.
由于struts.xml文件是自上而下解析的,所以被继承的package要放在继承package的前边。Namespace将action分成逻辑上的不同模块,每一个模块有自己独立的前缀。使用namespace可以有效的避免action重名的冲突,例如每一个package都可以有自己独立的Menu和Help action,但是事项方式各有不同。
Struts2标签带有namespace选项,可以根据namespace的不同向服务器提交不同的package的action的请求。
action与action的类对应,class属性表示交给哪个类来处理。
result 的name属性通常是字符串。直接反映返回的界面视图对应那一个。

 在上面的配置当中没有考虑method的配置的原因是因为method会提前限定action的作用范围,这样不如在页面当中动态的调用。

<action name=”loginAction” method=”add”>
比如这里添加了method的action和在页面中提交表单或者点击超链接地址时的”admin/loginAction!add”是一样的。

当然了通配符的配置也很好,只是那需要很多的配合,比如页面命名等,对规范性要求很高。