Событие PrimeULL FileUpload не запускается - JSF 2.0

Я разместил свой вопрос на форуме Primefaces, но никто не ответил, поэтому я решил попробовать здесь.

Я пытался заставить fileUpload работать в течение некоторого времени. В настоящее время я использую сборку RC2 с mojarra 2.0.3 и Tomcat 7.

У меня есть диалог, который будет содержать компонент fileUpload, как это.

<p:dialog id="uploadFileDialog" >
   <h:form id="uplaodFileForm" prependId="false" enctype="multipart/form-data">
       <p:fileUpload fileUploadListener="#{fileUploadController.uploadFile} auto="true"/>    
   </h:form>
</p:dialog>

FileUploadController выглядит так

public class FileUploadController {
    public void uploadFile(FileUploadEvent event) {
         byte[] file = event.getFile().getContents();

         System.out.println("MADE IT INTO FILE UPLOAD !!! ");
    }
}

По какой-то причине, когда файл загружен, он никогда не вызывает fileUploadEvent и никогда не попадает в контроллер. Загрузка выглядит так, как будто она работает, часть флеш-памяти визуализируется, и создается впечатление, что она что-то делает, но никакой вспомогательный компонент не вызывается. Я могу понять, что я делаю неправильно, и я прочитал почти каждый пост о загрузке файла с использованием простых символов. Кто-нибудь знает, что я делаю не так?

6 ответов

java.lang.ClassNotFoundException: org.apache.commons.io.output.DeferredFileOutputStream

Загрузка файла PrimeFaces использует Apache Commons FileUpload под прикрытием, которое, в свою очередь, имеет другую зависимость, Apache Commons IO. Убедитесь, что вы оба JAR в вашем /WEB-INF/lib,


Обновление: согласно комментариям, вы также должны убедиться, что фильтр загрузки был объявлен в web.xml согласно руководству пользователя:

<filter>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
</filter-mapping>

И вам также нужно убедиться, что в web.xml который может читать HttpServletRequest#getInputStream() потому что его можно прочитать только один раз.

Это правильно, вы должны добавить

<filter>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
</filter-mapping>

И позже это

<!-- JSF mapping -->
<servlet>
   <servlet-name>Faces Servlet</servlet-name>
   <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
   <load-on-startup>1</load-on-startup>
</servlet>

<!-- Map these files with JSF -->
<servlet-mapping>
   <servlet-name>Faces Servlet</servlet-name>
   <url-pattern>*.jsf</url-pattern>
</servlet-mapping>

Кроме того, если вы используете Maven добавить эти зависимости

<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.2.1</version>
</dependency>     
<dependency>
     <groupId>org.apache.commons</groupId>
     <artifactId>commons-io</artifactId>
     <version>1.3.2</version>
</dependency>
<dependency>
     <groupId>portlet-api</groupId>
     <artifactId>portlet-api</artifactId>
     <version>1.0</version>
</dependency>

Я также столкнулся с подобной проблемой. Исправление для меня (с помощью проекта Maven) заключалось в добавлении следующих зависимостей в файл pom.xml:

    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-io</artifactId>
        <version>1.3.2</version>
    </dependency>
    <dependency>
        <groupId>commons-fileupload</groupId>
        <artifactId>commons-fileupload</artifactId>
        <version>1.2.1</version>
    </dependency>

Это эквивалентно наличию соответствующих файлов.jar в вашем WEB-INF/lib, поэтому попробуйте сделать это, если это не проект Maven.

Я думаю, что я решил вашу проблему. Проверьте на своем web.xml наличие:

<context-param>
    <param-name>com.sun.faces.enableViewStateIdRendering</param-name>
    <param-value>false</param-value>
</context-param>

Вы должны удалить эту опцию или установить для нее значение True (значение по умолчанию).

У меня та же проблема, я решил ее, добавив

<filter>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
</filter-mapping>

как сказал BalusC.

но добавив это:

<!-- JSF mapping -->
<servlet>
   <servlet-name>Faces Servlet</servlet-name>
   <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
   <load-on-startup>1</load-on-startup>
</servlet>

<!-- Map these files with JSF -->
<servlet-mapping>
   <servlet-name>Faces Servlet</servlet-name>
   <url-pattern>*.jsf</url-pattern>
</servlet-mapping>

Поскольку по умолчанию в J2EE 6 эта часть является необязательной, сервлет JSF 2.0 активируется автоматически, когда присутствует дескриптор WEB-INF/face-config.xml.

Но для этого необходимо правильно активировать PrimeFaces Filter

Jboss 6.1.0.Final / PrimeFaces 3.0.RC2

В Websphere 7 событие вызывается, потому что когда я выбираю файл и нажимаю кнопку загрузки, я вижу полосу загрузки, которая растет. Проблема в том, что в Websphere 7 я предполагаю, что есть фильтр, который использует HttpRequest, а когда приходит в слушатель событий, он просто потребляется, поэтому не имеют данных:(

В журнале нет сообщений, отладка очень сложная. Существует ли какая-нибудь трассировка или логгер для включения в JSF 2 Mojarra 2 и PrimeFaces 3.4.2?

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