Struts2 第四讲 -- Struts2的基本配置

5.struts2的基本配置

5.1 struts2的访问连接url

  在struts1中,通过<action path=“/primer/helloWorldAction.action”>节点的path属性指定访问该action的URL路径。

  在struts2中,访问struts2中action的URL路径由两部份组成:包的命名空间+action的名称

例如: 访问本例子HelloWorldAction的URL路径为: /primer/helloWorldAction.action

(注意:完整路径为:http://localhost:端口//内容路径primer/helloWorldAction.action)。另外我们也可以加上.action后缀访问此Action,对于struts2来说,默认是.action结尾,或者是什么都不加。

    <package name="primer" namespace="/primer" extends="struts-default">
        <default-action-ref name="helloWorldAction"></default-action-ref>
        <action name="helloWorldAction" class="cn.youric.you.one_primer.HelloWorldAction">

            <result name="success">/primer/success.jsp</result>
            <result name="add">/primer/add.jsp</result>
        </action>
    </package>

5.2 struts2的namespace

  • 1).获得请求路径的URI,例如url是: http://server/struts2/path1/path2/path3/test.action
  • 2).首先寻找namespace为/path1/path2/path3的package,如果存在这个package,则在这个package中寻找名字为test的action,如果不存在这个package则转步骤3;
  • 3).寻找namespace为/path1/path2的package,如果存在这个package,则在这个package中寻找名字为test的action,如果不存在这个package,则转步骤4;
  • 4).寻找namespace为/path1的package, 如果存在这个package,则在这个package中寻找名字为test的action,
  • 5).如果仍然不存在这个package,就去默认的namaspace的package下面去找名字为test的action(默认的命名空间为空字符串“/” ),
  • 如果还是找不到,页面提示找不到action。
  <body>
       入门的路径:<br>
      测试Struts2带有参数:<a href="${pageContext.request.contextPath}/primer/helloWorldAction.action?username=‘zhangsanfeng‘">helloWorld</a><br>
      测试命名空间:<a href="${pageContext.request.contextPath}/primer/primer/helloWorldAction.action">helloWorld</a><br>
      测试action:<a href="${pageContext.request.contextPath}/primer/helloWorldAction">helloWorld</a><br>
  </body>

  上面是我们写的test.jsp页面,我们发现在第一个链接和第二个连接中,namespace的名称是不同的,但是仍然都能访问到同一个action,这就是namespace的路径寻找,以第二个链接为例,首先在/primer/primer下寻找helloWorldAction.action,如果不存在,那么就在/primer下查找,发现存在.

5.3 Action配置中的各项默认值

问题:如果没有为action指定class,默认是com.opensymphony.xwork2.ActionSupport,执行ActionSupport中的execute方法

  public String execute() throws Exception {
        return SUCCESS;
    }

由struts-default.xml文件中的以下代码

<default-class-ref class="com.opensymphony.xwork2.ActionSupport" />决定,class是可以由我们决定的,这样就可以在项目中把所有的问题访问转移到一个处理错误的页面上。

以下代码:

    <package name="primer" namespace="/primer" extends="struts-default">
        <default-action-ref name="helloWorldAction"></default-action-ref>
        <action name="helloWorldAction" class="cn.youric.you.one_primer.HelloWorldAction">

            <result name="success">/primer/success.jsp</result>
            <result name="add">/primer/add.jsp</result>
        </action>
    </package>
  • 1>如果没有为action指定class,默认是ActionSupport。
  • 2>如果没有为action指定method,默认执行action中的execute() 方法。ActionSupport的execute方法里面就一句话return "success";如果为action指定method,就会按照method指定的方法,去执行Action类中的同名方法
  • 3>如果没有指定result的name属性,默认值为success。
  • 4>问题:如果请求的路径查找不到action的情况下,程序运行会抛出异常 ,可以通过配置当找不到action的情况下,会执行默认的action【参见Struts2中的struts。Xml配置和解释】

5.4 ActionSupport类详解

