前言
上篇Struts博文已经讲解了Struts的开发步骤以及执行流程了…..对Struts的配置文件有了了解…..本博文继续讲解Struts在配置的时候一些值得要学习的细节…
为什么要学习通配符
在讲解通配符之前,我们来看一下需求…..
现在我的Action中有两个方法,处理登陆和处理注册:
public class PrivilegeAction extends ActionSupport { public String login() { System.out.println("我是登陆"); return "success"; } public String register() { System.out.println("我是注册"); return "success"; } }
因此,我们就需要在struts.xml文件中配置两个action节点
<action name="login" class="privilegeaction.PrivilegeAction" method="login"> <result name="success">/index.jsp</result> </action> <action name="register" class="privilegeaction.PrivilegeAction" method="register"> <result name="success">/index.jsp</result> </action>
现在我们发现:它们仅仅只有访问路径和方法的名称是不一样的….但是这却要多配置一个action节点,会造成浪费!
于是乎通配符就应运而生了…
使用通配符改造
没有通配符之前,我们是需要配置两个action的…有了通配符,我们是这样做的:
<package name="privilige" extends="struts-default"> <action name="privilege_*" class="privilegeaction.PrivilegeAction" method="{1}"> <result name="success">/index.jsp</result> </action> </package>
解释一下:
name=privilege_*
,我们用了_作为分隔符。*就是我们的通配符{1}
,就是代表着第一个通配符
我们来看一下效果:
同理可得,当我们在地址栏访问login的时候,就会执行login的方法
Struts中路径的匹配原则
有的时候,我们可能会在package节点中指定namespace名称空间,我们在访问对应的资源名称的时候,就需要在前面加入相对应名称空间的值…
比如:
名称空间的值为“/user”
<package name="privilige" extends="struts-default" namespace="/user"> <action name="privilege_*" class="privilegeaction.PrivilegeAction" method="{1}"> <result name="success">/index.jsp</result> </action> </package>
那么在访问资源的时候,就需要在项目名称后边加上名称空间的值:
现在就有一个很奇怪妙的事情发生了:在名称空间和资源路径的中间可添加任意的路径
但是呢,不能在名称空间之前加入不存在的路径:
其实这就涉及到了Struts中路径的匹配原则,我就拿随便拿个路径来举例子http://localhost:8080/user/a/a/privilege_login
:
- 首先,Struts会把请求的资源路径拿到,也就是
privilege_login
。 - 然后在看看有没有
/user/a/a
这个名称空间;如果有,就返回结果 - 如果没有,就看看有没有
/user/a
这个名称空间;如果有,就返回结果 - 如果没有,再看看有没有
/user
这个名称空间;如果有,就返回结果 - 直到最后,如果都没有找到,就报错!
看完这个例子,我们就可以知道为啥在名称空间和资源路径的中间可添加任意的路径,而不能在名称空间之前加入不存在的路径….这就是Struts的路径匹配原则..