[RESOLVIDO] JSF 2 - Managed Bean NULL com anotação @Model

Aloha galera, pois bem, estou fazendo um Projetinho de exemplo do EE6 e até então pretendo usar o mesmo de forma bem crua, sem adicionar muitos Frameworks… No momento só adicionei o PrimeFaces pra auxiliar na view…

To usando NetBeans 6.9.1 + GlassFish 3.0.1 + MySql

O que ocorre é que em minha página estou chamando um Bean (que deveria ser meu Managed Bean) que está sendo setado com null quando mando cadastrar uma nova pessoa.

Segue o erro:

AVISO: /form.xhtml @12,68 value="#{pessoaWebBean.pessoa.nome}": Target Unreachable, identifier 'pessoaWebBean' resolved to null
javax.el.PropertyNotFoundException: /form.xhtml @12,68 value="#{pessoaWebBean.pessoa.nome}": Target Unreachable, identifier 'pessoaWebBean' resolved to null
        at com.sun.faces.facelets.el.TagValueExpression.getType(TagValueExpression.java:93)
        at com.sun.faces.renderkit.html_basic.HtmlBasicInputRenderer.getConvertedValue(HtmlBasicInputRenderer.java:95)
        at javax.faces.component.UIInput.getConvertedValue(UIInput.java:1008)
        at javax.faces.component.UIInput.validate(UIInput.java:934)
        at javax.faces.component.UIInput.executeValidate(UIInput.java:1189)
        at javax.faces.component.UIInput.processValidators(UIInput.java:691)
        at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1080)
        at javax.faces.component.UIForm.processValidators(UIForm.java:243)
        at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1080)
        at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1080)
        at javax.faces.component.UIViewRoot.processValidators(UIViewRoot.java:1180)
        at com.sun.faces.lifecycle.ProcessValidationsPhase.execute(ProcessValidationsPhase.java:76)
        at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
        at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
        at javax.faces.webapp.FacesServlet.service(FacesServlet.java:312)
        at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1523)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:279)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:188)
        at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:641)
        at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:97)
        at com.sun.enterprise.web.PESessionLockingStandardPipeline.invoke(PESessionLockingStandardPipeline.java:85)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:185)
        at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:325)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:226)
        at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:165)
        at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:791)
        at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:693)
        at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:954)
        at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:170)
        at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:135)
        at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:102)
        at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:88)
        at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:76)
        at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:53)
        at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:57)
        at com.sun.grizzly.ContextTask.run(ContextTask.java:69)
        at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:330)
        at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:309)
        at java.lang.Thread.run(Thread.java:662)

Aqui está o form.xhtml:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:p="http://primefaces.prime.com.tr/ui"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      template="/templates/principal.xhtml">
    
    <ui:define name="corpo">
        <h:form id="frmCadastro">
            <h:panelGrid columns="2">
                <h:outputText value="Nome: "/>
                <h:inputText value="#{pessoaWebBean.pessoa.nome}"/>
                <h:commandButton value="Inserir" action="#{pessoaWebBean.novo}"/>
            </h:panelGrid>
        </h:form>
    </ui:define>
</ui:composition>

e o PessoaWebBean.java

package br.com.mirititecnologia.web.controle;

import br.com.mirititecnologia.ejb.business.PessoaBusiness;
import br.com.mirititecnologia.ejb.entidades.Pessoa;
import java.util.List;
import javax.ejb.EJB;
import javax.enterprise.inject.Model;

@Model
public class PessoaWebBean {

    @EJB
    private PessoaBusiness pessoaBusiness;
    
    private Pessoa pessoa = new Pessoa();

    public Pessoa getPessoa() {
        return pessoa;
    }

    public List<Pessoa> getListagem() {
        return pessoaBusiness.getListagem();
    }

    public void atualizarListagem() {
        pessoaBusiness.atualizarListagem();
    }

    public String novo() {
        pessoaBusiness.salvar(pessoa, true);
        return "/lista.xhtml";
    }

    public String cadastrar(){
        return "/form.xhtml";
    }
}

O erro ocorre quando clico no botão [Inserir] do form… pois bem, procurando o erro pela WEB, percebi que a maioria das pessoas se batiam com esse erro porque erravam a definição do mesmo com o nome do Bean declarado no faces-config… e aí, alguém passou por isso no EE6, já que não precisamos mais do faces-config e o Container trata de injetar a dependência pra nós ???

Fiquei realmente confuso e estou empacado nesse erro.

Lugares onde procurei:

http://blog.gilliard.eti.br/2009/02/exemplo-com-jsf-2/ - aqui passou perto, mas realmente não creio que seja o Container, tendo em vista que é o GlassFish mais novo…

abs []

Olá, li muito pouco sobre java ee6, mas vou tentar te ajudar. Pelo erro o EL resolver do jsf nao encontrou seu bean pessoaWebBean . Tem certeza que nao esqueceu de colocar o arquivo beans.xml no diretorio WEB-INF(se for aplicacao web) ou no META-INF(se for jar) mesmo com o arquivo vazio, o cdi procura por ele para ver se vai colocar os beans do seu modulo no contexto de injecao. Para testar se erro eh a nomeacao coloque na anotacao @Model(“pessoaWebBean”) e ve se funciona.

Cara… era isso mesmo… Muito obrigado… pequenino detalhe que me passou batido…