Struts的核心是拥有众多的自定义标记,这些自定义标记构成了Struts的外在的具体的实现,所以
弄清这些标记的来龙去脉是学好Struts基础的关键。
那么什么是标记呢?
<jsp:forward page=”next.jsp”>
<jsp:param name=”image” value=”house.gif” />
</jsp:forward>
(注:在next.jsp中使用:request.getParameter(“image”),把属性“image”的值取出来,也即:hous.gif )
假如上面例子使用的JSP标签是我们自己定义的,那么对于该标记而言,有如下概念:
1.标记名称:也即jsp:forward,jsp是前缀,forward是后缀,中间用冒号分割。
2.标记的属性:page就是jsp:forward的属性。而name、value是jsp:param的属性。
3.嵌套 :在<jsp:forward>中还有<jsp:param>标记,前者为父标记,后者为子标记。
4.体内容:上面的例子两个标记都没有体内容。
现在我们有这样的自定义标记<lsmx:hello></lsmx:hello>那么服务器在看到它的时候怎么能认识呢?
并且它所代表的功能怎么实现呢?那首先你必须在JSP页面引入下面的内容:
<%@ taglib uri="/mytag" prefix="lsmx" %>
它是在程序的web.xml中定义的
<taglib>
<taglib-uri>/mytag</taglib-uri>
<taglib-location>/WEB-INF/tlds/mytag.tld</taglib-location>
</taglib>
这样服务器就会根据<taglib-location>找到响应的*.tld文件。也就是标记描述器。
标记库描述器(Tag Library Descrip TLD)文件:遵循Sun Microsystems定义的DTD标准的XML文档,
它描述了包含着一个或多个标记扩展的标记库。并且它把标记映射到标记处理器类,还定义
两者之间的交互方式。我认为就像微软的COM技术中注册组件的地方,可以使客户段很方便
的找到服务器,说白了就是一个路牌,使程序很方便的找到要用的东西,那上面的
uri="/mytag" 中 mytag 就是这个标记库描述器的名字 ,而prefix="lsmx" lsmx是标
记的前缀,在这个全名为mytag.tld的标记库描述器里一定有这样的代码:
<tag>
<name>hello</name>
<tagclass>tagext.MyTag</tagclass>
<bodycontent>JSP</bodycontent>
</tag>
hello 就是jsp中标记的后缀。而tagext.MyTag就是标记处理器。
标记处理器:实现了标记具体功能的类,是一个JavaBean,它扩展了JSP API提供的这个类:
javax.servlet.jsp.tagext.TagSupport。我们就可以把这一标记要实现的所有功能的代
写在这个类里。
在Struts中是怎么应用这些的呢?
我们看一个登陆界面常用的标记<html:text property="username"/>
1.在JSP的上部一定有这样的代码
<%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
2.进入web.xml我们找到
<taglib>
<taglib-uri>/WEB-INF/struts-html.tld</taglib-uri>
<taglib-location>/WEB-INF/struts-html.tld</taglib-location>
</taglib>
可以看到它的<taglib-uri>用的是<taglib-location>的路径加文件名,其实也可以不是这样,只要这的
uri与jsp中的uri相同就可以了,但却不能与这个web.xml文件夹下别的<taglib>的<taglib-uri>同名。
3.进入/WEB-INF/struts-html.tld中找到
<tag>
<name>text</name>
<tagclass>org.apache.struts.taglib.html.TextTag</tagclass>
····
一些属性设置
····
</tag>
4.这样就找到哪个实现这一标记功能的TextTag.class了,如果有兴趣可以用反编译工具编译下,就可以看源码了。