0

ここで明らかな何かが欠けているかもしれませんが、これを機能させる方法がわからないようです。

テキストフィールド、1つのメニューの選択、オートコンプリート、エディター、およびfileuploadオブジェクトを含むap:dialogがあります。ユーザーがフィールドにいくつかの情報を入力し、オプションでファイルアップロードにいくつかのファイルを添付してから、ダイアログの送信ボタンを押して、バッキングBeanを呼び出し、処理を実行して、必要な場所にファイルを取得するという考え方です。 。ユーザーが複数のファイルを添付できるように、高度なファイルアップローダーを使用したいと思います。ユーザーが送信ボタンを押すと、ファイルアップローダーを除くすべてのデータが適切に送信されます。アップロードリスナーが起動されることはありません。

オンラインで検索したところ、wigdetVar.upload()を呼び出してアップロードをトリガーできる可能性があるという言及がありましたが、JavaScriptエラーがスローされるだけで、さらに検索すると、機能が利用できなくなっている可能性があります。

問題は、送信ボタンからフォームの残りの部分と一緒にファイルを送信するにはどうすればよいですか?ダイアログのコードは次のとおりです。

<p:dialog widgetVar="newthreaddialog" modal="true" header="New Thread for #{collaborationBacking.patientName}" dynamic="true"
                       resizeable="false">
              <div class="whitebox">
                 <h:form id="newthreadform" enctype="multipart/form-data">
                    <p:panelGrid>
                       <p:row>   
                          <p:column>
                             <p:messages/>
                             <h:outputLabel for="threadtitle" value="Thread Title: "/>
                             <p:inputText id="threadtitle" label="Thread Title" value="#{newCollabThreadBacking.title}" required="true"/>
                          </p:column>
                          <p:column>
                             <h:outputLabel for="threadtype" value="Type: "/>
                             <h:selectOneMenu id="threadtype" label="Thread Type" value="#{newCollabThreadBacking.type}">
                                <f:selectItems value="#{newCollabThreadBacking.typeList}"/>
                             </h:selectOneMenu>
                          </p:column>
                       </p:row>

                       <p:row>
                          <p:column colspan="2">
                             <h:outputLabel for="addressedTo" value="To: "/>
                             <p:autoComplete id="addressedTo" value="#{newCollabThreadBacking.addressedTo}"
                                                   completeMethod="#{newCollabThreadBacking.completeAddress}"
                                                   var="practice"
                                                   itemValue="#{practice}"
                                                   itemLabel="#{practice.name}"
                                                   converter="practiceConverter"
                                                   forceSelection="true"/>
                          </p:column>
                       </p:row>


                       <p:row>
                          <p:column colspan="2">
                             <p:editor value="#{newCollabThreadBacking.content}" label="Message Content" required="true"/>
                          </p:column>
                       </p:row>

                       <p:row>
                          <p:column colspan="2">
                             <p:fileUpload widgetVar="uploader" fileUploadListener="#{newCollabThreadBacking.fileUpload}"/>
                          </p:column>
                       </p:row>

                       <p:row>
                          <p:column colspan="2">
                             <span class="submit">
                                <p:commandButton id="submitthread" value="Submit" action="#{newCollabThreadBacking.saveThread}"
                                                          oncomplete="newThreadResult(xhr, status, args)"
                                                          onclick="uploader.upload();"
                                                          process="@form" update="@form"/>
                             </span>
                          </p:column>
                       </p:row>                              
                    </p:panelGrid>
                 </h:form>
              </div>

              <p:ajax event="close" listener="#{collaborationBacking.reloadThreads}" update="threadtable newthreadform"/>
           </p:dialog> <!-- newthreaddialog -->
4

1 に答える 1

0

ファイル アップロード フィルタを追加しましたか? サーバーにファイルをアップロードできるようにするには、web.xml ファイルに fileUpload フィルターを追加する必要があります。以下を 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>
于 2012-04-13T00:20:55.560 に答える