Erro ao gravar dados de uma página em JSF no banco

Boa noite galera,

Estou quebrando a cabeça com um erro que está havendo aqui quando eu clico no botão gravar nesse código.

<!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:f="http://java.sun.com/jsf/core"
      xmlns:h="http://java.sun.com/jsf/html">

	<f:view contentType="text/html" />

	<h:head>
		<title> Sistema de Notas Fiscais </title>
	</h:head>
	
	<h:body>
		<h:form>
			<h:outputLabel value="Nome:" for="nome"/>
			&lt;h:inputText id="nome" value="#{produtoBean.produto.nome}"/&gt; <br/>

			&lt;h:outputLabel value="Descrição:" for="descricao"/&gt;
			&lt;h:inputTextarea id="descricao" value="#{produtoBean.produto.descricao}"/&gt; <br/>

			&lt;h:outputLabel value="Preço:" for="preco"/&gt;
			&lt;h:inputText id="preco" value="#{produtoBean.produto.preco}"/&gt; <br/>

			&lt;h:commandButton value="Gravar" action="#{produtoBean.gravar}"/&gt; <br/>
		&lt;/h:form&gt;
	&lt;/h:body&gt;
&lt;/html&gt;

O erro que dá é o seguinte:
exception

javax.servlet.ServletException: viewId:/produto.xhtml - A exibição de /produto.xhtml não pôde ser restaurada.
javax.faces.webapp.FacesServlet.service(FacesServlet.java:325)

root cause

javax.faces.application.ViewExpiredException: viewId:/produto.xhtml - A exibição de /produto.xhtml não pôde ser restaurada.
com.sun.faces.lifecycle.RestoreViewPhase.execute(RestoreViewPhase.java:200)
com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:111)
com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
javax.faces.webapp.FacesServlet.service(FacesServlet.java:312)

Eu não entendi porque dessa excessão, porque estou gravando e ainda não tem nada fazendo que a sessão expire e tal…
Alguém pode ajudar?
Obrigado.

Guri.

Galera, adicionei um bloco lá no arquivo web.xml e tipo, resolveu, mas agora está dando outro erro.

Meu web.xml é esse: (adicionei da linha 13 a linha 16)

&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;
&lt;web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"&gt;
  &lt;display-name&gt;NotasFiscais&lt;/display-name&gt;
  &lt;welcome-file-list&gt;
    &lt;welcome-file&gt;index.html&lt;/welcome-file&gt;
    &lt;welcome-file&gt;index.htm&lt;/welcome-file&gt;
    &lt;welcome-file&gt;index.jsp&lt;/welcome-file&gt;
    &lt;welcome-file&gt;index.jspx&lt;/welcome-file&gt;
    &lt;welcome-file&gt;default.html&lt;/welcome-file&gt;
    &lt;welcome-file&gt;default.htm&lt;/welcome-file&gt;
    &lt;welcome-file&gt;default.jsp&lt;/welcome-file&gt;
  &lt;/welcome-file-list&gt;
  &lt;context-param&gt;
    &lt;param-name&gt;javax.faces.STATE_SAVING_METHOD&lt;/param-name&gt;
    &lt;param-value&gt;client&lt;/param-value&gt;
  &lt;/context-param&gt;
  &lt;servlet&gt;
  	&lt;servlet-name&gt;Faces Servlet&lt;/servlet-name&gt;
  	&lt;servlet-class&gt;javax.faces.webapp.FacesServlet&lt;/servlet-class&gt;
  	&lt;load-on-startup&gt;1&lt;/load-on-startup&gt;
  &lt;/servlet&gt;
  &lt;servlet-mapping&gt;
  	&lt;servlet-name&gt;Faces Servlet&lt;/servlet-name&gt;
  	&lt;url-pattern&gt;*.xhtml&lt;/url-pattern&gt;
  &lt;/servlet-mapping&gt;
&lt;/web-app&gt;

O erro é esse:

exception

java.io.IOException: Not in GZIP format
java.util.zip.GZIPInputStream.readHeader(Unknown Source)
java.util.zip.GZIPInputStream.<init>(Unknown Source)
java.util.zip.GZIPInputStream.<init>(Unknown Source)
com.sun.faces.renderkit.ClientSideStateHelper.doGetState(ClientSideStateHelper.java:231)
com.sun.faces.renderkit.ClientSideStateHelper.getState(ClientSideStateHelper.java:198)
com.sun.faces.renderkit.ResponseStateManagerImpl.getState(ResponseStateManagerImpl.java:100)
com.sun.faces.application.view.StateManagementStrategyImpl.restoreView(StateManagementStrategyImpl.java:232)
com.sun.faces.application.StateManagerImpl.restoreView(StateManagerImpl.java:181)
com.sun.faces.application.view.ViewHandlingStrategy.restoreView(ViewHandlingStrategy.java:123)
com.sun.faces.application.view.FaceletViewHandlingStrategy.restoreView(FaceletViewHandlingStrategy.java:448)
com.sun.faces.application.view.MultiViewHandler.restoreView(MultiViewHandler.java:148)
com.sun.faces.lifecycle.RestoreViewPhase.execute(RestoreViewPhase.java:187)
com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:111)
com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
javax.faces.webapp.FacesServlet.service(FacesServlet.java:312)

Eaí, alguém pode me ajudar?

Olá a todos.
Estou tendo o mesmo problema. Alguém sabe a solução?

Estou com o mesmo problema. Alguem ajuda por favor.

Olá,

Ao atualizar uma página que utiliza um ManagedBean @ViewScope algum tempo sem atividade tive o mesmo erro:

javax.faces.application.ViewExpiredException: viewId:/mypage.xhtml - A exibição de /mypage.xhtml não pôde ser restaurada.

Encontrei a mesma solução proposta neste post em: http://www.guj.com.br/java/85236-resolvidojsflimite-de-paginas-abertas-na-sessao-viewstate-deletado-#460553

Alterar o STATE_SAVING_METHOD para CLIENT e tive o mesmo erro: java.io.IOException: Not in GZIP format

Consegui resolver o problema e estou compartilhando com vocês…

O último erro ocorre pois o servidor de aplicação, no meu caso o Tomcat, não estava com a compressão ZGIP habilitada…

Acredito que isto ocorra pois a implementação do Faces, no meu caso o Mojarra 2.1, utiliza este tipo de compressão no modo STATE_SAVING_METHOD = CLIENT.

Enfim caso alguém também esteja utilizando o Tomcat basta alterar o server.xml como explicado em: http://www.servletworld.com/tomcat/enable-tomcat-gzip-compression.html

Atenciosamente,
Davi Garcia Pereira.