1

我有一个 Web 应用程序正在从 Tomcat 5.5.35 迁移到 Tomcat 7.0.39。目前,有几个自定义标记库,每个都在自己的tld文件中定义。这是一个例子:

<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd">
<taglib>
    <tlib-version>1.0</tlib-version>
    <jsp-version>1.2</jsp-version>
    <short-name>customTag</short-name>
    <uri>http://www.something.com/util/customTag-db-taglib</uri>
    <description>
        Database tag library for Util 
    </description>
    <tag>
        <name>useBean</name>
        <tag-class>com.mx.releasemgr.tags.db.UseBeanTag</tag-class>
        <tei-class>com.mx.releasemgr.tags.db.UseBeanTEI</tei-class>
        <body-content>EMPTY</body-content>
        <attribute>
            <name>id</name>
            <required>true</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
        <attribute>
            <name>oid</name>
            <required>false</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
        <attribute>
            <name>oidParameter</name>
            <required>false</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
        <attribute>
            <name>type</name>
            <required>true</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
        <attribute>
            <name>scope</name>
            <required>false</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
    </tag>
    ...
</taglib>

该文件夹中恰好有一份此 tld 文件的副本WEB-INF。它从未被放入jar文件中。

web.xml看起来像这样:

<?xml version="1.0" encoding="UTF-8"?>
<web-app 
  xmlns="http://java.sun.com/xml/ns/javaee" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
  http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0">
...
<jsp-config>
     <taglib>
    <taglib-uri>customTag</taglib-uri>
    <taglib-location>/WEB-INF/customTag.tld</taglib-location>
</taglib>
</jsp-config>
...

此错误显示在catalina.out

Apr 11, 2013 3:50:08 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://www.mx.com/releasemgr/releasemgr-db-taglib is already defined

taglib 是这样导入的:

<%@ taglib uri="customTag" prefix="db" %>

我看过这个问题,但它似乎并不适用。我已经添加了<jsp-config>,它没有帮助。我把标签库叫错了吗?URI 参数是否正确?任何帮助表示赞赏。

4

1 回答 1

3

规范要求的 URI 的优先顺序是:

  1. J2EE 平台标记库 - Tomcat 不提供这些
  2. web.xml 条目
  3. WEB-INF/lib 中的 JARS 和 WEB-INF下的 TLD(同等优先级)
  4. 来自容器的其他条目

您的 tld 加载了两次,第一次来自 web.xml,第二次来自扫描 WEB-INF 及其子文件夹。

解决方案是

1、从web.xml中删除

或者

2、把你的tld文件放在/WEB-INF/tags/


好的,这只是一个小故事。如果你想了解更多。

1、tomcat 5.5也有同样的逻辑,只是不做烦人的日志而已。

2、这个日志是在tomcat启动的时候出现的。在 tomcat 启动时加载 tld用于在 tld 文件中查找侦听器。

3、在jsp中真正使用tld是另外一回事。

在编译第一个 jsp 时,tomcat 将为 uri 和 location 对构建缓存。

uri加载来自相同的顺序

1) web.xml 条目,标签 uri 来自 web.xml

2) 扫描WEB-INF下的tld文件,标签uri取自tld文件

3) 扫描 jars,标签 uri 是从 tld 文件中获取的。

所以在你的配置中,customTag.tld 注册了 2 个 uri、customTag 和http://www.mx.com/releasemgr/releasemgr-db-taglib

4)当tomcat启动时。它加载 tld 以在 tld 文件中查找侦听器。

从 web.xml 加载时,它会将 customTag(来自 web.xml)和http://www.mx.com/releasemgr/releasemgr-db-taglib (来自tld 文件)放入一个集合中。

从 WEB-INF 加载时,uri 来自 tld 文件,即 ttp://www.mx.com/releasemgr/releasemgr-db-taglib。Tomcat 需要避免重复添加 tld 监听器,因此它会检查 uri 是否存在于集合中。如果 uri 已经存在,它会记录消息并跳过添加 tld 侦听器。

把它们放在一起,

1、如果你的tld文件中没有监听器,Tomcat启动时不需要扫描tld。您可以通过在上下文中将 processTlds 设置为 false 来禁用。

在编译第一个 jsp 时,tomcat 将为 uri 和 location 对构建缓存。

2,您可以忽略警告。这只是为了避免在 tld 文件中重复加载侦听器。

于 2013-11-14T16:52:28.530 回答