Не удалось загрузить ViewHandler (InstantiationException), используя Тринидад 2 с Facelets

ОК, у меня нет идей. Я пытаюсь запустить Trinidad 2.1.0 на Glassfish 4 с использованием Facelets, но сначала получаю следующее исключение:

WARNING:   Could not load ViewHandler javax.faces.application.ViewHandler
WARNING:   java.lang.InstantiationException
    at sun.reflect.InstantiationExceptionConstructorAccessorImpl.newInstance(InstantiationExceptionConstructorAccessorImpl.java:48)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:526)
    at java.lang.Class.newInstance(Class.java:374)
    at org.apache.myfaces.trinidadinternal.application.ViewHandlerImpl._initIfNeeded(ViewHandlerImpl.java:311)
    at org.apache.myfaces.trinidadinternal.application.ViewHandlerImpl.createView(ViewHandlerImpl.java:83)

С последующим:

SEVERE:   Error when processing tag for component with id: "". The scoped id of the parent component is ":j_id_id5".
java.lang.NullPointerException
    at org.jboss.weld.el.ELCreationalContextStack.getCreationalContextStore(ELCreationalContextStack.java:33)
    at org.jboss.weld.el.WeldValueExpression.getValue(WeldValueExpression.java:47)
    at org.apache.myfaces.trinidad.webapp.UIXComponentELTag.setProperty(UIXComponentELTag.java:297)
    at org.apache.myfaces.trinidadinternal.taglib.html.HtmlScriptTag.setProperties(HtmlScriptTag.java:81)
    at org.apache.myfaces.trinidad.webapp.UIXComponentELTag.setProperties(UIXComponentELTag.java:284)

Я сейчас пользуюсь com.sun.faces, jsf-impl, 2.2.4, Я тоже пробовал org.apache.myfaces.core, myfaces-impl, 2.1.13, но это дало мне более или менее ту же ошибку.

Я поставил <class-loader delegate="true" /> в моем glassfish-web.xml, Я вижу различия в ошибках при переключении реализаций JSF, поэтому я уверен, что не использую реализацию JSF в комплекте с Glassfish.

Переключение обработчика вида в web.xml в org.apache.myfaces.trinidadinternal.facelets.TrinidadFaceletViewHandler тоже не сработало.

Я сократил свой документ до:

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
                xmlns:ui="http://java.sun.com/jsf/facelets"
                xmlns:f="http://java.sun.com/jsf/core"
                xmlns:tr="http://myfaces.apache.org/trinidad"
>
  <f:view>
    <tr:document>
      <tr:outputText value="Hello"/>
    </tr:document>
  </f:view>
</ui:composition>

Но я все еще получаю упомянутые ошибки.

Я начал с проекта, использующего Trinidad 1.2.14 с использованием JSF 1.2 и Facelets 1.1.14, который работал на том же сервере Glashfish. Я выполнил шаги в этой статье по миграции JSF для миграции JSF и Facelets.
Итак, моя зависимость Facelets 1.1.14 удалена, я обновил зависимости Trinidad и JSF и обновил web.xml а также faces-config.xml,

Кто-нибудь знает, что еще я мог проверить?


Обновить

Я исключил Glassfish. Я создал новый пустой проект, настроил Trinidad 2 и попытался запустить его на Tomcat 7 и получил то же исключение.

В моем новом проекте я использовал следующую конфигурацию:

зависимости

<dependency>
  <groupId>com.sun.faces</groupId>
  <artifactId>jsf-api</artifactId>
  <version>2.2.4</version>
</dependency>
<dependency>
  <groupId>com.sun.faces</groupId>
  <artifactId>jsf-impl</artifactId>
  <version>2.2.4</version>
</dependency>
<dependency>
  <groupId>org.apache.myfaces.trinidad</groupId>
  <artifactId>trinidad-api</artifactId>
  <version>2.1.0</version>
</dependency>
<dependency>
  <groupId>org.apache.myfaces.trinidad</groupId>
  <artifactId>trinidad-impl</artifactId>
  <version>2.1.0</version>
</dependency>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.1"
         xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd">
  <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>/faces/*</url-pattern>
  </servlet-mapping>

  <!-- Trinidad -->

  <filter>
    <filter-name>trinidad</filter-name>
    <filter-class>org.apache.myfaces.trinidad.webapp.TrinidadFilter</filter-class>
  </filter>

  <filter-mapping>
    <filter-name>trinidad</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
  </filter-mapping>

  <servlet>
    <servlet-name>resources</servlet-name>
    <servlet-class>org.apache.myfaces.trinidad.webapp.ResourceServlet</servlet-class>
  </servlet>

  <!-- This cannot be configured currently -->
  <servlet-mapping>
    <servlet-name>resources</servlet-name>
    <url-pattern>/adf/*</url-pattern>
  </servlet-mapping>

  <context-param>
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
    <param-value>client</param-value>
  </context-param>

  <context-param>
    <param-name>org.apache.myfaces.trinidad.ALTERNATE_VIEW_HANDLER</param-name>
    <!-- TrinidadFaceletViewHander must be the alternate view handler if SessionChangeManager is used -->
    <param-value>javax.faces.application.ViewHandler</param-value>
  </context-param>

  <context-param>
    <!--Unfortunately, Facelets provides no hook for plugging the PageResolver into the logic
      handling "facelets.VIEW_MAPPINGS". You should leave "facelets.VIEW_MAPPINGS"
      unset and use "org.apache.myfaces.trinidad.FACELETS_VIEW_MAPPINGS" instead.-->
    <param-name>org.apache.myfaces.trinidad.FACELETS_VIEW_MAPPINGS</param-name>
    <param-value>*.xhtml</param-value>
  </context-param>

  <!-- / Trinidad -->

  <session-config>
    <session-timeout>
      30
    </session-timeout>
  </session-config>
  <welcome-file-list>
    <welcome-file>faces/index.xhtml</welcome-file>
  </welcome-file-list>
</web-app>

faces-config.xml

<?xml version='1.0' encoding='UTF-8'?>
<faces-config version="2.2"
              xmlns="http://xmlns.jcp.org/xml/ns/javaee"
              xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
              xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-facesconfig_2_2.xsd">

  <application>
    <default-render-kit-id>org.apache.myfaces.trinidad.core</default-render-kit-id>
  </application>

</faces-config>

1 ответ

Решение

Error when processing tag for component with id было легко решить. Я думаю, что один даже ушел, используя урезанный документ.

Я не мог избавиться от Could not load ViewHandler предупреждение. Поэтому я пытаюсь жить с этим предупреждением (которое регистрируется только при развертывании приложения). После решения некоторых других проблем миграции JSF приложение, кажется, работает без дальнейших проблем.

Другие вопросы по тегам