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了,如果有兴趣可以用反编译工具编译下,就可以看源码了。 
|