2

私のWebアプリケーションで、ログインリンクをクリックすると、TomcatWebサーバーは次の例外をスローします。

exception
javax.servlet.ServletException: /aluno_jsf.xhtml: Property 'logout' not found on type
br.com.aluno.controller.LoginMB

javax.faces.webapp.FacesServlet.service(FacesServlet.java:422)

root cause
javax.el.ELException: /aluno_jsf.xhtml: Property 'logout' not found on type
br.com.aluno.controller.LoginMB
[...]

これが私の@ManagedBeanです:

package br.com.aluno.controller;

import java.io.Serializable;
import java.util.Collection;
import javax.annotation.PostConstruct;
import javax.faces.bean.ManagedBean;
import javax.faces.context.FacesContext;
import javax.servlet.http.HttpSession;
import br.com.aluno.dao.DaoFactory;
import br.com.aluno.entity.Usuario;
import br.com.aluno.util.JsfUtil;

@ManagedBean
public class LoginMB implements Serializable {
private static final long serialVersionUID = 6667329439219329074L;

private Usuario usuario;

@PostConstruct
public void init() {
    usuario = new Usuario();
}

public void logar() {
    try {
        Collection<Usuario> usuarios = DaoFactory
                .getDAOFactory(DaoFactory.JPA).getUsuarioDao()
                .validarLogin(usuario);
        if (usuarios != null && usuarios.size() == 1) {

            usuario = usuarios.iterator().next();

            HttpSession session = (HttpSession) FacesContext
                    .getCurrentInstance().getExternalContext()
                    .getSession(true);
            if (session != null) {
                session.setAttribute("usuario", usuario);
                session.setAttribute("usuarioTipo", usuario.getClass()
                        .getName());
            }
        } else {
            JsfUtil.addErrorMessage("Login ou senha invalida",
                    "Login ou senha invalida");
        }
    } catch (Exception e) {
        JsfUtil.addFatalMessage("Entre em contato com o administrador",
                e.getMessage());
    }
}

public String logout() {
    HttpSession session = (HttpSession) FacesContext.getCurrentInstance()
            .getExternalContext().getSession(false);
    if (session != null) {
        session.invalidate();
    }
    return "/login?faces-redirect=true";
}

public Usuario getUsuario() {
    return usuario;
}

public void setUsuario(Usuario usuario) {
    this.usuario = usuario;
}
}

次のlogin.xhtmlにリダイレクトするindex.htmlにリンクがあります。

<ui:decorate 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" template="/aluno_jsf.xhtml">

<ui:define name="conteudo">
    <h:form rendered="#{sessionScope.usuario == null}">
        <h3>Login</h3>
        <p:messages id="messages" showDetail="true" autoUpdate="true" />
        <h:panelGrid columns="2">
            <p:outputLabel for="login" value="Login:" />
            <p:inputText id="login" value="#{loginMB.usuario.login}" required="true" 
requiredMessage="Digite um login" />
            <p:outputLabel for="senha" value="Senha:" />
            <p:password id="senha" value="#{loginMB.usuario.senha}" required="true" 
requiredMessage="Digite uma senha" />
            <p:commandButton action="#{loginMB.logar}" value="Logar" ajax="false" />
        </h:panelGrid>
    </h:form>
</ui:define>

検証後、次のページをレンダリングする必要があります。

<!DOCTYPE html>
<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" >
<h:head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
<title>aluno_jsf</title>
</h:head>
<h:body>
<f:view>
    <h:form>
        <p:menubar
            rendered="#{sessionScope.usuarioTipo == 'br.com.aluno.entity.Administrador'}">
            <p:menuitem url="/administrador/cadastroCurso.xhtml"
value="Cadastro de curso" />
            <p:menuitem url="/administrador/cadastroDisciplina.xhtml" 
value="Cadastro de disciplinas" />
            <p:menuitem url="/administrador/cadastroAluno.xhtml" 
value="Cadastro de alunos" />
            <p:menuitem url="/administrador/atribuiNota.xhtml" 
value="Atribuicao de notas para alunos" />
            <p:menuitem action="#{loginMB.logout}" value="Logout" />
        </p:menubar>
        <p:menubar
rendered="#{sessionScope.usuarioTipo == 'br.com.aluno.entity.Aluno'}">
            <p:menuitem url="/aluno/nota.xhtml" value="Consulta de notas" />
            <p:menuitem url="/aluno/senha.xhtml" value="Alteracao de senha" />
            <p:menuitem action="#{loginMB.logout}" value="Logout" />
        </p:menubar>
    </h:form>
    <ui:insert name="conteudo">
    conteudo
    </ui:insert>
</f:view>
</h:body>
</html>

私はこのWebアプリを適応させているので(そして以前にいくつかの設定ミスがありました)、誰かが今何が起こっているのか知っていますか?

前もって感謝します。

あなたが尋ねたように、彼女は新しい例外です:

message Could not initialize class br.com.fiap.aluno.util.JpaUtil

description The server encountered an internal error (Could not initialize class     br.com.fiap.aluno.util.JpaUtil) that prevented it from fulfilling this request.

exception

javax.servlet.ServletException: Could not initialize class br.com.fiap.aluno.util.JpaUtil
javax.faces.webapp.FacesServlet.service(FacesServlet.java:422)

root cause

