FileDownload和FileUpload JSF Primefaces无法正常工作

时间:2012-11-20 10:27:34

标签: jsf primefaces

我正在使用PrimeFaces 3.1.2,NetBeans 7.2,JSF 2.1和GlassFish 3.1.2。

我正在使用我从http://www.primefaces.org/showcase/ui/fileUploadAuto.jsf获得的实际代码 和http://www.primefaces.org/showcase/ui/fileDownload.jsf

当我运行文件上传代码时,它根本不起作用。文件未上传,未显示成功消息。但是,如果文件大小超过上述大小,则会显示一条消息,指出文件太大。

以下是我的观点:

<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<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:p="http://primefaces.org/ui">
    <h:head>
    </h:head>
    <h:body>
        <h:form enctype="multipart/form-data">
            <p:fileUpload fileUploadListener="#{fileUploadController.handleFileUpload}"
                mode="advanced"
                update="messages"
                auto="true"
                sizeLimit="100000" 
                allowTypes="/(\.|\/)(gif|jpe?g|png)$/"/>
            <p:growl id="messages" showDetail="true"/>
        </h:form>
    </h:body>
</html>

这是我的支持bean:

package com;

import javax.faces.application.FacesMessage;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.context.FacesContext;
import org.primefaces.event.FileUploadEvent;

@ManagedBean
@SessionScoped
public class FileUploadController {
    public void handleFileUpload(FileUploadEvent event) {
        FacesMessage msg = new FacesMessage("Succesful",   event.getFile().getFileName() + " is uploaded.");
        FacesContext.getCurrentInstance().addMessage(null, msg);
    }
}

它与PrimeFaces展示页面中的代码基本相同。

与文件下载代码类似;当我点击下载时没有任何反应。弹出窗口打开和关闭,然后才能注意到它。我有get资源流中提到的图像文件(对于下载部分),但我不知道是什么问题。代码也与PrimeFaces展示页面中的代码基本相同。

我在Netbeans的Glassfish下看不到任何日志或错误。我还不知道如何在必要时启用日志记录。

3 个答案:

答案 0 :(得分:9)

您需要的第一件事是在应用程序中添加一些库。事实上,PrimeFaces文件上传依赖于Apache commons-file-upload和commons-io库。因此下载它们并将它们添加到WEB-INF / lib路径:

您可以从以下链接下载。

http://commons.apache.org/io/

http://commons.apache.org/fileupload/

此外,您必须将其配置为web.xml

<filter>
  <filter-name>PrimeFaces FileUpload Filter</filter-name>
  <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class>
  <init-param>
    <param-name>thresholdSize</param-name>
    <param-value>51200</param-value>
  </init-param>
  <init-param>
    <param-name>uploadDirectory</param-name>
    <param-value>C:\etc</param-value>
   </init-param>
</filter>
<filter-mapping>
  <filter-name>PrimeFaces FileUpload Filter</filter-name>
  <servlet-name>Faces Servlet</servlet-name>
</filter-mapping>

此外,如果您想以编程方式设置更改上传文件的目的地,请查看:

PrimeFaces FileUpload File Saving Destination

答案 1 :(得分:1)

为了能够使用xhtml中的bean,您需要将控制器注释为@ManagedBean并设置一些范围。在这种情况下,最好是@ViewScoped或@RequestScoped。

示例:

@ManagedBean
@ViewScoped
public class FileUploadController {

    public void handleFileUpload(FileUploadEvent event) {
        FacesMessage msg = new FacesMessage("Succesful",     event.getFile().getFileName() + " is uploaded.");
        FacesContext.getCurrentInstance().addMessage(null, msg);
    }
}

详细了解jsf托管bean如何在此处运行:http://www.mkyong.com/jsf2/configure-managed-beans-in-jsf-2-0/

答案 2 :(得分:1)

我注意到的一件事是,如果你没有正确地在标签“allowTypes”中加入正则表达式,那么“fileupload”元素不会触发操作,给人的印象是操作无法访问。

我知道现在这不是你的问题,但我认为分享这些信息非常重要。