5.5 struts2的请求后缀

  StrutsPrepareAndExecuteFilter是Struts 2框架的核心控制器,它负责拦截由<url-pattern>/*</url-pattern>指定的所有用户请求,当用户请求到达时,该Filter会过滤用户的请求。默认情况下,如果用户请求的路径不带后缀或者后缀以.action结尾,这时请求将被转入Struts 2框架处理,否则Struts 2框架将略过该请求的处理。

这是因为根据配置文件:struts2-core-2.3.3.jar包下的org.apache.struts2/default.properties文件定义的常量决定,

 struts.action.extension=action,

默认处理的后缀是可以通过常量”struts.action.extension“进行修改的,如下面配置Struts 2只处理以.do为后缀的请求路径,可以在struts.xml中配置:

<struts>
    <constant name="struts.action.extension" value="do"/>
</struts>

这个配置会覆盖default.properties文件的配置。

如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。如:

<constant name="struts.action.extension" value="do,go"/>

这里注意:

多学一招:常量可以在struts.xml或struts.properties中配置,但是我们建议在struts.xml中配置,两种配置方式如下:

在struts.xml文件中配置常量

<struts>

    <constant name="struts.action.extension" value="do"/>

</struts>

在struts.properties中配置常量, (struts.properties文件放置在src下)

struts.action.extension=do

因为常量可以在多个配置文件中进行定义,所以我们需要了解下struts2加载常量的搜索顺序:

  • 1 struts-default.xml
  • 2 struts-plugin.xml
  • 3 struts.xml
  • 4 struts.properties
  • 5 web.xml

如果在多个文件中配置了同一个常量,则后一个文件中配置的常量值会覆盖前面文件中配置的常量值.

5.6 struts2常用的常量介绍

指定默认编码集,作用于HttpServletRequest的setCharacterEncoding方法 和freemarker 、velocity的输出

<constant name="struts.i18n.encoding" value="UTF-8"/>


该属性指定需要Struts 2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts2处理。如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开

<constant name="struts.action.extension" value="do"/>


设置浏览器是否缓存静态内容,默认值为true(生产环境下使用),开发阶段最好关闭

<constant name="struts.serve.static.browserCache" value="false"/>

当struts的配置文件修改后,系统是否自动重新加载该文件,默认值为false(生产环境下使用),开发阶段最好打开

<constant name="struts.configuration.xml.reload" value="true"/>


开发模式下使用,这样可以打印出更详细的错误信息 ,同时可以自动加载struts2的配置文件和资源文件

<constant name="struts.devMode" value="true" />


默认的视图主题,设置为simple表示简单主题,目的是去掉struts2提供的css样式,因为在开发中,css样式事由美工设计的

<constant name="struts.ui.theme" value="simple" />


与spring集成时,指定由spring负责action对象的创建,这里在spring整合struts2的时候会用到,大家可以先记住

<constant name="struts.objectFactory" value="spring" />


该属性设置Struts 2是否支持动态方法调用,该属性的默认值是true。如果需要关闭动态方法调用,则可设置该属性为 false

<constant name="struts.enable.DynamicMethodInvocation" value="false"/>


上传文件的大小限制

     <constant name="struts.multipart.maxSize" value=“10701096"/>

5.7 struts.xml可以指定多个xml文件

  它的目的就是为了减轻struts.xml的数据加载负担,因为在大部分应用里,随着应用规模的增加,系统中Action的数量也会大量增加,导致struts.xml配置文件变得非常臃肿。为了避免struts.xml文件过于庞大、臃肿,提高struts.xml文件的可读性,我们可以将一个struts.xml配置文件分解成多个配置文件,然后在struts.xml文件中包含其他配置文件。下面的struts.xml通过<include>元素指定多个配置文件:

<struts>
    <include file="cn/youric/you/one_primer/struts-primer.xml"></include>
    <include file="cn/youric/you/two_context/struts-context.xml"></include>
    <include file="cn/youric/you/c_resulttype/struts-resulttype.xml"></include>
    <include file="cn/youric/you/d_pattern/struts-pattern.xml"></include>
</struts>

通过这种方式,我们就可以将Struts 2的Action按模块添加在多个配置文件中。

原文地址:https://www.cnblogs.com/lin-jing/p/8319728.html

时间: 2024-08-04 11:44:31

Struts2 第四讲 -- Struts2的基本配置的相关文章

Struts2 第六讲 -- Struts2的结果类型

7.struts2的结果类型 l 每个 action 方法都将返回一个 String 类型的值, Struts 将根据这个值来决定响应什么结果. l 每个 Action 声明都必须包含有数量足够多的 result 元素, 每个result 元素分别对应着 action 方法的一个返回值. l result 元素可以有下面两个属性 l  name: 结果的名字, 必须与 Action 方法的返回值相匹配, 默认值为 success l  type: 响应结果的类型. 默认值为 dispatcher

Struts2 第二讲 -- Struts2的入门

搭建struts2环境时,我们一般需要做以下几个步骤的工作: 第一步:创建javaweb工程(这个很废话有木有) 第二步:找到开发Struts2应用需要使用到的jar文件.(这个很白痴有没有) 到http://struts.apache.org/download.cgi#struts2514.1下载struts-2.x.x-all.zip,最新的版本为2.5.14.下载完后解压文件,开发struts2应用需要依赖的jar文件在解压目录的lib文件夹下.不同的应用需要的JAR包是不同的.下面给出了

struts2第四天——拦截器和标签库

一.拦截器(interceptor)概述 struts2是个框架,里面封装了很多功能,封装的很多功能都是在拦截器里面. (属性封装.模型驱动等都是封装在拦截器里面) struts2里面封装了很多功能,有很多拦截器,每次执行一部分拦截器,比如一些默认拦截器等 默认拦截器的位置在 core的jar包的struts-default.xml里边<interceptor>标签里边 二.拦截器基本原理 拦截器在什么时候执行: 在action对象创建之后和action方法执行之前进行执行(使用在相关位置打断

Struts2学习第一天——struts2基本流程与配置

struts2框架 什么是框架,框架有什么用? 框架 是 实现部分功能的代码 (半成品),使用框架简化企业级软件开发 ,提高开发效率. 学习框架 ,清楚的知道框架能做什么? 还有哪些工作需要自己编码实现 ? 什么是struts2框架,它有什么用? Struts 2是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架. 其全新的Struts 2的体系结构与Struts 1的体系结构差别巨大.Struts 2以WebWork为核心 struts2=struts1+

二十四、Struts2中的UI标签

二十四.Struts2中的UI标签 Struts2中UI标签的优势: 数据回显 页面布局和排版(Freemark),struts2提供了一些常用的排版(主题:xhtml默认 simple ajax) 可以使用OGNL表达式 模板: 常量设置的:struts.ui.theme=xhtml 开发中建议设置为struts.ui.theme=simple;

Struts2之配置文件中Action的详细配置(续)

承接上一篇 4.处理结果的配置 Action类的实例对象调用某个方法,处理完用户请求之后,将返回一个逻辑视图名的字符串.核心Filter收到返回的逻辑视图名字符串,根据struts.xml中的逻辑视图名与物理视图名的对应关系,通过地址转发 ,转发到物理视图中去. 配置处理结果,通过使用<result>元素,放在<action>元素下面. <result   name=“”   type=" ">    </result> Struts2支

struts2中两种validation.xml的配置方式_百度文库

在struts中,根据配置的validation.xml文件进行页面输入项目的验证已经众所周知,本文介绍在struts2中两种validation.xml的配置方式.可以根据不同的需要进行不同的配置. 以下以login页面输入firstname,lastname,和age为例进行说明.struts.xml中,成功的话转向成功页面.不成功的话转回到原页面. 首先建立userbean文件.文件名:UserBean.java包:struts2.login.bean文件内容:package struts

第四章 Struts2深入

4.1 Struts2架构    1.ActionMapper:        提供请求和Action之间的映射.根据请求查找是否存在对于的action,如有,翻译描述action映射的ActionMapping对象,没有,返回null    2.ActionMapping:        保存了调用action的映射信息,其中必须保存Action的命名空间信息和name属性    3.ActionProxy:        在XWork和真正的Action之间充当代理    4.ActionI

struts2拦截器interceptor的三种配置方法

struts2拦截器interceptor的三种配置方法方法1. 普通配置法 <struts>     <package name="struts2" extends="struts-default">         <interceptors>             <interceptor name="myInterceptor" class="edu.hust.interceptor.