java.lang.NoClassDefFoundError: Could not initialize class br.com.fiap.aluno.util.JpaUtil
br.com.fiap.aluno.dao_jpa.JpaUsuarioDao.validarLogin(JpaUsuarioDao.java:46)
br.com.fiap.aluno.controller.LoginMB.logar(LoginMB.java:30)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:601)
javax.el.BeanELResolver.invoke(BeanELResolver.java:484)
javax.el.CompositeELResolver.invoke(CompositeELResolver.java:161)
org.apache.el.parser.AstValue.getValue(AstValue.java:159)
org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:189)
com.sun.faces.facelets.el.ELText$ELTextVariable.toString(ELText.java:214)
com.sun.faces.facelets.compiler.AttributeInstruction.write(AttributeInstruction.java:89)
com.sun.faces.facelets.compiler.UIInstructions.encodeBegin(UIInstructions.java:82)
    com.sun.faces.renderkit.html_basic.HtmlBasicRenderer.encodeRecursive(HtmlBasicRenderer.java:302)
com.sun.faces.renderkit.html_basic.GridRenderer.renderRow(GridRenderer.java:185)
com.sun.faces.renderkit.html_basic.GridRenderer.encodeChildren(GridRenderer.java:129)
javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:845)
javax.faces.component.UIComponent.encodeAll(UIComponent.java:1756)
javax.faces.render.Renderer.encodeChildren(Renderer.java:168)
javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:845)
javax.faces.component.UIComponent.encodeAll(UIComponent.java:1756)
javax.faces.component.UIComponent.encodeAll(UIComponent.java:1759)
javax.faces.component.UIComponent.encodeAll(UIComponent.java:1759)
  com.sun.faces.application.view.FaceletViewHandlingStrategy.renderView(FaceletViewHandlingStrategy.java:401)
com.sun.faces.application.view.MultiViewHandler.renderView(MultiViewHandler.java:131)
com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:121)
com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139)
javax.faces.webapp.FacesServlet.service(FacesServlet.java:410)

note The full stack trace of the root cause is available in the Apache Tomcat/7.0.29 logs.

修正を試みますが、ヒントをいただければ幸いです。

4

4 に答える 4

9

javax.el.E​​LException:/aluno_jsf.xhtml:プロパティ'logout'がタイプbr.com.aluno.controller.LoginMBに見つかりません

これは、がではなく#{loginMB.logout}として評価されていることを示しています。ValueExpressionMethodExpression

これは、たとえば、を使用している場合や、XML名前空間宣言が欠落しているか正しくないため、またはランタイムクラスパスに含まれていないコンポーネントを含むJARファイルが原因で、背後の名前空間を解決できない<h:outputText value="#{loginMB.logout}" />場合でも発生する可能性があります。x<x:someComponent action="#{loginMB.logout}" />

これまでに投稿されたコードでは原因はわかりませんが、Faceletsを適切にテンプレート化していないと推測されます。このコードは、の奇妙なユースケースを示しています<ui:decorate>。テンプレート構成を適切に使用する方法を学ぶために、この回答に進んでください:JSF 2.0 Faceletsを使用してXHTMLに別のXHTMLを含める方法は?

于 2012-07-26T17:59:07.120 に答える
3

ログアウトはプロパティアクセサーではなく、メソッドです。

これを試してください:代わりに#{loginMB.logout()}

于 2012-07-26T17:52:18.983 に答える
1

同じ問題が発生しましたが、xhtmlファイルに追加したコメントを削除して解決しました

このページにある解決策

于 2014-03-25T15:56:20.183 に答える
1

javax.el.ELExceptionxhtmlでELメソッドのリファレンスを入手する理由をいくつか紹介したいと思います。これは参考事項と考えてください。おそらく他の人が貢献し続けるでしょう。

JavaEEバージョンの不一致

  • AppServerで実行されているJavaEEバージョン。これはAppServerのドキュメントの一部である必要があります。または、カスタマイズした場合(tomcatの上に独自のドキュメントを作成するなど)、知っておく必要があります。
  • xmlns使用されているタグライブラリ。タグで使用されているもので識別できます<html>

たとえば、Java EE 6を使用している場合、これは間違っています。

<html 
  xmlns="http://www.w3.org/1999/xhtml"
  xmlns:h="http://xmlns.jcp.org/jsf/html">

そして代わりにすべきです

<html 
  xmlns="http://www.w3.org/1999/xhtml"
  xmlns:h="http://java.sun.com/jsf/html">

jcpの代わりにsun.comを使用していることに注意してください。JavaEE7以降ではjcpを使用する必要があります。

<persistence>persistence.xmlと<beans>beans.xmlにも同様の問題が存在することに注意してください。

MethodExpressionをサポートしないタグ属性

使用している正確なバージョンについては、タグライブラリのドキュメントを調べてください。いくつかの可能性があります。

  1. タグ属性は仕様に含まれていません。これは、タグライブラリの新しいバージョンでのみ追加されたことが原因である可能性があります。その場合、コードはそれが通常のプロパティであると想定し、レンダリングフェーズ中に通常のプロパティとして評価されます(ゲッターを探します)。これは、JavaEEバージョンの不一致の場合の失敗の背後にある理由でもあります。
  2. タグ属性は文書化されていますが、「評価する必要javax.el.MethodExpressionがある」とは指定されていません。その場合、提供されたプロパティが異なるタイプであると想定し、そのように評価しようとします。メソッドが提供されている場合、それは()構文を使用している必要があり、メソッドは期待されるタイプを取得するためにのみ実行されます。
  3. タグ属性は文書化されていますが、タイプとしては文書化されjavax.el.ValueExpressionていません。その場合、EL構文の式も受け入れず、評価はレンダリング中にのみ即座に行われます。

この特定の質問については、PrimeFaces3.4タグのドキュメントを参照できます。使用されている正確なバージョンが提供されていないのは残念です。

EL実装はメソッド参照をサポートしていません

この場合、()意志のないメソッド参照はデフォルトで通常のプロパティとして解釈され、ゲッター/セッターにアクセスしようとします。

于 2014-11-15T22:55:48.943 に答える