1

我有一个从 Eclipse Ganymede 通过 Tomcat 6 部署的 JSF 应用程序。后者建议使用 JSP 2.0。我正在使用 Sun RI JSF 实现和 RichFaces 3.3.2SR1。

我的 index.jsp 文件应浏览器的请求导致控制台出现此错误:

05-Mar-2010 12:04:41 org.apache.catalina.core.ApplicationDispatcher invoke SEVERE: Servlet.service() for servlet jsp threw exception org.apache.jasper.JasperException: /index.jsp(35,41) #{..} is not allowed in template text ...

好的,我已经看到了关于这个主题的各种其他帖子,包括各种 jars/taglibs/syntaxes 版本的不兼容等。

index.jsp 调用使用http://localhost:8989/myapp/index.jsf (或 .jsp - 给出相同的错误),并包含

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:a4j="http://richfaces.org/a4j"
    xmlns:rich="http://richfaces.org/rich">

这应该没问题,因为 facelets 在我正在使用的 Mojarra 2.0.2FCS 中。我似乎必须使用上述语法而不是例如。<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f"%>正如 facelets URI 导致 Eclipse 说的那样Cannot find the tag library descriptor for "http://java.sun.com/jsf/facelets"

我的问题与我列出这些标签的方式有关吗?

我的 Ant 构建文件引用了这些 Tomcat jar:

    <fileset dir="${cliTomcatlib}">
        <include name="servlet-api.jar" />
        <include name="jsp-api.jar" />
    </fileset>

所以我很难过如何解决这个错误。感觉这将是一个简单的修复,但是当我使用应该与 JSP 2.0 兼容的最新 jar 时,我想知道为什么会出现这个错误。JSF

编辑 响应 BalusC 的智慧,我更正了对外部 jsp 文件的两个引用,并将 all 重命名.jsp.xhtml. 我记得也更新了我的faces-config.xml.

index.xhtml当这样请求时,现在重新部署错误并出现大且重复的错误:

05-Mar-2010 13:29:26 org.apache.catalina.core.ApplicationDispatcher invoke
SEVERE: Servlet.service() for servlet Faces Servlet threw exception
java.lang.StackOverflowError
    at org.apache.catalina.connector.RequestFacade.getSession(RequestFacade.java:824)
    at javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:216)
    at org.apache.catalina.core.ApplicationHttpRequest.getSession(ApplicationHttpRequest.java:544)
...
    at javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:216)
    at org.apache.catalina.core.ApplicationHttpRequest.getSession(ApplicationHttpRequest.java:544)
    at com.sun.faces.context.ExternalContextImpl.getSession(ExternalContextImpl.java:151)
    at javax.faces.application.ViewHandler.calculateCharacterEncoding(ViewHandler.java:242)
    at javax.faces.application.ViewHandler.initView(ViewHandler.java:458)
    at com.sun.faces.application.view.MultiViewHandler.initView(MultiViewHandler.java:106)
    at org.ajax4jsf.application.ViewHandlerWrapper.initView(ViewHandlerWrapper.java:128)
    at com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:109)
    at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:312)

我承认这不是很有启发性,除了堆栈跟踪的前几行重复了很多次,我不得不更改 Eclipse 上的控制台缓冲区。如果有人以前看过这个,我会感激不尽。

标记

4

2 回答 2

6
org.apache.jasper.JasperException: /index.jsp(35,41) #{..} is not allowed in template text 

JSP的模板文本中确实不允许统一EL。它只允许在 Facelets 中使用。

index.jsp 使用http://localhost:8989/myapp/index.jsf调用 (或 .jsp - 给出相同的错误)并包含

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
     xmlns:ui="http://java.sun.com/jsf/facelets"

您将 JSP 与 Facelets 混为一谈。你可以也不应该那样做。这是两种不同的视图技术。使用其中之一。JSP 用于这些<%@taglib %>东西,而 Facelets 是面向 XHTML<html xmlns><ui:xxx>。对于 JSF 2.0,您应该使用 Facelets。将所有文件重命名为*.jspto*.xhtml并替换并删除任何<% %>东西<jsp:xxx>

要了解有关 Facelets 的更多信息,请从Java EE 6 教程第二部分第 5 章开始。如果您想在 JSF 2.0 中退回到古老的 JSP 而不是 Facelets,那么您需要在 JSF 中重新配置视图处理程序。

除了这个问题,顺便说一下,Tomcat 6.0 是 JSP 2.1,而不是 JSP 2.0。

更新:StackOverflowError on表示 servlet/filter 映射中的getSession()无限递归。你的FacesServlet映射是怎样的?它应该被映射到监听一个url-patternof *.jsf,而不是*.xhtml。否则它将递归调用自身。请仔细查阅/参考 JSF 2.0书籍/教程/文档如何正确配置它。

于 2010-03-05T13:05:26.520 回答
0

将 JSF impl jar 添加到 Tomcat 的库或您的应用程序库中,然后重试。
有关更多信息,请参阅

于 2010-03-05T13:00:15.113 回答