使用JBoss设置JSF时出现StackOverflowError

时间:2013-03-17 00:03:14

标签: jsf jboss jboss5.x

我尝试使用JBoss(5.1)运行JSF,但我有两个问题。 我得到了face-config.xml中配置的FaceletViewHandler的类找不到异常,或者得到无限数量的StackOverflowError。

错误:

00:48:30,767 ERROR [[Faces Servlet]] Servlet.service() for servlet Faces Servlet threw exception
java.lang.StackOverflowError
....
at org.apache.catalina.core.ApplicationHttpRequest.setAttribute(ApplicationHttpRequest.java:279)
...

我认为它与我的web.xml配置或我的faces-config.xml

有关

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 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_2_5.xsd">
    <display-name>test1</display-name>
    <context-param>
        <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
        <param-value>server</param-value>
    </context-param>
    <context-param>
        <param-name>javax.faces.DEFAULT_SUFFIX</param-name>
        <param-value>.xhtml</param-value>
    </context-param>
    <listener>
        <listener-class>com.sun.faces.config.ConfigureListener</listener-class>
    </listener>
    <session-config>
        <session-timeout>
            30
        </session-timeout>
    </session-config>
    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
    <servlet>
        <servlet-name>Faces Servlet</servlet-name>
        <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>Faces Servlet</servlet-name>
        <url-pattern>*.xhtml</url-pattern>
    </servlet-mapping>
</web-app>

我发现了一个'解决方案',它说url模式应该与默认后缀不同 - 它没有帮助

faces-config.xml:

<?xml version='1.0' encoding='UTF-8'?>
<faces-config version="1.2" 
    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-facesconfig_1_2.xsd">
  <application>
        <view-handler>com.sun.facelets.FaceletViewHandler</view-handler>
    </application>
</faces-config>
POM.XML中的

....
    <dependency>
      <groupId>com.sun.facelets</groupId>
      <artifactId>jsf-facelets</artifactId>
      <version>1.1.15</version>
    </dependency>
....

有什么问题?

问候D3

2 个答案:

答案 0 :(得分:1)

StackOverflowError告诉我们线程没有足够的内存可用于堆栈。也许你使用-Xss JVM选项(例如-Xss256k甚至更多)来增加一个线程可用的堆栈。

您应该在run.conf.bat或run.conf.sh中设置它,具体取决于您的操作系统。

您还可以尝试通过将javax.faces.STATE_SAVING_METHOD从“server”设置为“client”来保存服务器资源。

答案 1 :(得分:0)

我找到了解决方案 - 至少是一种解决方法。 我从JDK7改回JDK6,现在一切正常。

我认为需要再次设置项目并仔细检查所有包含的库的版本。