Бин CDI приводит к появлению javax.el.PropertyNotFoundException в glassfish 5 build 25 - PullRequest
0 голосов
/ 04 ноября 2018

Я использую Java 8, Glassfish 5 build 25, Eclipse. Я пытаюсь обновить Java EE 7 до Java EE 8. Поэтому я начал с этого простого примера.

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://xmlns.jcp.org/xml/ns/javaee"
    xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
    id="WebApp_ID" version="4.0">
    <display-name>Play ID</display-name>
    <context-param>
        <param-name>javax.faces.PROJECT_STAGE</param-name>
        <param-value>Development</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>*.xhtml</url-pattern>
    </servlet-mapping>
</web-app>

CDI Bean:

@Named
@ViewScoped
public class CommentFront implements Serializable {
    private static final long serialVersionUID = 1L;

    public void addComment() {
        System.out.println("I don’t work: ");   
    } 
}

Простая страница JSF comment.xhtml

<!DOCTYPE html >
<html lang="en" 
    xmlns="http://www.w3.org/1999/xhtml" 
    xmlns:h="http://xmlns.jcp.org/jsf/html"
    xmlns:c="http://xmlns.jcp.org/jsp/jstl/core"
    >
<h:head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no" />
    <title>Derbyware</title>

<h:body>
    <h:form id="form">
        <h:commandButton id="OneBtn" value="1 Comment" action="#{commentFront.addComment()}" >  
        </h:commandButton>

    </h:form>
</h:body>
</h:head>
</html>

Ошибка:

javax.el.PropertyNotFoundException: /comment.xhtml @17,89 action="#{commentFront.addComment()}": Target Unreachable, identifier 'commentFront' resolved to null

Когда я впервые запускаю Glassfish, он печатает:

    2018-10-31T14:26:57.985+0000|Info: WELD-000411: Observer method [BackedAnnotatedMethod] public org.glassfish.jms.injection.JMSCDIExtension.processAnnotatedType(@Observes ProcessAnnotatedType<T>) receives events for all annotated types. Consider restricting events using @WithAnnotations or a generic type with bounds.

    2018-10-31T14:26:58.032+0000|WARN: WELD-000146: BeforeBeanDiscovery.addAnnotatedType(AnnotatedType<?>) used for class org.glassfish.cdi.transaction.TransactionalInterceptorMandatory is deprecated from CDI 1.1!
    ...
    2018-10-31T14:26:58.048+0000|WARN: WELD-000146: BeforeBeanDiscovery.addAnnotatedType(AnnotatedType<?>) used for class org.glassfish.jersey.ext.cdi1x.transaction.internal.TransactionalExceptionMapper is deprecated from CDI 1.1!
    2018-10-31T14:26:58.282+0000|Info: Initializing Soteria 1.0 for context '/Play_ID'
    2018-10-31T14:26:58.282+0000|Info: Initializing Mojarra 2.3.2 ( 20170627-2139 e63598abf2ed2bb1a24674f308a734e0dce18a72) for context '/Play_ID'
    2018-10-31T14:26:58.829+0000|Info: Loading application [Play_ID] at [/Play_ID]
    2018-10-31T14:26:58.938+0000|Info: Play_ID was successfully deployed in 1,932 milliseconds.

Почему что-то столь простое, как это, не работает на Glassfish 5 ????

1 Ответ

0 голосов
/ 07 ноября 2018

Решение 1:

Я использовал это из ответа на Изменение Face-config.xml с 2.2 на 2.3 вызывает javax.el.PropertyNotFoundException: Target Unreachable, идентификатор 'bean' разрешен в null

import javax.enterprise.context.ApplicationScoped;
import javax.faces.annotation.FacesConfig;

@ApplicationScoped
@FacesConfig(version = FacesConfig.Version.JSF_2_3)
public class JSFActivator {

}

теперь все работает как надо.

Решение 2:

переключиться на Payara 5.183, работает из коробки. Нет необходимости в решении 1

Мнение : Почему, черт возьми, стеклянная рыба сломана. жалко, что сервер приложений эталонной реализации для Java EE 8 не справляется с такой простой работой. Я надеюсь, что эта возможность теперь, когда она перешла домой от Оракула до Затмения.

Я думаю, что переключусь на Payara, пока стеклянная рыба не будет исправлена.

...