Struts2配置文件加载顺序

struts2框架要能执行,必须先加载StrutsPrepareAndExecuteFilter.

在StrutsPrepareAndExecuteFilter的init方法中对Dispatcher进行了初始化.,Dispatcher类中定义的init方法内就描述了struts2配置文件加载的顺序


        init_DefaultProperties(); // [1]   ----------  org/apache/struts2/default.properties 
            init_TraditionalXmlConfigurations(); // [2]  --- struts-default.xml,struts-plugin.xml,struts.xml
            init_LegacyStrutsProperties(); // [3] --- 自定义struts.properties 
            init_CustomConfigurationProviders(); // [5]  ----- 自定义配置提供
            init_FilterInitParameters() ; // [6] ----- web.xml 
            init_AliasStandardObjects() ; // [7] ---- Bean加载 

1.default.properties文件
作用:定义了struts2框架中所有常量
位置: org/apache/struts2/default.properties 

2.struts-default.xml
作用:配置了bean,interceptor,result等。
位置:在struts的core核心jar包.

  struts-plugin.xml
它是struts2框架中所使用的插件的配置文件。
  struts.xml   
我们使struts2所使用的配置文件。

3.自定义的struts.properties
就是可以自定义常量。

4.web.xml

在开发中,后加载文件中的配置会将先加载文件中的配置覆盖。

default.properties
struts-default.xml

struts.xml

.关于Action的配置

1.<package>  作用:是用于声明一个包。用于管理action。
1.name     它用于声明一个包名,包名不能重复,也就是它是唯一的。 
2.namespace  它与action标签的name属性合并确定了一个唯一访问action的路径。
3.extends  它代表继承的包名。
4.abstrace 它可以取值为true/false,如果为true,代表这个包是用于被继承的。
2<action>  用于声明 一个action
1.name  就是action的一个名称,它是唯一的(在同包内) 它与package中的namespace确定了访问action的路径。
2.class Action类的全名
3.method 要访问的Action类中的方法的名称,方法无参数 ,返回值为String.
3.<result> 用于确定返回结果类型
1.name  它与action中的方法返回值做对比,确定跳转路径。

关于action配置其它细节:
1.关于默认值问题
<package namespace="默认值"> namespace的默认值是""
<action class="默认值"  method="默认值">
class的默认值是  com.opensymphony.xwork2.ActionSupport


method的默认值是  execute
<result\d X name="默认值"> name的默认值是 "success" 


2.关于访问action的路径问题
现在的action的配置是:
<package name="default" namespace="/" extends="struts-default">
<action name="hello" class="cn.itcast.action.DefaultAction">
<result>/hello.jsp</result>
</action>
</package>

当我们输入:
http://localhost/struts2_day01_2/a/b/c/hello
也访问到了action。

原因:struts2中的action被访问时,它会首先查找
1.namespace="/a/b/c"  action的name=hello  没有.
2.namespace="/a/b     action的name=hello  没有
3.namespace="/a"      action的name=hello  没有
4.namespace="/"        action的name=hello  查找到了.
 
如果最后也查找不到,会报404错误.

3.默认的action。
作用:处理其它action处理不了的路径。

<default-action-ref name="action的名称" />
配置了这个,当访问的路径,其它的action处理不了时,就会执行name指定的名称的action。

4.action的默认处理类
在action配置时,如果class不写。默认情况下是 com.opensymphony.xwork2.ActionSupport。

<default-class-ref class="cn.itcast.action.DefaultAction"/>

如果设置了,那么在当前包下,默认处理action请的的处理类就为class指定的类。

struts.xml文件的分离:

目的:就是为了阅读方便。可以让一个模块一个配置文件,在struts.xml文件中通过

<include file="test.xml"/>导入其它的配置文件。


关于Action类的创建方式介绍:
有三种方式
1.创建一个POJO类.
简单的Java对象(Plain Old Java Objects)
指的是没有实现任何接口,没有继承任何父类(除了Object)

