struts2配置文件讲解

解决在断网环境下,配置文件无提示的问题 咱们能够看到Struts.xml在断网的状况下,前面有一个叹号,这时,咱们按alt+/ 没有提示,这是由于” http://struts.apache.org/dtds/struts-2.0.dtd”是一个网络地址,若是上网的话,IDE会自动帮咱们下载此文件,若是断网就没有办法了,可是咱们仍是有解决方法的. 首先在源码包里找到struts-2.0.dtd这个文件 在MyEclipse中菜单栏中选择:windowPreferencesMyEclipseFiles and Editors Xmlxml Catalog在右边的下拉框中选择User Specified Entries点击Add按钮左边选中Catalog Entry右边的location中点击File System在弹出的对话框中将搜索到的文件全路径复制上去,并选中struts-2.0.dtd在key type下拉框中选择URIkey文本框中填写: http://struts.apache.org/dtds/struts-2.0.dtd ,点击OK便可. 这时咱们能够看到Struts.xml文件中还有叹号,咱们能够在Struts标签与package标签中打入一个回车后保存便可. 首先,咱们先配置一个HelloWorld程序 环境的搭建和前面讲的如出一辙,导6个jar包,复制struts.xml文件到src目录下,改写web.xml文件,将struts整合到web工程中,这里就再也不演示 如下是代码: Chapter1Action package chapter1.action; public class Chapter1Action { private String message; public String getMessage() {    return message; } public String execute() {    message = "个人第一个Struts2程序";    return "success"; } }  Struts.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"     "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <constant name="struts.enable.DynamicMethodInvocation" value="false"/> <constant name="struts.devMode" value="false"/> <constant name="struts.i18n.encoding" value="UTF-8"/> <constant name="struts.serve.static.browserCache" value="false"/> <include file="chapter1.xml"/> </struts>  chapter1.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"     "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <package name="chapter1" namespace="/chapter1" extends="struts-default">    <action name="HelloWorld" class="chapter1.action.Chapter1Action" method="execute">     <result name="success">/WEB-INF/JspPage/chapter1/HelloWorld.jsp</result>    </action> </package> </struts>  HelloWorld.jsp <%@ page language="java" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head>     <title>HelloWorld</title> </head>  <body>     ${message} </body> </html> 问题一:你们能够看到这里用到了EL表达式,咱们知道EL表达式只能取出page,request,session,application四个范围之一里面的数据,可是我这里并无将任何数据放入到四个范围中,为何这里可以取出数据来呢? 问题二: Chapter1Action是一个很是普通的类,它不是Servlet,为何可以处理用户的请求呢? Struts2用于处理用户请求的Action,没有与Servlet API耦合,显示没法处理用户请求,而Struts2提供了系列拦截器,该系列拦截器负责将HttpServletRequest请求中的请求参数解析出来,传入到Action中,并调用Action的execute方法来处理用户的请求. Struts.xml配置中包与action的介绍 <package name="chapter1" namespace="/chapter1" extends="struts-default"> <action name="HelloWorld" class="chapter1.action.Chapter1Action" method="execute">    <result name="success">/WEB-INF/JspPage/chapter1/HelloWorld.jsp</result> </action> </package>  Struts2框架中使用包来管理action,避免了Servlet在web.xml中难以管理的与维护的局面.包的做用和java中的类包是很是相似的,它主要用于管理一组业务功能相关的action,在实际应用中,咱们应该把一组业务功能相关的action 放在同一个包下. 配置包时必须指定name属性,该name属性值能够任意取名,但必须惟一,若是其余包要继承该包,必须经过该属性进行引用,包的namespace属性用于定义该包的命名空间,命名空间做用为访问该包下的action路径的一部分,见示例.namespace属性能够不配置,若是不指定该属性,默认的命名空间为”” 一般每一个包都应该继承struts-default包,由于struts2不少核心功能都是拦截来实现的,如,从请求中把请求参数封闭到action,文件上传和数据验证等都是经过拦截器实现的,struts-default定义了这些拦截器和Result类型,能够这么说,当包继承了struts-default才能使用struts2提供的核心功能,struts-default包是在struts2-core-2.xx.jar文件中的struts-defalut.xml中定义,struts-default.xml也是struts2默认配置文件,struts2每次都会自动加载struts-default.xml文件. package还有一个abstract=”true”属性,指定此包为抽象包,和抽象类的概念差很少,说明此包只能被其余包继承,则它里面不容许包含action元素. <action name="HelloWorld" class="chapter1.action.Chapter1Action" method="execute"> <result name="success">/WEB-INF/JspPage/chapter1/HelloWorld.jsp</result> </action>  Action 元素method属性,默认值为method=”execute”,也就是当action接收到请求后,交给哪一个方法去处理,默认的是交给execute方法去处理,固然,也能够交给其余方法,后面会讲解到. <result name="success">/WEB-INF/JspPage/chapter1/HelloWorld.jsp</result>  result元素主要定义视图的跳转和返回的行为及类型,后面会详细介绍. struts.xml文件的分离 从上一个项目实践中能够看到,咱们的web.xml文件很是之大,到后来是愈来愈难的查找与维护,看得头都是大的,Struts2配置文件能够分离,很好的解决了此问题. 经过主次配置文件的分离,能够增强团队间的合做,而且互不打扰彼此的配置文件,出了问题也知道责任在哪里. 在实例开发中也是这样作的,经过一个主文件中,打开全局开关,引入其余子配置文件,如: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"     "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <constant name="struts.enable.DynamicMethodInvocation" value="false"/> <constant name="struts.devMode" value="false"/> <constant name="struts.i18n.encoding" value="UTF-8"/> <constant name="struts.serve.static.browserCache " value="false"/> <include file="chapter1.xml"/> </struts>  经常使用开关的介绍 <constant name="struts.i18n.encoding" value="UTF-8"/> 指定Web应用的默认编码集,至关于调用HttpServletRequest的setCharacterEncoding方法 <constant name="struts.action.extension" value="do"/> 该属性指定须要Struts 2处理的请求后缀,该属性的默认值是action,即全部匹配*.action的请求都由Struts 2处理。    若是用户须要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。    <constant name="struts.serve.static.browserCache " value="false"/> 设置浏览器是否缓存静态内容,默认值为true,开发阶段最好false <constant name="struts.configuration.xml.reload" value="true"/> 当struts的配置文件修改后,系统是否自动从新加载该文件,默认值为false,开发阶段最好true <constant name="struts.devMode" value="true"/> 开发模式下设为true,这样能够打印出更详细的错误信息 <constant name="struts.enable.DynamicMethodInvocation" value="false"/> 动态方法调用,能够解决多个请求对应一个Servlet的问题,后面详细讲解,默认为true,关闭则设为false. 这里只是列举了一些经常使用的开关,固然还有许多其余的开关,后面的学习中会逐渐介绍,你们在这里先了解一下. 如下是从网上摘得的,比较全的一个资料 struts.serve.static.browserCache 该属性设置浏览器是否缓存静态内容。当应用处于开发阶段时,咱们但愿每次请求都得到服务器的最新响应,则可设置该属性为false。 struts.enable.DynamicMethodInvocation 该属性设置Struts 2是否支持动态方法调用,该属性的默认值是true。若是须要关闭动态方法调用,则可设置该属性为false。 struts.enable.SlashesInActionNames 该属性设置Struts 2是否容许在Action名中使用斜线,该属性的默认值是false。若是开发者但愿容许在Action名中使用斜线,则可设置该属性为true。 struts.tag.altSyntax 该属性指定是否容许在Struts 2标签中使用表达式语法,由于一般都须要在标签中使用表达式语法,故此属性应该设置为true,该属性的默认值是true。 struts.devMode该属性设置Struts 2应用是否使用开发模式。若是设置该属性为true,则能够在应用出错时显示更多、更友好的出错提示。该属性只接受true和flase两个值,该属性的默认值是false。一般,应用在开发阶段,将该属性设置为true,当进入产品发布阶段后,则该属性设置为false。 struts.i18n.reload该属性设置是否每次HTTP请求到达时,系统都从新加载资源文件。该属性默认值是false。在开发阶段将该属性设置为true会更有利于开发,但在产品发布阶段应将该属性设置为false。 提示 开发阶段将该属性设置了true,将能够在每次请求时都从新加载国际化资源文件,从而可让开发者看到实时开发效果;产品发布阶段应该将该属性设置为false,是为了提供响应性能,每次请求都须要从新加载资源文件会大大下降应用的性能。 struts.ui.theme该属性指定视图标签默认的视图主题,该属性的默认值是xhtml。 struts.ui.templateDir该属性指定视图主题所须要模板文件的位置,该属性的默认值是template,即默认加载template路径下的模板文件。 struts.ui.templateSuffix该属性指定模板文件的后缀,该属性的默认属性值是ftl。该属性还容许使用ftl、vm或jsp,分别对应FreeMarker、Velocity和JSP模板。 struts.configuration.xml.reload该属性设置当struts.xml文件改变后,系统是否自动从新加载该文件。该属性的默认值是false。 struts.velocity.configfile该属性指定Velocity框架所需的velocity.properties文件的位置。该属性的默认值为velocity.properties。 struts.velocity.contexts该属性指定Velocity框架的Context位置,若是该框架有多个Context,则多个Context之间以英文逗号(,)隔开。 struts.velocity.toolboxlocation该属性指定Velocity框架的toolbox的位置。 struts.url.http.port该属性指定Web应用所在的监听端口。该属性一般没有太大的用户,只是当Struts 2须要生成URL时(例如Url标签),该属性才提供Web应用的默认端口。 struts.url.https.port该属性相似于struts.url.http.port属性的做用,区别是该属性指定的是Web应用的加密服务端口。 struts.url.includeParams该属性指定Struts 2生成URL时是否包含请求参数。该属性接受none、get和all三个属性值,分别对应于不包含、仅包含GET类型请求参数和包含所有请求参数。 struts.custom.i18n.resources该属性指定Struts 2应用所须要的国际化资源文件,若是有多份国际化资源文件,则多个资源文件的文件名以英文逗号(,)隔开。 struts.dispatcher.parametersWorkaround 对于某些Java EE服务器,不支持HttpServlet Request调用getParameterMap()方法,此时能够设置该属性值为true来解决该问题。该属性的默认值是false。对于WebLogic、Orion和OC4J服务器,一般应该设置该属性为true。 struts.freemarker.manager.classname 该属性指定Struts 2使用的FreeMarker管理器。该属性的默认值是org.apache.struts2.views.freemarker.FreemarkerManager,这是Struts 2内建的FreeMarker管理器。 struts.freemarker.wrapper.altMap该属性只支持true和false两个属性值,默认值是true。一般无需修改该属性值。 struts.xslt.nocache 该属性指定XSLT Result是否使用样式表缓存。当应用处于开发阶段时,该属性一般被设置为true;当应用处于产品使用阶段时,该属性一般被设置为false。 struts.configuration.files 该属性指定Struts 2框架默认加载的配置文件,若是须要指定默认加载多个配置文件,则多个配置文件的文件名之间以英文逗号(,)隔开。该属性的默认值为struts-default.xml,struts-plugin.xml,struts.xml,看到该属性值,读者应该明白为何Struts 2框架默认加载struts.xml文件了。  在请求时,路径后的后缀action可要可不要,即下面的两种请求都是能够的 http://localhost:8080/Struts2/chapter1/HelloWorld http://localhost:8080/Struts2/chapter1/HelloWorld.action Action配置中的各项默认值 请看下面的代码 <action name="Login"> <result>/WEB-INF/JspPage/chapter1/Login.jsp</result> </action>  咱们发现,当咱们请求的路径为http://localhost:8080/Struts2/chapter1/Login时,一样能够实现页面的跳转,这是怎么回事呢? 若是没有为action指定class,默认是ActionSupport类 <action name="Login">  至关于  <action name="Login" class="com.opensymphony.xwork2.ActionSupport"> 若是没有为action指定method,默认执行action中的execute()方法 <action name="Login"> 至关于 <action name="Login" class="com.opensymphony.xwork2.ActionSupport" method="execute"> 若是没有指定result的name属性,默认值为success. <result> 至关于 <result name="success"> 提出一个问题ActionSupport这个类究竟是个什么类呢? 首先要确定的一点是他是一个具备execute方法的类,而且execute方法返回”success”字符串,由于只有这样,前面的运行结果才能说的通. ActionSupport还实现了不少其余的结果,提供了许多定制的功能. ActionSupport类的做用  struts2不要求咱们本身设计的action类继承任何的struts基类或struts接口,可是咱们为了方便实现咱们本身的action,大多数状况下都会继承com.opensymphony.xwork2.ActionSupport类,并重写此类里的public String execute() throws Exception方法。由于此类中实现了不少的实用借口,提供了不少默认方法,这些默认方法包括国际化信息的方法、默认的处理用户请求的方法等,这样能够大大的简化Acion的开发。  Struts2中一般直接使用Action来封装HTTP请求参数,所以,Action类里还应该包含与请求参数对应的属性,而且为属性提供对应的getter和setter方法。 课堂笔记 默认值 class="" ActionSupport method="" execute name="" “success” Action接口里提供了一些常量及execute方法,一般咱们本身写的Action能够实现这个接口, ActionSupport已经实现了这个接口,而且还实现了验证,国际化等功能的接口,因此咱们本身写的Action类一般会继承ActionSupport这个类来达到启用验证框架,国际化,自动转换等功能的目的.