所以我在 Gemini 运行时下使用 OSGi 中的 JSTL。当我尝试访问我的 servlet
的 url 时,出现以下异常:-
SEVERE: Servlet.service() for servlet jsp threw exception
org.apache.jasper.JasperException: /WEB-INF/login.jsp (line: 3, column: 66) Unable to read TLD "META-INF/c.tld" from JAR file "file:/D:/OSGi%20Runtime/Gemini/gemini-web/dep/com.springsource.javax.servlet.jsp.jstl-1.2.0.v20110728.jar": org.apache.jasper.JasperException: Failed to load or instantiate TagLibraryValidator class: org.apache.taglibs.standard.tlv.JstlCoreTLV
但是,我已经检查过,我的运行时中已经拥有所有必需的包。我拥有的相关 bundle 是:-
71 ACTIVE javax.servlet_3.0.0.v201103241009
73 ACTIVE javax.el_2.2.0.v201105051105
74 ACTIVE javax.servlet.jsp_2.2.0.v201103241009
75 ACTIVE com.springsource.javax.servlet.jsp.jstl_1.2.0.v20110728
121 ACTIVE com.springsource.org.apache.taglibs.standard_1.1.2.v20110517
有更多的 bundle ,但那些是相关的。所以,我不明白哪里出了问题。
来自Spring Source Repository ,从我下载包的地方,很明显,org.apache.taglibs.standard bundle - Bundle 121,包含 JSTLCoreTLV 类
。
所以,不确定这里发生了什么。
这是我正在使用的 JSP
header (以防万一,它是相关的):-
<%@ taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
我正在使用:-
Servlet 3.0
JSP 2.2
双子座运行时 2.1
JSTL 1.2.0
更新:-
下面描述的问题似乎已经解决,现在我没有收到如下所示的任何警告。那是因为,我有 taglibs.standard_1.1.2
- (Bundle 121),它与其他人不兼容。所以,我删除了它,警告消失了。
因此,从这里开始您可以忽略任何内容。但是,上面的问题仍然存在。我仍然收到 JasperException
。这可能会进一步提供帮助,因为由于@BalusC 提供的宝贵意见,问题域现在有所减少。
解决后的部分。所以,你可以忽略它:-
此外,我不确定我拥有的 OSGi JSTL 包版本 - Bundle 75
是否与其他包 - javax.el
兼容, taglibs
、servlets
等,或不。因为我使用的是 JSTL 1.2.1
,但我无法获得 JSTL 1.2.1
的包。我得到的是我使用的包 (JSTL 1.2.0
)。为什么这会困扰我是因为当我启动我的应用程序时会出现这些类型的消息:-
Jan 22, 2013 7:14:05 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://java.sun.com/jstl/core is already defined
Jan 22, 2013 7:14:05 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://java.sun.com/jsp/jstl/core is already defined
Jan 22, 2013 7:14:05 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://java.sun.com/jstl/fmt_rt is already defined
Jan 22, 2013 7:14:05 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://java.sun.com/jstl/fmt is already defined
Jan 22, 2013 7:14:05 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://java.sun.com/jsp/jstl/fmt is already defined
Jan 22, 2013 7:14:05 PM org.apache.catalina.startup.TaglibUriRule body
INFO: TLD skipped. URI: http://java.sun.com/jsp/jstl/functions is already defined
如您所见,上面显示了两个不同的 URL:-
- URI:
http://java.sun.com/jSTL/core
- URI:
http://java.sun.com/jsp/jSTL/core
现在,AFAIK 这两个 URL 不属于相同的 JSTL
版本。
那么,这会引发一些问题吗?他们来的原因是什么?我刚刚使用了一个 JSTL bundle
。
最佳答案
com.springsource.javax.servlet.jsp.jstl_1.2.0.v20110728
com.springsource.org.apache.taglibs.standard_1.1.2.v20110517
您正在将 JSTL 1.2.0 API+impl 与 JSTL 1.1.2 impl 混合。
这两个 impls 相互冲突,这解释了你所看到的所有问题。
摆脱 1.1.2 实现。
另见:
关于java - 无法加载或实例化 TagLibraryValidator 类 : org. apache.taglibs.standard.tlv.JSTLCoreTLV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14459873/