Struct.xml Action配置

<package  name="default" namespace="/"   extends="struts-default">

        <action name="hello">
           <result>
              /Hello.jsp
           </result>
        </action>
    </package>

struct通过这个action寻找目的视图的过程其实是分为以下几步的:

1. 找出与url中地址匹配name的action

2. 找到这个action后,看他的class与method属性,得到这个class对象对应的method方法的返回值(一定是字符串)

 class默认值是ActionSupport

     method默认值是execute

3.  寻找与返回值具有匹配的name的result

所以Action的配置有以下三种:

具体视图的返回可以由用户自己定义的Action来决定

具体的手段是根据返回的字符串找到对应的配置项,来决定是视图的内容

Action 的class的处理

  • 具体的Action的实现可以是一个普通的java类,里面有public String execute方法即可(忘掉)
  • 实现Action接口且实现他的execute方法(忘掉)
  • 从ActionSupport类继承,好处是它可以直接使用Struct2封装好的方法

Action如果没有class属性,那么默认的就是ActionSupport。

看ActionSupport这个类的源码,会发现有一个方法:

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

其实Struct就是默认调用的这个方法

但是Action执行的时候并不一定执行execute方法

Action 配置

  • 1 可以通过在配置Action的时候加上一个method属性
<action name="userAdd" class="com.bjsxt.struts2.user.action.UserAction" method="add">
     <result>/user_add_success.jsp</result>
</action>

忘掉,太不灵活,会产生大量的action(一个方法一个action)

  • 2 在url地址中动态指定(动态方法调用DMI)
<package name="user" extends="struts-default" namespace="/user">

        <action name="user" class="com.bjsxt.struts2.user.action.UserAction">
            <result>/user_add_success.jsp</result>
        </action>
    </package>

然后要配url,配置url的时候,用个感叹号把方法分开

<a href="<%=context %>/user/user!add">添加用户</a>
<a href="<%=context %>/user/user!delete">删除用户</a>

这样的话对于同一个类 只需要上面一条action即可,但是在UserAction中注意要写上不同的方法

  • 3.通配符
<struts>
    <constant name="struts.devMode" value="true" />
    <package name="actions" extends="struts-default" namespace="/actions">
        <action name="Student*" class="com.bjsxt.struts2.action.StudentAction" method="{1}">
            <result>/Student{1}_success.jsp</result>
        </action>

        <action name="*_*" class="com.bjsxt.struts2.action.{1}Action" method="{2}">
            <result>/{1}_{2}_success.jsp</result>
            <!-- {0}_success.jsp -->
        </action>
    </package>
</struts>

{1} 表示第一个*

 使用通配符,可以将配置量降到最低

遵守 约定大于配置的原则,

匹配顺序

  • 如果有多个action符合的话,不带通配符的级别高
  • 只要是含有通配符的都是一个级别,谁在前面匹配谁
时间: 2024-08-07 18:02:33

Struct.xml Action配置的相关文章

struts.xml文件中action配置、OGNL的投影映射、OGNL表达式的符号

在struts.xml文件中不同的action配置,请求的路径是不一样的 1.请求 path = user!query.action; 配置如下: <action name="user" class="com.bwf.code.action.UserAction"> <result name="queryUser">/query.jsp</result> </action> 2.请求path = u

在struts-config.xml中配置validator-plugin导致404 Servlet action is not available

就是在struts-config.xml中添加了这么一段 <plug-in className="org.apache.struts.validator.ValidatorPlugIn"> <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"/> <set-property pro

strut2_struts.xml文件配置知识点汇集

1.Struts2的基本流程 Struts2框架大致分为三部分: .核心控制器StrutsPerpareAndExecuteFilter,Struts2框架提供 .业务控制器 ,用户自己实现 .用户实现的业务逻辑组建,用户自己实现 Struts2应用中的Action用于处理用户请求的Action实例,并不是用户自己实现业务控制器,而是Action代理.因为用户实现的业务控制器并没有ServletAPI耦合,显然无法处理用户请求.而Stuts2框架提供了系列拦截器,该拦截器负责将HttpServl

源码跟读,Spring是如何解析和加载xml中配置的beans

Spring版本基于: 跟踪代码源码基于: https://github.com/deng-cc/KeepLearning commit id:c009ce47bd19e1faf9e07f12086cd440b7799a63 1.配置启动Spring所需的监听器 web.xml中配置监听器 <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-cla

Struts2基于注解的Action配置

使用注解来配置Action的最大优点就是能够实现零配置,可是事务都是有利有弊的.使用方便.维护起来就没那么方便了. 要使用注解方式,我们必须加入一个额外包:struts2-convention-plugin-2.x.x.jar. 虽说是零配置的,但struts.xml还是少不了的,配置例如以下: <? xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apa

java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)

1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":&qu

Struts2的默认action配置真的是bug?

最近在捯饬struts2,其中在学习一个namespace中的默认action的时候,遇到了一个问题,先提供下struts的配置文件如下: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://str

web.xml完整配置

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" id="WebApp_1227143028044" version="2.4" xsi:

JavaEE SSH框架整合(二) struts2 加载本地dtd文件,action配置

1. 加载struts2的dtd文件,使struts.xml不用联网就能验证,并在eclipse中有提示 在src下创建struts.xml: <?xmlversion="1.0"encoding="UTF-8"?> <!DOCTYPE strutsPUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://strut