Struts2讲义2

[size=xx-large]使用配置文件struts.xml实现页面导航定义[/size]
Struts2中最核心的是Action,而Action的核心就是struts.xml,struts.xml集中了所有页面的导航定义。对于大型的Web项目,通过此配置文件即可迅速把握其脉络,这不管是对于前期的开发,还是后期的维护或升级都是大有裨益的。掌握struts.xml是掌握Struts2的关键所在。
技术要点
本节代码向读者演示struts.xml内容的组成部分
 [align=left] XML文件字符编码定义和DTD文件声明。
 global-results映射定义,如何进行全局导航页面
 package映射定义。包含的Action各属性介绍[/align]演示代码
<!---------------------------------文件名:struts.xml------------------------------->
<?xml version="1.0" encoding="gb2312"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<!-- Action所在包定义 -->
<package name="C04" extends="struts-default">
<!-- 全局导航页面定义 -->
<global-results>
<result name="global">/jsp/login.jsp</result>
</global-results>
<!-- Action名字,类以及导航页面定义 -->
<!-- 通过Action类处理才导航的的Action定义 -->
<action name="Login"
class="com.example.struts.action.LoginAction">
<result name="input">/jsp/login.jsp</result>
<result name="success">/jsp/success.jsp</result>
</action>
<!-- 直接导航的的Action定义 -->
<action name="index" >
<result >/jsp/login.jsp</result>
</action>
</package>
</struts>
代码解释
(1)struts.xml第一行是所有xml文件都具有的声明。通常以“<?”开始,以“?>”结束。Version是必须指定的,该属性一般都为1.0,表明该文档遵守XML1.0规范。Encoding是可选的,如果不写则默认UTF-8,该文件代码中的gb2312表明该文件的编码集是gb2312,支持中文字符。常见的字符编码集有支持简体中文的gb2312,支持繁体中文的GBK,支持西欧字符的ISO8859-1以及通用的国际编码UTF-8。DTD文件必须被声明,它表明struts.xml是支持Struts2.0的文档类型定义。DTD全称为Document Type Defination(文档类型定义)。
(2)struts.xml文件中所有的属性定义都是以“<struts >”开始,“</struts >”结束。主要属性有很多,这里先详细介绍package。
(3)package里定义了Action映射申明。它也可以包含很多<action>或者一个也不包含(当然实际开发中是不可能一个都不包含的)。其中name属性内容是开发的web项目名称,比如本章代码是C04项目,所以代码里写的是C04。而且它还扩展了Struts2自带的缺省文件struts-default.xml配置文件,在此基础上可以对Action或其他项目中需要用到的类映射进行自定义。
(4)Action是之前所述package包含的Action映射申明。<action>里的name属性是在JSP页面上定义的Action名字。在Struts2里系统主动寻找名字为它的Action,一旦找到就根据class属性里定义的Action类路径去执行该Action类。在代码里可以看到Action名字为Login.action,系统搜索到它之后根据映射定义的class执行LoginAction类。result相当于在Struts1里的forward属性。因为Action对象都是配置对象,这些配置对象都有唯一的标识,其中name就是标识。通过检索这些标识,Action对象封装了需要指向的URL,系统就会将最后响应信息转到URL所指的JSP页面。也就是代码里在<result>和</result>里定义的JSP页面路径。
注意:Action的name一定要写成代码里显示的形式,没必要后面加“.do”或者“.action”这样的后缀名形式。因为“.do”是Struts1里定义的Action后缀名形式(当然在web.xml里也可以使用<url-pattern>*.do</url-pattern>来定义或定义成其他后缀名形式),在Struts2里已经废弃不用了。而“.action”不加是因为当系统运行时候其实它会自动搜寻后缀名为“.action”的Action,所以也没必要加。否则就变成搜寻“xx.action.action”这样格式的Action,系统肯定会报错。
另外说一句,虽然Struts2里系统只会搜寻“.action”的Action,但也可以让它只搜寻其他名字的后缀名。在Struts2的org/apache/struts2目录下有个default.properties属性文件,其中有个属性名为struts.action.extension,可以将它改为“struts.action.extension=do”,这样就只搜寻“.do”后缀名。如果不想修改Struts2的源文件,也可以用struts.properties,在该文件里加上“struts.action.extension=do”。而且还可以改为“struts.action.extension=do,htm”,这样就不只搜寻“.do”,还可以搜寻“.htm”后缀名。当中以“,”隔开就行。
代码里还示范了另外一种Action写法,这种Action是不经过具体Action类进行业务逻辑处理,而是类似一个简单的Html链接功能。如代码所示,系统找到index.Action,根据<result>里定义的URL,在浏览器里直接显示login.jsp。
注意:<result>和</result>之间定义的JSP页面要把全路径写出来,不能只写login.jsp、success.jsp。除非该JSP页面是在系统根目录下。
(5)<global-results>是全局导航页面映射定义,这些定义的<result>是被多个Action共用的。如果一个具体Action在<action>里找不到定义的<result>唯一标识,它就去寻找(也可称之为匹配)<global-results>里的<result>唯一标识。如代码所示如果LoginAction返回的唯一标识不是“input”和“success”而是“global”,那它就在浏览器显示的是名字为“global”的<result>指向的JSP,这里只是为了示范,所以还是指向login.jsp。可以新建一个error.jsp,让<global-results>中这个名字为“global”的<result>指向它。则页面显示的就是error.jsp的内容。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值