struts访问

struts基本工程结构:

1. struts.xml支持语法提示;
2. struts.xml配置常量, 用来覆盖struts.properties中的默认常量配置
  一般情况下, 这个配置放在struts.xml中, 不要放在各个模块的xml中
    constant元素和package是同一个级别的
 <struts>
  <constant name="" value=""></constant>
 </struts>
 
 3. 模块xml配置文件引入(将各个模块的xml分开写,之后导入struts.xml)
 <struts>
  <include file="各个模块的xml配置文件的目录"></include>
 </struts>


 4. 常用常量(在struts核心包中可以找到文件,只需复制到xml中进行修改)
  1)开发模式:修改struts.xml之后,如果没有大的改动,则不要多次重启Tomcat.
   devMode模式是开发模式,开启它则默认开启了i18n.reload、configuration.xml.reload.
   <constant name="struts.devMode" value="true" />
  2)设置当struts的配置文件修改后,系统是否自动重新加载该文件: 默认值为false(生产环境下使用),开发阶段最好打开
   <constant name="struts.configuration.xml.reload" value="true"/>
  3)指定每次请求到达,重新加载资源文件
   <constant name="struts.i18n.reload" value="true"/>
  4)指定XSLT Result使用样式表缓存
   <constant name="struts.xslt.nocache" value="true"/>
  5)设置actionName的后缀: 默认值是action,即所有匹配*.action的请求都由Struts2处理。
   如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开
   <constant name="struts.action.extension" value="action,,"/>
  6)默认的视图主题
   <constant name="struts.ui.theme" value="simple" />
  7)设置浏览器是否缓存静态内容: 默认值为true(生产环境下使用),开发阶段最好关闭
   true: 表示有缓存, false:表示没有缓存
   <constant name="struts.serve.static.browserCache" value="false"/>
  8)设置是否支持动态方法调用
   <constant name="struts.enable.DynamicMethodInvocation" value="false"/>
  9)指定默认编码集,作用于HttpServletRequest的setCharacterEncoding方法 和freemarker 、velocity的输出
   <constant name="struts.i18n.encoding" value="UTF-8"/>
  
 5. 各个元素
  1)package: 是struts.xml根元素(strtus)的子元素. 用来管理多个action元素.
   * 格式为:
    <package name="" extends="" namespace="" abstract="true/false">
   * 用法: 一个模块分出一个<package>元素.
   * 常用的属性:
    - name: 表示当前<package>元素的名称,多个<package>元素的name不能相同.
    - extends: 自定义的<package>元素必须继承于包struts-default或其的子包.
    - namespace: 命名空间,和actionName共同决定了一个action的访问路径, 与程序中的命名空间的作用类似.
    - abstract: 表示当前<package>元素是否是抽象的.
      如果为true,那么当前<package>就不能定义action元素,只能用于被其他<package>所继承.
  2)action: 是<package>元素的子元素,用于配置Action类. 表示对一次请求的动作的配置:找哪一个类的哪一个方法.
   * 语法:<action name="" class="" method="">
   * 常用属性:
    - name: action的名称,该名称和当前action所在package的namespace共同决定了访问路径.
     访问Action的格式:http://host:port/contextPath/namsspace/actionName[.action]
     注意:action名称没有/,在同一个<package>不能同名.
    - class: Action类的全限定名,表示把哪一个Action对象交给Strtus2框架来管理.
     class的默认值:com.opensymphony.xwork2.ActionSupport.
    - method: 当前action需要执行哪一个方法.
     method的默认值:execute().
  3)result元素:是<action/>元素的子元素,表示对应的action的执行结果: `action执行完成后输出哪个页面`.
   * 语法格式:<result name="" type=""></result>
   * 分类: 先在当前的Action中找, 找不到就去找<global-results>中的result, 如果还找不到→报错;
    - 全局: 配置在<package>元素中的<global-results>元素里面,<package>下的所有Action都可以跳转进去.
    - 局部: 配置在<action>元素里面,就只能在当前Action中跳转.
    $ 在配置的时候需要先配置global, 然后才能配置action
   * 常用属性及文本:
    - name属性: 同一个action中的result的name不能同名,该name就是action方法的返回结果.默认值:success.
    - type属性: 表示资源的跳转方式(请求转发/URL重定向...),这些属性存放在struts-default包.默认:dispatcher.
     ~ dispatcher: 请求转发:(Action请求转发到JSP),是默认值.
     ~ redirect: URL重定向:(Action重定向到JSP).
     ~ chain: 请求转发:(Action请求转发到Action).
     ~ redirectAction: URL重定向:(Action重定向到Action).
     ~ stream: 文件下载.
    - innerText: 表示需要跳转资源的路径.

