所以我在 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
但是,我已经检查过,我的运行时中已经拥有所有必要的包。我拥有的相关捆绑包是:-
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
有更多的捆绑包,但那些是相关的。所以,我不明白出了什么问题。
从我下载包的 Spring Source Repository 中,很明显 org.apache.taglibs.standard bundle - Bundle 121 包含 JstlCoreTLV class
。所以,不确定,这里发生了什么。
这是我正在使用的 JSP
标头(以防万一,它是相关的):-
<%@ taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
我在用着: -
Servlet 3.0
JSP 2.2
Gemini Runtime 2.1
JSTL 1.2.0
更新: -
下面描述的问题似乎已解决,现在我没有收到如下所示的任何警告。那是因为,我有 taglibs.standard_1.1.2
( Bundle 121 ),它与其他人不兼容。所以,我删除了它,警告消失了。
所以,你可以忽略从这里开始的任何内容。但是,上面的问题仍然存在。我仍然得到那个 JasperException
。这可能会进一步提供帮助,因为由于@BalusC 提供的宝贵意见,问题域现在有所减少。
解决后的部分。所以,你可以忽略它:-
另外,我不确定我拥有的 OSGi JSTL 包的版本 - Bundle 75
是否与其他包兼容 - javax.el
, taglibs
-bc709 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
。
原文由 Rohit Jain 发布,翻译遵循 CC BY-SA 4.0 许可协议
您将 JSTL 1.2.0 API+impl 与 JSTL 1.1.2 impl 混合使用。
这两个暗示相互冲突,这解释了你所看到的所有麻烦。
摆脱 1.1.2 impl。
也可以看看: