Struts.xml配置文件详解

来源:互联网 发布:帝国cms仿站视频下载 编辑:程序博客网 时间:2024/05/16 23:42

1、package 元素:

1.1 作用:方便分模块化开发

1.2 属性:

name:必须有。唯一。标识一个包, 好有一定的含义。

extends:继承。一般要求必须继承struts-default的包。不继承该包,将无法使用struts2提供的一些核心功能。struts-default包在struts-default.xml中有配置,加载自己的struts.xml文件之前,框架就已经加载了struts-default.xml配置文件,所以我们可以使用。

abstract:是否是抽象包。让别人继承用的。没有任何action子元素的包就可以声明为抽象包。

namespace:名称空间。默认值是"",称之为默认名称空间。取值一般以/开头。

namespace和的name共同组成了用户访问的URI.
如下:URI=/user/hello.action
URI

1.3 关于namesapce的搜索顺序问题

搜索顺序

2、action 元素:

action:定义一个动作

name :动作名称。对应着用户的请求名称,默认的后缀是action或没有后缀

class:框架要实例化的动作类名称,全名称。默认值是:com.opensymphony.xwork2.ActionSupport。在struts-
default.xml中有定义。

method:执行的动作类的动作方法。默认值是execute

3、Struts2中的常用常量

default.properties中有
覆盖这些常量时,用后面的配置文件覆盖即可
struts.xml中<constant/>来覆盖

常量的名称 取值 说明 struts.devMode true/false 开启开发模式。配置文件修改后会自动加载;出错时能打印出更加详细的错误说明。真正运行时要改为false struts.i18n.reload true/false properties文件修改后会不会被自动加载 struts.configuration.xml.reload true/false xml配置文件修改后会不会被自动加载 struts.action.extension action struts2框架处理URI后缀。默认是action或者没有。可以配置多个值,用逗号进行分割 struts.i18n.encoding UTF-8 Struts2中使用的默认编码 struts.multipart.maxSize 2097152:2M Struts2中进行文件上传时的文件大小限制 struts.objectFactory.spring.autoWire name 与Spring框架进行集成用的 struts.objectFactory spring 与Spring框架进行集成用的 struts.serve.static.browserCache true 是否允许浏览器进行缓存静态资源 struts.enable.DynamicMethodInvocation true/false 是否允许动态方法调用。 struts.ui.theme xhtml Struts2UI标签库使用的默认样式主题 struts.ui.templateDir template 样式模板存在了什么文件夹中。

4、多个struts配置文件

user.xml

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE struts PUBLIC    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"    "http://struts.apache.org/dtds/struts-2.3.dtd"><struts>    <package name="user" extends="struts-default">        <action name="user" class="com.sd.action.User">            <result name="success">/success.jsp</result>        </action>    </package></struts>

struts.xml

<!-- 覆盖默认的参数配置 --><constant name="struts.devMode" value="true"></constant><constant name="struts.enable.DynamicMethodInvocation" value="true"></constant><include file="user.xml"></include>     

5、结果视图

5.1 result元素:


  1. 作用:配置逻辑结果视图。一个动作可以对应多个逻辑视图
  2. 属性:
    • name:逻辑视图名称,和动作类方法的返回值对应。默认是success
    • type:转向实际视图的方式。默认是dispatcher,转发,目标是一个页面。

type的取值:从struts-defualt.xml中找
1). dispathcer:目标是一个页面,请求转发
2). redirect:目标是一个页面,请求重定向
3). chain :目标是另外一个动作,请求转发
4). redirectAction:目标是另外一个动作,请求重定向

5.2 result中的参数设置

  1. 下面两种的写法本质上是一样的:
<action name="demo4">    <result name="success" type = "dispatcher">/success.jsp</result></action>
<action name="demo4">    <result name="success" type = "dispatcher">        <param name="location">/success.jsp</param>    </result></action>
  1. 转发的目标动作不在同一个包下,而且有着不同的namespace
<package name="p1" extends="struts-default">    <action name="demo3" class="com.itheima.action.Demo3Action">        <!-- 一个动作转向另外一个动作 -->        <result name="success" type="chain">            <!-- 转发到不同名称空间下的动作 -->            <param name="namespace">/p2</param>                <param name="actionName">demo4</param>        </result>    </action></package><package name="p2" extends="struts-default" namespace="/p2">    <action name="demo4">        <result name="success" type="dispatcher">            <!-- param设置参数:调用dispatcher对应的类的setLocation("/success.jsp") -->            <param name="location">/success.jsp</param>        </result>    </action></package>
0 0
原创粉丝点击