使用外部按钮进行rich:fileUpload

ces*_*egb 6 java jsf richfaces web

我正在使用组件rich:fileUpload将文件上传到我的服务器,问题是这些文件与用户填写的表单一起使用,因此我想使用一个外部按钮来执行此操作.

用户选择要上载的文件,填写表单,然后单击页面底部的"提交"按钮.这会使用表单上传文件.我试过这样的:

我可以隐藏fileUpload面板内的按钮,这样用户就不会点击它.

    <rich:fileUpload id="fileUploadId"
        style="width: 100%; height: 130px;"
        fileUploadListener="#{documentsBean.listener}"
        maxFilesQuantity="1"
        uploadButtonClass="display-none"
        uploadButtonClassDisabled="display-none">
    </rich:fileUpload>
Run Code Online (Sandbox Code Playgroud)

而我用按钮试过的是

<a4j: commandButton  id="uploadFormButton"
        value="Attach"
        onclick="#{rich:component('fileUploadId')}.submitForm();"
        oncomplete="#{rich:component('fileUploadId')}.clear(); return false;"/>
Run Code Online (Sandbox Code Playgroud)

但它不起作用.

Ale*_*oie 2

我不知道是否有一种方法可以完全满足您的要求,但这是您可以使用的另一种解决方案:

<html xmlns="http://www.w3.org/1999/xhtml"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:rich="http://richfaces.org/rich"
    xmlns:a4j="http://richfaces.org/a4j"
    xmlns:st="http://spectotechnologies.com/jsf"
    xmlns:t="http://myfaces.apache.org/tomahawk">

    ...

    <h:form enctype="multipart/form-data">
        ... your fields ...

        <t:inputFileUpload value="#{bean.document}" />

        <h:commandButton value="Submit" actionListener="#{bean.onButtonSubmitClick}" />
    </h:form>
</html>
Run Code Online (Sandbox Code Playgroud)

和豆子:

@ManagedBean
@RequestScoped
public class Bean
{
    private UploadedFile m_oDocument;

    public void setDocument(UploadedFile p_oDocument)
    {
        m_oDocument = p_oDocument;
    }

    @UploadedFileNotEmpty
    @UploadedFileSize(max="10000000")
    @UploadedFileExtension(accept="doc,docx,pdf,txt,rtf,xls,xlsx,zip,rar,jpg,jpeg,jpe,bmp,gif,png,csv,ppt,pptx,odp,pic,odt,ods")
    public UploadedFile getDocument()
    {
        return m_oDocument;
    }

    public void onButtonSubmitClick(ActionEvent p_oEvent)
    {
        ...
    }
}
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助!