2012-03-01 87 views
3

我想使用JSF2.0/Primefaces使用<p:fileUpload>上傳文件。我還沒有找到任何可以幫助我的文檔。如何使用JSF/Primefaces上傳文件?

我有兩個表:Person(name,lastnam....)file(id,path,name,size) ,我想實現的方案是:

  • 用戶訂閱到我的網站,我救了他的信息,包括文件上傳
  • 當文件上傳,我要保存我的硬盤上,節省 路徑到我的數據庫
    (保持用戶和他的文件之間的關係)

所以當用戶按下按鈕保存按鈕時,我保存所有這些信息。

這裏是我的index.xhtml

<h:form > 
    <p:panel header="Add User" style="width: 500px; font-size: 14px"> 
     <h:panelGrid width="width: 300px;" columns="2"> 


     <h:outputLabel style="font-size: 13px" value="Name" /> <h:inputText value="#{AddPerson.lastname}" /> 
     <h:outputLabel value="LastName"/> <h:inputText value="#{AddPerson.name}" /> 

      <h:outputLabel value="Marital Status"/> 
      <h:selectOneMenu id="status" value="#{AddPerson.status}"> 
      <f:selectItem itemValue="Single" itemLabel="Single"/> 
      <f:selectItem itemValue="Married" itemLabel="Married"/> 
      </h:selectOneMenu> 

      <h:outputLabel value="Bith date "/> <p:calendar value="#{AddPerson.birthdate}" id="popupButtonCal" showOn="button" /> 
      <h:outputLabel value="email"/><h:inputText value="#{AddPerson.email}" /> 
      <h:outputLabel value="mobile"/><h:inputText value="#{AddPerson.mobile}" /> 
      <h:outputLabel value="fax"/><h:inputText value="#{AddPerson.fax}" /> 
      <h:outputLabel value="Job"/><h:inputText value="#{AddPerson.Job}" /> 
      <h:outputLabel value="addresse"/><h:inputText value="#{AddPerson.addresse}" /> 
      <h:outputLabel value="code"/><h:inputText value="#{AddPerson.code}" /> 
      <h:outputLabel value="Country"/><h:inputText value="#{AddPerson.country}" /> 
      <h:outputLabel value="login"/><h:inputText value="#{AddPerson.login}" /> 
      <h:outputLabel value="password"/><h:inputText value="#{AddPerson.password}" /> 

      <h:outputLabel value="CV"/> <input type="file" name="uploaded_file"/> 
      <p:fileUpload fileUploadListener="#{AddPerson...." update="messages" sizeLimit="500000" allowTypes="/(\.|\/)(gif|jpe?g|png)$/"/> 
      <p:growl id="messages" showDetail="true"/>  // **example :taken from primefaces showcases** 

      <h:commandButton action="#{AddPerson.addUserDB}" value="Add User" /> 

     </h:panelGrid> 
     </p:panel> 
</h:form> 

,這裏是My bean

public void addUserDB() { 
    try { 

     EntityTransaction entr = em.getTransaction(); 
     entr.begin(); 

     Person user = new Person(); 

     user.setNom(lastname); 
     user.setPrenom(name); 
     user.setCodepostal(code); 
     user.setEmail(email); 
     user.setEtatCivil(status); 
     user.setFax(fax); 
     user.setDateNaissance(birthdate); 
     user.setMobile(mobile); 
     user.setAdresse(addresse); 
     user.setPays(country); 
     user.setLogin(login); 
     user.setPassword(password); 

     //**I should also add here the path of the file to the table and save the file on the disc !!!!**   

     em.persist(user); 

     entr.commit(); 
    } catch (Exception e) { 
     System.out.println(e.getMessage()); 
     System.out.println("Failed"); 
    } finally { 
     em.close(); 
    } 

} 
+2

PrimeFaces有確鑿例子展示:http://www.primefaces.org/showcase/ui/fileUploadHome.jsf PrimeFaces也有一個用戶指南:http://www.primefaces.org/documentation。 html – BalusC 2012-03-01 19:41:40

+0

你在WEB-INF/lib下添加了兩個jar文件嗎? common-fileupload.jar和common.io.jar – 2013-10-25 06:12:21

回答

10

哪來的fileUploadListener的實施?我通常只是這樣做:

<p:fileUpload cancelLabel="#{msg['cancel']}" update="someComponent" 
fileUploadListener="#{someBean.uploadListener}" 
multiple="false" sizeLimit="1000000" allowTypes="/(\.|\/)(gif|jpe?g|png)$/" /> 

然後我的bean有一個方法來處理文件上傳事件。事情是這樣的:

public void fileUpload(FileUploadEvent event) throws IOException { 
    String path = FacesContext.getCurrentInstance().getExternalContext() 
      .getRealPath("/"); 
    SimpleDateFormat fmt = new SimpleDateFormat("yyyyMMddHHmmss"); 
    String name = fmt.format(new Date()) 
      + event.getFile().getFileName().substring(
        event.getFile().getFileName().lastIndexOf('.')); 
    File file = new File(path + "catalogo_imagens/temporario/" + nome); 

    InputStream is = event.getFile().getInputstream(); 
    OutputStream out = new FileOutputStream(file); 
    byte buf[] = new byte[1024]; 
    int len; 
    while ((len = is.read(buf)) > 0) 
     out.write(buf, 0, len); 
    is.close(); 
    out.close(); 
} 

保持到剛剛保存和使用,在您的addUserDB()方法中設置相應的用戶屬性的文件路徑參考。所以這是一個兩步驟的過程。您首先將文件保存在服務器的某個位置,然後保存您的用戶。

+0

我試過這個,但文件保存在D:\ MyDocuments \ MySites \ MySiteExample \ build \ web \ eventImage137.jpg 有沒有什麼辦法不把它保存在BUILD文件夾,但在「真實」的Web文件夾? – vtomic85 2014-06-12 19:43:03

+2

真的,你可以隨時隨地保存。只需相應地設置路徑變量即可。儘管不要對其進行硬編碼,因爲如果最終在具有不同操作系統的不同服務器上運行此操作,可能會遇到問題。也許使用環境變量或java參數來設置文件將被保存的位置。 – Andre 2014-06-13 12:56:33

+0

嗨@Andre你能澄清誰「使用環境變量或java參數來設置文件將被保存的位置」,請 – 2014-11-24 23:36:10

3

fileUpload有fileUploadListener。請注意,您應該實現邏輯以將文件內容保存到您的後臺bean中。

<p:fileUpload fileUploadListener="#{fileBean.handleFileUpload}"> 

public class FileBean { 
    public void handleFileUpload(FileUploadEvent event) { 
     UploadedFile file = event.getFile(); 
     String fileName = file.getFileName(); 
     long fileSize = file.getSize(); 
     InputStream myInputStream = file.getInputstream(); 
     //Save myInputStream in a directory of your choice and store that path in DB 
    } 
}