我是靠谱客的博主 真实香菇,最近开发中收集的这篇文章主要介绍SSH框架之struts2专题2:Struts2配置文件1 Struts2相关的六个配置文件2 Struts2核心配置文件,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
1 Struts2相关的六个配置文件
1.1 struts-default.xml文件(只读,不可修改)
- Struts2的默认核心配置文件,其中主要定义了11种返回类型、35种拦截器,以及拦截器栈。其中较重要的默认拦截器栈中包含20种拦截器,是Struts2核心功能的体现。
<struts> <package name="struts-default" abstract="true"> <!-- 定义了11种返回类型 --> <result-types> <result-type name="chain" class="com.opensymphony.xwork2.ActionChainResult"/> <result-type 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-type name="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" /> <result-type name="postback" class="org.apache.struts2.dispatcher.PostbackResult" /> </result-types> <!-- 定义35种拦截器 --> <interceptors> <interceptor name="alias" class="com.opensymphony.xwork2.interceptor.AliasInterceptor"/> <interceptor name="autowiring" class="com.opensymphony.xwork2.spring.interceptor.ActionAutowiringInterceptor"/> <interceptor name="chain" class="com.opensymphony.xwork2.interceptor.ChainingInterceptor"/> <interceptor name="conversionError" class="org.apache.struts2.interceptor.StrutsConversionErrorInterceptor"/> <interceptor name="cookie" class="org.apache.struts2.interceptor.CookieInterceptor"/> <interceptor name="cookieProvider" class="org.apache.struts2.interceptor.CookieProviderInterceptor"/> <interceptor name="clearSession" class="org.apache.struts2.interceptor.ClearSessionInterceptor" /> <interceptor name="createSession" class="org.apache.struts2.interceptor.CreateSessionInterceptor" /> <interceptor name="debugging" class="org.apache.struts2.interceptor.debugging.DebuggingInterceptor" /> <interceptor name="execAndWait" class="org.apache.struts2.interceptor.ExecuteAndWaitInterceptor"/> <interceptor name="exception" class="com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor"/> <interceptor name="fileUpload" class="org.apache.struts2.interceptor.FileUploadInterceptor"/> <interceptor name="i18n" class="com.opensymphony.xwork2.interceptor.I18nInterceptor"/> <interceptor name="logger" class="com.opensymphony.xwork2.interceptor.LoggingInterceptor"/> <interceptor name="modelDriven" class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/> <interceptor name="scopedModelDriven" class="com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor"/> <interceptor name="params" class="com.opensymphony.xwork2.interceptor.ParametersInterceptor"/> <interceptor name="actionMappingParams" class="org.apache.struts2.interceptor.ActionMappingParametersInteceptor"/> <interceptor name="prepare" class="com.opensymphony.xwork2.interceptor.PrepareInterceptor"/> <interceptor name="staticParams" class="com.opensymphony.xwork2.interceptor.StaticParametersInterceptor"/> <interceptor name="scope" class="org.apache.struts2.interceptor.ScopeInterceptor"/> <interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/> <interceptor name="timer" class="com.opensymphony.xwork2.interceptor.TimerInterceptor"/> <interceptor name="token" class="org.apache.struts2.interceptor.TokenInterceptor"/> <interceptor name="tokenSession" class="org.apache.struts2.interceptor.TokenSessionStoreInterceptor"/> <interceptor name="validation" class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/> <interceptor name="workflow" class="com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor"/> <interceptor name="store" class="org.apache.struts2.interceptor.MessageStoreInterceptor" /> <interceptor name="checkbox" class="org.apache.struts2.interceptor.CheckboxInterceptor" /> <interceptor name="datetime" class="org.apache.struts2.interceptor.DateTextFieldInterceptor" /> <interceptor name="profiling" class="org.apache.struts2.interceptor.ProfilingActivationInterceptor" /> <interceptor name="roles" class="org.apache.struts2.interceptor.RolesInterceptor" /> <interceptor name="annotationWorkflow" class="com.opensymphony.xwork2.interceptor.annotations.AnnotationWorkflowInterceptor" /> <interceptor name="multiselect" class="org.apache.struts2.interceptor.MultiselectInterceptor" /> <interceptor name="deprecation" class="org.apache.struts2.interceptor.DeprecationInterceptor" /> <!-- 定义默认拦截器栈,包括20种拦截器 --> <interceptor-stack name="defaultStack"> <interceptor-ref name="exception"/> <interceptor-ref name="alias"/> <interceptor-ref name="servletConfig"/> <interceptor-ref name="i18n"/> <interceptor-ref name="prepare"/> <interceptor-ref name="chain"/> <interceptor-ref name="scopedModelDriven"/> <interceptor-ref name="modelDriven"/> <interceptor-ref name="fileUpload"/> <interceptor-ref name="checkbox"/> <interceptor-ref name="datetime"/> <interceptor-ref name="multiselect"/> <interceptor-ref name="staticParams"/> <interceptor-ref name="actionMappingParams"/> <interceptor-ref name="params"/> <interceptor-ref name="conversionError"/> <interceptor-ref name="validation"> <param name="excludeMethods">input,back,cancel,browse</param> </interceptor-ref> <interceptor-ref name="workflow"> <param name="excludeMethods">input,back,cancel,browse</param> </interceptor-ref> <interceptor-ref name="debugging"/> <interceptor-ref name="deprecation"/> </interceptor-stack> </package> </struts>
1.2 default.properties配置文件(只读,不可修改)
- 定义了Struts2中用到的常量的默认值。
# 设置Struts2中请求的字符集 struts.i18n.encoding=UTF-8 # SSH中使用。将Action交由Spring容器来管理 struts.objectFactory = spring # SSH中使用。按名称自动装配Bean struts.objectFactory.spring.autoWire = name # 设置文件上传的最大文件大小值。单位为:字节。 struts.multipart.maxSize=2097152 # 设置struts2所处理请求的默认扩展名 struts.action.extension=action,, # 动态方法调用的开关 struts.enable.DynamicMethodInvocation = false # 开关模式开关。开关模式的开启,在控制台给出更多信息。 struts.devMode = false
1.3 struts-plugin.xml配置文件(只读,不可修改)
- Struts2与第三方插件的整合配置文件。
- 位置:Struts2框架lib目录中所有以-plugin-结束的jar包中。
1.4 struts.properties配置文件
- 用于修改常量的值。因为常量在struts.xml中也可以进行配置,所以一般不使用该文件。
- 该文件是程序员手工创建的,放在src目录下,即classpath下,文件内容格式为:
struts.i18n.encoding = GBK struts.action.extension = action, do
- 注意:配置项与default.properties配置文件的关系是覆盖,而不是追加。
1.5 web.xml配置文件
- 可用于设置常量,扩展Struts2等,但是一般不这样使用。因为这里的常量设置在struts.xml中均可设置。但是,若这些文件中均做了某一个设置,web.xml中设置的优先级最高。
<!-- 注册Struts2的启动项 --> <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> <!-- 在此可进行常量设置等 --> <init-param> <param-name>struts.i18n.encoding</param-name> <param-value>GBK</param-value> </init-param> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
1.6 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="do"></constant> </struts>
- struts.xml文件设置常量的优先级比web.xml和struts.properties配置文件都低,优先级处于最低的位置。
2 Struts2核心配置文件
2.1 < package/>标签
1、name属性:配置包时必须指定name属性,该属性值可以任意取值,但是必须唯一。其与Java的类包间无对应关系。若其他包要继承该包,则必须通过该属性进行引用。
2、namespace属性:包的namespace属性用于定义该包下Action路径的一部分。此属性是必须的,且不能为空值。但是命名空间可以为“/”,表示为Web应用的根路径。<!-- 正确 --> <package name="demo" namespace="/test" extends="struts-default"> <!-- 正确 --> <package name="demo" namespace="/xxx/jjj" extends="struts-default"> <!-- 正确 --> <package name="demo" namespace="/" extends="struts-default"> <!-- 错误 --> <package name="demo" namespace="" extends="struts-default"> <!-- 错误 --> <package name="demo" namespace="xxx" extends="struts-default"> <!-- 无namespace属性,错误 --> <package name="demo" extends="struts-default">
- name通常和namespace属性对应使用,如name = "xxx-yyy-test" ,namespace="/xxx/yyy/test"。
3、extends属性:
- 通常情况下,包需要继承struts-default包。因为Struts2的11个返回类型、35个拦截器、默认拦截器栈等Struts2的主要功能,都定义在这个包中。继承了这个包,也就是拥有了这些功能。struts-default包定义在struts-default.xml中。
4、abstract属性:
- 包还可以通过abstract="true"定义为抽象包。抽象包中是不能包含Action的。抽象包一般就是用于被继承的。structs-default包即为抽象包。
2.2 < action/>标签
1、name属性:
- 在struts2中,访问struts2中的action的URL路径由两部分组成:包的命名空间+action的name属性值。例如访问loginDemo例子中名为login的Action的URL路径为:/test/login.action。
- 若从浏览器地址直接访问,其访问URL地址可写为: http://127.0.0.1:8080/loginDemo/test/login.action 。
2、method属性:
- Action标签由一个属性method,该属性用于指定所要执行的Action类的哪个Action方法。若没有指定该属性值,则默认值为“execute”,即执行指定Action类的execute方法。
- 测试1:修改Action中的Action方法名不为execute,而不指定method属性值,提交请求,会看到错误提示。
- 结论:说明默认自动查找执行的方法名为execute()。
- 测试2:在同一个Action类中创建两个Action方法,在配置文件中创建两个相对应的<action/>。可以看到这两个<action/>的class属性相同,但是name和method均不同。
- 说明<action/>的定义粒度并非是Action类,而是Action类中的method。即<action/>定义的是“Action类 + method”。
3、class属性:
- class属性用于指定该Action所要执行的Action类。其由三种写法:
a、直接写要执行的类的全限定性类名。
b、在SSH中,Action交由Spring容器进行管理,此时class属性要设置为一个伪类名。
c、class属性缺省。对于class属性缺省情况是指,若用户提交某个请求后,不需要经过某个Action类的处理,而是直接要转向某个视图页面,如简单的页面间的超链接,则可以采用如下形式: - 若<action/>没有class属性,则默认执行ActionSupport类。原因是在Struts-default包中通过<default-class-ref/>指定默认执行的类。
<default-class-ref class="com.opensymphony.xwork2.ActionSupport" />
- ActionSupport类有一个execute()方法,其返回值为常量SUCCESS,即字符串“success”。
2.3 < result/>标签
1、name属性:result标签用于指定Action执行完毕后所要转向的视图资源。其name属性指定该视图的名称,如果name属性缺省,默认值为字符串常量“success”。
2、type属性:Struts2中共提供了11种视图转向类型,类型由result标签的type属性指定,type属性的值在struts-default.xml中可以查看到。需要注意的是,在dispatcher后设置的default为true。<result-types> <result-type name="dispatcher" class="org.apache.struts2.dispatcher.ServletDispatcherResult" default="true"/> </result-types>
- 注意,对于请求转发的页面,可以是WEB-INF中的页面:而重定向的页面,是不能为WEB-INF中的页面的。因为重定向相对于用户而言是再发一次请求,而用户是不能直接访问WEB-INF中的资源。
dispatcher转发: - 该转向类型用于完成请求转发功能,即服务器内跳转。请求转发是可以将请求参数传递给所要转发的下一级页面的。dispatcher为默认转向类型。
redirect跳转:
- redirect是无法将Action中的属性值传递给要转向的下一个页面的。但是可以通过在result值中使用${属性名}表达式携带参数的形式,实现将属性值向下传递的目的。表达式里的“属性名”对应Action类中的属性。
- 该请求在进行重定向时,会将username加入请求参数中,以GET方式提交请求。该username为LoginAction中的属性。若有多个请求参数,注意参数连接符为“& + amp;”,而非&。
- 但是对于动态参数的写法,Struts2不建议以上写法,而是提倡<param/>方式。
- 还可以通过参数charSet设置字符集。
- 注意,其输出是从param参数中进行读取。
redirectAction跳转:
- 专门用于重定向到Action。当然,Action中的属性值是无法传递到下一个Action中的。不过请注意,redirect在不使用<param/>方式时,也是可以重定向到Aciton的。
- 对于重定向到action,还可以使用<param/>来设定转向的action。注意,也不要为要跳转的action添加请求扩展名。且使用<param/>方式时,不能使用type="redirect",必须使用redirectAction。
- 也可以转向其他包中的action,通过namespace参数指定包。
chain跳转:
- 用于将请求转发到Action中。注意,此时要转向的Aciton请求不能带扩展名。例如本例,只能写为second,但是不能够写为second.action。当然,request范围的参数是可以传递到下一个Action中的。
2.4 全局视图globalResults
1、包范围全局视图:
- 若某视图页面可以被同一个包中的多个action所公用,则应将其定义为包范围全局视图。包范围全局视图定义于包中,在包中是可见的。
2、应用范围全局视图:
- 若要使某个视图为所有包可用,即定义其为应用范围全局视图。可定义一个基本包,在基本包中定义全局视图。然后,让其他包都继承自该基本包即可。当然,基本包要继承自struts-default。
2.5 为应用指定多个配置文件
- 在大部分应用里,随着应用规模的增加,系统中Action数量也大量增加,导致struts.xml配置文件变得非常庞大、臃肿。为了避免这种情况的发生,提高struts.xml文件的可读性和可维护性,可以将一个struts.xml配置文件分解成多个配置文件,然后在struts.xml文件中包含入其他配置文件。
- 为Struts2应用指定多个Struts2配置文件,可以使用<include/>。
- 一般情况下,是按照功能模块来拆分struts.xml配置文件的。需要注意的是,要保证各个子配置文件中的包名是不能重复的。
- 当然,若各个子配置文件的命名结构相同,也可以使用通配符*来定义被包含的子配置文件。
转载于:https://blog.51cto.com/12402717/2057987
最后
以上就是真实香菇为你收集整理的SSH框架之struts2专题2:Struts2配置文件1 Struts2相关的六个配置文件2 Struts2核心配置文件的全部内容,希望文章能够帮你解决SSH框架之struts2专题2:Struts2配置文件1 Struts2相关的六个配置文件2 Struts2核心配置文件所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复