所以我在 Gemini 运行时下的 OSGi 中使用 JSTL。当我尝试访问我的网址时,出现以下异常servlet
: -
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 源代码库,从我下载捆绑包的地方,很明显,org.apache.taglibs.standard捆 -捆绑 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
- (捆绑 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
现在,据我所知,这两个 URL 不属于同一个JSTL
版本。
那么,这会带来一些问题吗?他们来的原因是什么?我刚刚用过一个JSTL bundle
.