0

Jetty サーバーで JSF アプリケーションを実行していたとき、問題なく動作していました。

しかし、これをWeblogicサーバーに移動すると、このエラーが発生し始めました。

javax.faces.application.ViewExpiredException: /wsListing.xhtmlNo saved view state could be found for the view identifier: /wsListing.xhtml
at org.apache.myfaces.lifecycle.RestoreViewExecutor.execute(RestoreViewExecutor.java:132)
at org.apache.myfaces.lifecycle.LifecycleImpl.executePhase(LifecycleImpl.java:170)
at org.apache.myfaces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:117)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:197)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:226)
at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:124)
at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:283)
at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
at weblogic.servlet.internal.RequestEventsFilter.doFilter(RequestEventsFilter.java:26)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3402)
at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
at weblogic.security.service.SecurityManager.runAs(Unknown Source)
at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2140)
at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2046)
at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1398)
at weblogic.work.ExecuteThread.execute(ExecuteThread.java:200)
at weblogic.work.ExecuteThread.run(ExecuteThread.java:172)

wsListing.xhtml を以下に示します。

  <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:p="http://primefaces.org/ui" xmlns:lang="en">

<f:view xmlns:c="http://java.sun.com/jstl/core"
    xmlns:s="http://www.springframework.org/tags"
    xmlns:form="http://www.springframework.org/tags/form">
    <h:head>
        <h:outputStylesheet library="css" name="../resources/css/style.css"
            target="head" />
        <meta http-equiv="content-type" content="text/html; charset=utf-8" />
        <title>Test Client</title>
        <link rel="shortcut icon" href="../resources/images/favicon.ico" />
        <link rel="stylesheet" href="../resources/css/style.css"
            type="text/css" media="all" />
    </h:head>
    <h:body>
        <ui:include src="header.xhtml" />
        <div id="home-training-container">
            <h:form>
                <table align="center" border="1">
                    <tr>
                        <td><h:commandLink value="First Web Service"
                                action="#{wsListingBean.action}">
                                <f:setPropertyActionListener
                                    target="#{wsListingBean.webServiceId}" value="abcService" />
                            </h:commandLink></td>
                    </tr>
                    <tr>
                        <td><h:commandLink value="Second Web Service"
                                action="#{wsListingBean.action}">
                                <f:setPropertyActionListener
                                    target="#{wsListingBean.webServiceId}" value="filterabc" />
                            </h:commandLink></td>
                    </tr>
                    <tr>
                        <td>Third Web Service</td>
                    </tr>
                    <tr>
                        <td>Fourth Web Service</td>
                    </tr>
                    <tr>
                        <td>Fifth Web Service</td>
                    </tr>
                </table>
            </h:form>
        </div>
        <ui:include src="footer.xhtml" />
    </h:body>
</f:view>
</html>

コマンド リンクのいずれかをクリックすると、次の問題が発生します。

<h:commandLink value="First Web Service"
                                    action="#{wsListingBean.action}">
                                    <f:setPropertyActionListener
                                        target="#{wsListingBean.webServiceId}" value="abcService" />

このビューステートが何であるかについて何か知っている人はいますか?

4

2 に答える 2

1

エラーを修正するために、 web.xmlに次の行を追加しました。

    <context-param>
    <!--description>
        The location where state information is saved. Valid values
        are 'server' (typically saved in HttpSession) and 'client'
        (typically saved as a hidden field in the form. Default is
        server.
        </description-->
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
    <param-value>server</param-value>
</context-param>
<context-param>
    <!--description>
        Number of Views to be stored in the session when Server-Side
        State Saving is being used. Default is 20.
        </description-->
    <param-name>
        org.apache.myfaces.NUMBER_OF_VIEWS_IN_SESSION
    </param-name>
    <param-value>20</param-value>
</context-param>    
于 2013-01-15T14:09:36.643 に答える
1

web.xml の PROJECT_STAGE を Development に設定していますか? もしそうなら、本番環境に切り替えて、問題が解決するかどうかを確認できますか? 同じではないにしても、WebLogic で同様のエラー メッセージが表示され、変更によって修正されたと思います。

于 2012-05-15T20:17:32.993 に答える