Struts2框架配置文件加载顺序:
(服务器启动之后, 这些配置文件会按照顺序一一加载进内存, 进行类等匹配的时候才会去内存查找):
 1. default.properties
 2. struts-default.xml
 3. struts-plugin.xml
 4. struts.xml
 5. struts.properties
 6. web.xml

 1.default.properties: 该文件保存在 struts2-core-x.x.x.jar的根路径的包org.apache.struts2中
  * 其中包含了Struts2的默认常量配置(比如actionName的extention等).
 2.struts-default.xml: 该文件保存在 struts2-core-x.x.x.jar根路径中
  * 其中包含了框架依赖的对象配置和结果类型,拦截器等配置.
 3.struts-plugin.xml: 该文件保存在Struts2框架的插件中:struts-`functionName`-plugin-x.x.x.jar.
 4.struts.xml: 该文件是一个自配置文件, 是web应用默认的struts配置文件, 配置自定义的Action和其他信息.
 5.struts.properties: 该文件是一个自配置文件, 用来覆盖default.properties中的常量配置.
  * 但是一般情况下, 我们不会配置这个文件, 需要的话可以直接在struts.xml中配置, 具体配置详情参考struts.xml
 6.web.xml: 就是在项目的web.xml中配置信息, 前端控制器等等, 一般也不糊在这里配置
 上述三个文件是我们可以修改操作的.
 
 如果多个文件配置了同一个struts2 常量,则后一个文件中配置的常量值会覆盖前面文件配置的常量值.
 注意:一般的,我们只在struts.xml中做常量配置.
 <constant name="struts.action.extension" value="action,do,,"/> .(可以在请求URL后面添加后缀名)

总的struts.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>

    <constant name="struts.action.extension" value="action,nice,,"></constant> <!-- 加后缀 -->
    <constant name="struts.devMode" value="true" />  <!-- 小的改动不需要再启动服务器 -->
    <constant name="struts.enable.DynamicMethodInvocation" value="true"/> <!-- 动态调用 -->
 

    <include file="accesspathhello_struts.xml"></include>
    <include file="/listgloble/List_struts.xml"></include>
    <include file="/multimethod/multimethod.xml"></include>
    <include file="/servletapi/api.xml"></include>
    <include file="/params/params.xml"></include>
    
</struts>

action.Java类

package accesspath;

public class HelloStrutsAction {
    public String hello(){
        System.out.println("$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$");
        return "h";
    }
}

action类的.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="struts-hello" extends="struts-default" abstract="true"></package>
    <package name="nihao" namespace="/nice" extends="struts-hello">
        <action name="hello" class="accesspath.HelloStrutsAction" method="hello">
            <result name="h">/JSP/HE.jsp</result>
        </action>
    </package> 
</struts>

list的action类

package listgloble;

public class ListAction {//如果不继承自ActionSupport,则需要根据普通类来处理,
                        //即,在xml中需要按普通方法的配置来写出name,class,method
        public String list() {
            return "success";
        }
}

list.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="struts-globle" extends="struts-default" abstract="true"></package>
    
    <package name="glob" namespace="/globle" extends="struts-globle">
    <!--globle 必须写在action之前 -->
<global-results> <result>/JSP/glob.jsp</result> </global-results> <action name="gg" class="listgloble.ListAction" method="list"> <!-- 程序进来后先执行此action,当有下面这句的时候, 先执行下面的result,若没有下面此句,则执行global-results里的--> <!-- <result name="success">/JSP/HE.jsp</result> --> </action> </package> </struts>

多方法调用:

package multimethod;

import com.opensymphony.xwork2.ActionSupport;

public class MultiMethodAction extends ActionSupport {
    private static final long serialVersionUID = 1L;
        public String add() {
                System.out.println("MultiMethodAction.add()");
            return "add";
        }
        public String delete() {
            System.out.println("MultiMethodAction.delete()");
            return "delete";
    }
        public String update() {
            System.out.println("MultiMethodAction.update()");
            return "update";
    }
        public String query() {
            System.out.println("MultiMethodAction.query()");
            return "query";
    }
        
}

多方法调用的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="multium" namespace="/method" extends="struts-default" >
    
        <!-- 第一种方法,每一个方法都写一个action 
        
            <action name="adds" class="multimethod.MultiMethodAction" method="add">
                <result name = "add">/JSP/glob.jsp</result>
            </action>
            <action name="deletes" class="multimethod.MultiMethodAction" method="delete">
                <result name = "delete">/JSP/HE.jsp</result>
            </action>
            <action name="updates" class="multimethod.MultiMethodAction" method="update">
                <result name = "update">/JSP/glob.jsp</result>
            </action>
            <action name="querys" class="multimethod.MultiMethodAction" method="query">
                <result name = "query">/JSP/HE.jsp</result>
            </action>
        -->
        <!-- 
            第二种方法:DMI(动态调用)
             访问方式:http//host:port//contextPath/namespace/actionName!methodName 
         
            <action name="dmi" class="multimethod.MultiMethodAction">
                <result name = "add">/JSP/glob.jsp</result>
                <result name = "delete">/JSP/glob.jsp</result>
                <result name = "update">/JSP/glob.jsp</result>
                <result name = "query">/JSP/glob.jsp</result>
            </action> 
        -->
        <!-- 第三种方法 通配符 
        http//host:port//contextPath/namespace/actions_methodName
        -->
        <action name="actions_*" class="multimethod.MultiMethodAction" method="{1}">
            <result name = "add">/JSP/HE.jsp</result>
            <result name = "delete">/JSP/glob.jsp</result>
            <result name = "update">/JSP/HE.jsp</result>
            <result name = "query">/JSP/glob.jsp</result>
        </action>
                    
    </package>
    
</struts>
原文地址:https://www.cnblogs.com/huike/p/6528689.html