質問

さて、このサイトに参加して以来、初めて StackOverflowError に遭遇しました。これは必須の投稿だと思いました :-)。私の環境は Seam 2.0.1.GA、JBoss 4.2.2.GA で、JSF を使用しています。既存のサイトで使用されている既存の JSP タグを利用するために、facelets ビューから JSP に変換しているところです。faces-config.xml 構成ファイルと web.xml 構成ファイルを変更したところ、JSP ページをレンダリングしようとすると次のエラーが発生するようになりました。何か考えのある人はいますか?

2008-09-17 09:45:17,537 Debug [org.jboss.seam.contexts.faceslifecycle] for /form_home.jsp 2008-09-17 09:45:17,587エラー[org.apache.catalina.coreのJSF要求を開始します。 containerbase。 ApplicationHttpRequest.java:210) at org.apache.catalina.core.ApplicationHttpRequest.getAttribute(ApplicationHttpRequest.java:222) at org.apache.catalina.core.ApplicationHttpRequest.getAttribute(ApplicationHttpRequest.java:222) at org.apache.catalina .core.applicationhttprequest.getattribute(applicationhttprequest.java:222)...

私のfaces-config.xmlファイルは空になり、FaceletsViewHandlerがなくなりました。

<?xml version="1.0" encoding="UTF-8"?>
<faces-config version="1.2" xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xi="http://www.w3.org/2001/XInclude"
 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">

</faces-config>

そして私の Web.xml ファイル:

<?xml version="1.0"?>
<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">
 <!-- Ajax4jsf -->
 <context-param>
  <param-name>org.richfaces.SKIN</param-name>
  <param-value>blueSky</param-value>
 </context-param>
  <!-- Seam -->
 <listener>
  <listener-class>org.jboss.seam.servlet.SeamListener</listener-class>
 </listener>


 <filter>
  <filter-name>Seam Filter</filter-name>
  <filter-class>org.jboss.seam.servlet.SeamFilter</filter-class>
 </filter>

 <filter-mapping>
  <filter-name>Seam Filter</filter-name>
  <url-pattern>*.jsp</url-pattern>
 </filter-mapping>

 <servlet>
    <servlet-name>Seam Resource Servlet</servlet-name>
     <servlet-class>org.jboss.seam.servlet.SeamResourceServlet
     </servlet-class>
 </servlet>
 <servlet-mapping>
   <servlet-name>Seam Resource Servlet</servlet-name>
   <url-pattern>/seam/resource/*</url-pattern>
 </servlet-mapping>
 <!-- Seam end --> 

 <!-- JSF -->
 <context-param>
        <param-name>javax.faces.DEFAULT_SUFFIX</param-name>
        <param-value>.jsp</param-value>
 </context-param>

 <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>*.jsp</url-pattern> 
 </servlet-mapping>
役に立ちましたか?

解決

この問題を理解することができました。どうやら、Javax.faces.DEFAULT_SUFFIX の .jsp の param-value を Faces Servlet URL-pattern (*.jsp) と同じにするように web.xml を構成することはできません。URL パターンを次のように変更すると、 .jspx または /whateverdirnameyouwant/ へ アプリケーションはスタック オーバーフロー エラーなしで起動します。(注記:重要なのは、DEFAULT_SUFFIX と Faces サーブレットの URL パターンは、それらが何であるかに関係なく、同じにすることはできないということです。) この特定の問題を経験している他の人の助けになれば幸いです。

他のヒント

Java でのスタック オーバーフローは、ほとんどの場合、無限再帰またはメソッド呼び出しによって発生します。あなたの場合、スタックトレースを考慮すると、「getAttribute()」がクラッシュするまで繰り返し呼び出されているようです。あなたが使用している特定の環境については詳しくありませんが、.jsp コードでこの種の動作 (たとえば、相互に呼び出す 2 つのメソッド) がないかどうかを確認することをお勧めします。

それで、私も同様のエラーを経験しました。私の場合は、JSF プロジェクトがあり、ファイル拡張子をいじっていたことが原因でした。まず、すべての Web ファイルに拡張子 .jsp が付いていました。これはうまくいきましたが、すべて .jsf にしたいと考え、その後は .xhtml を使用することにしました。その過程で、web.xml ファイルが xhtml と jsf に対応するように変更されました。web.xml ファイルを変更しても問題ありませんでした。StackOverflowError が発生したのは、header.jsf を指す ui.include タグを持つindex.xhtml があったためです。つまり、jsfファイルを指すxhtmlファイルがありました。web.xml でこれを処理できると思っていましたが、そうではなく、StackOverflowError が発生しました。したがって、これを修正するために、すべての JSF ファイルの拡張子が .xhtml になり、ネストされた ui:include タグが .xhtml ファイルを指すようになりました。

ただし、逆に言えば、ブラウザの URL は、index.jsp、index.jsf、index.xhtml を問題なく処理できます。そのため、web.xml (jsp、jsf、および xhtml のサーブレット マッピングを含む) はブラウザの URL を問題なく処理しますが、上記の問題で強調されたものについては処理されません。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top