1

myfaces ExtensionFilterを使用してファイルをアップロードしていますが、ファイルがさらに処理するためにBeanに設定されていません。

コードは次のとおりです。

<h:form id="uploadFileForm" enctype="multipart/form-data">
    <tom:inputFileUpload id="file" 
        value="#{paramUpload.uploadFile}">
        <f:valueChangeListener type="com.bosch.de.plcd.plugin.ParamFileUpload" />
    </tom:inputFileUpload>
    <a4j:commandButton value="#{tpMsgs.upload}"
        styleClass="button" action="#{paramUpload.uploadParamFile}"
        onclick="javascript:updateParentScreen();">
    </a4j:commandButton>
</h:form>

web.xmlの構成は次のとおりです

<filter>
    <filter-name>Extensions Filter</filter-name>
    <filter-class>org.apache.myfaces.webapp.filter.ExtensionsFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>Extensions Filter</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
</filter-mapping>

Beanに設定されていないのでUploadFile、ValueChangeListenerも使用してみましたが、それでもなお、Beanではありません:)

Beanコード

public class ParamFileUpload implements ValueChangeListener {

    private UploadedFile uploadFile;

    public void uploadParamFile() {
        if(uploadFile != null) {
            LOGGER.info("File type: " + uploadFile.getContentType());
            LOGGER.info("File name: " + uploadFile.getName());
            LOGGER.info("File size: " + uploadFile.getSize() + " bytes");
        }
    }

    public UploadedFile getUploadFile() {
        return uploadFile;
    }

    public void setUploadFile(UploadedFile uploadFile) {
        this.uploadFile = (UploadedFile)uploadFile;
    }

    public void processValueChange(ValueChangeEvent event)
        throws AbortProcessingException {
        this.uploadFile = (UploadedFile) event.getNewValue();
    }
}

ここで欠落している可能性のある他の構成がありますか?

4

1 に答える 1

3

現在のJSFおよびTomahawkバージョンでは、ajaxでファイルをアップロードすることはできません。JSFによって作成されたAjaxリクエストは、をサポートも使用もしませんmultipart/form-data。Tomahawkはajaxベースのコンポーネントライブラリではありません。代わりに通常のコマンドボタンを使用してください。

<h:commandButton value="#{tpMsgs.upload}"
    styleClass="button" action="#{paramUpload.uploadParamFile}"
    onclick="javascript:updateParentScreen();">
</h:commandButton>

ajaxを使用したファイルのアップロードのサポートは、新しいコンポーネントを備えた今後のJSF2.2で予定されています。<h:inputFile>

または、RichFaces独自のを使用することもできます<rich:fileUpload>。使用するRichFacesのバージョンに応じて、Flashまたはiframeハックのいずれかを使用して、非同期ファイルアップロードを実現します。

于 2012-05-25T14:35:14.243 に答える