优点:无耦合。
缺点:所以工作都要自己实现。

在struts2框架底层是通过反射来操作:
* struts2框架 读取struts.xml 获得 完整Action类名 
* obj = Class.forName("完整类名").newInstance();
* Method m = Class.forName("完整类名").getMethod("execute");  m.invoke(obj); 通过反射 执行 execute方法


2.创建一个类,实现Action接口.  com.opensymphony.xwork2.Action

优点:耦合低。提供了五种结果视图,定义了一个行为方法。
缺点:所以工作都要自己实现。

public static final String SUCCESS = "success";  // 数据处理成功 (成功页面)
public static final String NONE = "none";  // 页面不跳转  return null; 效果一样
public static final String ERROR = "error";  // 数据处理发送错误 (错误页面)
public static final String INPUT = "input"; // 用户输入数据有误,通常用于表单数据校验 (输入页面)
public static final String LOGIN = "login"; // 主要权限认证 (登陆页面)


3.创建一个类,继承自ActionSupport类.  com.opensymphony.xwork2.ActionSupport
ActionSupport类实现了Action接口。

优点:表单校验、错误信息设置、读取国际化信息 三个功能都支持.
缺点:耦合度高。

在开发中,第三种会使用的比较多.


在struts2框架中获取servlet api:

2.注入方式获取(这种方式是真正的获取到了servlet api)

1.要求action类必须实现提定接口。
ServletContextAware : 注入ServletContext对象
ServletRequestAware :注入 request对象
ServletResponseAware : 注入response对象


2.重定接口中的方法。
private HttpServletRequest request;
3.声明一个web对象,使用接口中的方法的参数对声明的web对象赋值.
public void setServletRequest(HttpServletRequest request) {
this.request = request;
}


扩展:分析其实现:
是使用struts2中的一个interceptor完成的.
<interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>

 if (action instanceof ServletRequestAware) { //判断action是否实现了ServletRequestAware接口
HttpServletRequest request = (HttpServletRequest) context.get(HTTP_REQUEST); //得到request对象.
((ServletRequestAware) action).setServletRequest(request);//将request对象通过action中重写的方法注入。
}

3.通过ServletActionContext获取.
在ServletActionContext中方法都是static。
getRequest();
getResposne();

getPageContext();


Result结果类型:

<result>标签
1.name  与action中的method的返回值匹配,进行跳转.

2.type  作用:是用于定义跳转方式

对于type属性它的值有以下几种:
在struts-default.xml文件中定义了type可以取的值

<result-type name="chain" class="com.opensymphony.xwork2.ActionChainResult"/>

<resulttype name="dispatcher"class="org.apache.struts2.dispatcher.ServletDispatcherResult"default="true"/>

<result-type name="freemarker" class="org.apache.struts2.views.freemarker.FreemarkerResult"/>

<result-type name="httpheader" class="org.apache.struts2.dispatcher.HttpHeaderResult"/>

<result-type name="redirect" class="org.apache.struts2.dispatcher.ServletRedirectResult"/>

<result-typename="redirectAction" class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>

<result-type name="stream" class="org.apache.struts2.dispatcher.StreamResult"/>

<result-type name="velocity" class="org.apache.struts2.dispatcher.VelocityResult"/>

<result-type name="xslt" class="org.apache.struts2.views.xslt.XSLTResult"/>

<result-type name="plainText" class="org.apache.struts2.dispatcher.PlainTextResult" />


必会: chain  dispatcher  redirect redirectAction  stream


dispatcher:它代表的是请求转发,也是默认值。它一般用于从action跳转到页面。

        chain:它也相当于请求转发。它一般情况下用于从一个action跳转到另一个action。
redirect:它代表的是重定向  它一般用于从action跳转到页面
redirectAction: 它代表的是重定向  它一般用于从action跳转另一个action。
stream:代表的是服务器端返回的是一个流,一般用于下载。

猜你喜欢

转载自blog.csdn.net/qq_29569183/article/details/80048677
今日推荐